# **TOSHIBA**

TOSHIBA Original CMOS 16-Bit Microcontroller

TLCS-900/L Series

TMP93CS40/41

## **TOSHIBA CORPORATION**

Semiconductor Company

## **Preface**

Thank you very much for making use of Toshiba microcomputer LSIs. Before use this LSI, refer the section, "Points of Note and Restrictions". Especially, take care below cautions.

### \*\*CAUTION\*\*

#### How to release the HALT mode

Usually, interrupts can release all halts status. However, the interrupts =  $(\overline{\text{NMI}}, \text{INT0})$ , which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 3 clocks of fFPH) with IDLE1 or STOP mode (IDLE2 and RUN are not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficultly. The priority of this interrupt is compare with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

### Low Voltage/Low Power CMOS 16-Bit Microcontrollers

## TMP93CS40F/TMP93CS41F TMP93CS40DF/TMP93CS41DF

#### 1. Outline and Device Characteristics

The TMP93CS40/S41 are high-speed advanced 16-bit microcontrollers developed for controlling medium to large-scale equipment. The TMP93CS41 does not have a ROM; the TMP93CS40 has a built-in ROM. Otherwise, the devices function in the same way.

The TMP93CS40/S41F are housed in a 100-pin flat package.

The device characteristics are as follows:

#### (1) Original 16-bit CPU (900/L CPU)

- TLCS-90 instruction mnemonic upward compatible
- 16-Mbyte linear address space
- General-purpose registers, register bank system
- 16-bit multiplication/division and bit transfer/arithmetic instructions
- Micro DMA: 4 channels (1.6 µs/2 bytes at 20 MHz)
- (2) Minimum instruction execution time: 200 ns at 20 MHz
- (3) Internal RAM: 2 Kbytes

Internal ROM:

| TMP93CS40 | 64-Kbyte ROM |
|-----------|--------------|
| TMP93CS41 | None         |

#### (4) External memory expansion

- Can be expanded up to 16 Mbytes (for both programs and data).
- AM8/ AM16 pin (selects the external data bus width)
- Can mix 8-/16-bit external data buses.
  - ..... Dynamic bus sizing
- (5) 8-bit timer: 2 channels

030619EBP1

- The information contained herein is subject to change without notice.
- The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of TOSHIBA or others.
- TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property.

- property.
  In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc..

  The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment requires extraordinarily light quality and/or reliability or a malfunctionor failure of which may cause less of human life as hadily injury ("Using the plant"). In his tended these industries are used to the product and the product and products are neither intended nor warranted for usage in equipment, injury ("Using the plant"). In his tended these injury and the products are neither intended and products are neither intended and products are neither intended and products are neither intended for usage in equipment, injury ("Using the plant"). In the product are neither the products are neither intended and products are neither intended for usage in equipment. failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk
- The products described in this document are subject to the foreign exchange and foreign trade laws.
   TOSHIBA products should not be embedded to the downstream products which are prohibited to be produced and sold, under any law
- and regulations.
- For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions.

93CS40-1 2004-02-10

- (6) 8-bit PWM timer: 2 channels
- (7) 16-bit timer: 2 channels
- (8) 4-bit pattern generator: 2 channels
- (9) Serial interface: 2 channels
- (10) 10-bit AD converter: 8 channels
- (11) Watchdog timer
- (12) Chip select/wait controller: 3 blocks
- (13) Interrupt functions: 29
  - 9 CPU interrupts .... SWI instruction, and illegal instruction
  - 14 internal interrupts
    6 external interrupts
    7-level priority can be set.
- (14) I/O ports

79 pins for TMP93CS40 and 61 pins for TMP93CS41

- (15) Standby function: 4 HALT modes (RUN, IDLE2, IDLE1, STOP)
- (16) Clock gear function
  - Dual clock operation
  - Clock gear: High-frequency clock can be varied from fc to fc/16.
- (17) Wide operating voltage
  - Vcc = 2.7 to 5.5 V

#### (18) Package

| Type No.                   | Package              |  |
|----------------------------|----------------------|--|
| TMP93CS40F<br>TMP93CS41F   | P-QFP100-1414-0.50   |  |
| TMP93CS40DF<br>TMP93CS41DF | P-LQFP100-1414-0.50F |  |



Figure 1.1 TMP93CS40/TMP93CS41 Block Diagram

## 2. Pin Assignment and Functions

The assignment of input/output pins on the TMP93CS40/TMP93CS41, their names and outline functions are described below.

### 2.1 Pin Assignment

Figure 2.1.1 shows the pin assignment for the TMP93CS40F/S41F and TMP93CS40DF/S41DF.



Note: Because the TMP93CS41 does not have an internal ROM, pins P00 to P17 are tied to AD0 to AD15 (when AM8/ $\overline{\text{AM16}} = 0$ ), or to AD0 to AD7 and A8 to A15 (when AM8/ $\overline{\text{AM16}} = 1$ ). P30 is tied to  $\overline{\text{RD}}$ , P31 to  $\overline{\text{WR}}$ .

Figure 2.1.1 Pin Assignment (100-Pin QFP and 100-Pin LQFP)

## 2.2 Pin Names and Functions

The names of the input/output pins and their functions are described below.

Table 2.2.1 to Table 2.2.4 show pin names and functions.

Table 2.2.1 Pin Names and Functions (1/4)

| Pin Names        | Number of Pins | I/O       | Functions                                                                   |  |
|------------------|----------------|-----------|-----------------------------------------------------------------------------|--|
| P00 to P07       | 8              | I/O       | Port 0: I/O port that allows at the bit level                               |  |
| AD0 to AD7       |                | Tri-state | Address/data (lower): Bits 0 to 7 of address/data bus                       |  |
| P10 to P17       | 8              | I/O       | Port 1: I/O port that allows at the bit level                               |  |
| AD8 to AD15      |                | Tri-state | Address data (upper): Bits 8 to 15 of address/data bus                      |  |
| A8 to A15        |                | Output    | Address: Bits 8 to 15 of address bus                                        |  |
| P20 to P27       | 8              | I/O       | Port 2: I/O port that allows selection of I/O at the bit level              |  |
|                  |                |           | (with pull-down resistor)                                                   |  |
| A0 to A7         |                | Output    | Address: bits 0 to 7 of address bus                                         |  |
| A16 to A23       |                | Output    | Address: bits 16 to 23 of address bus                                       |  |
| P30              | 1              | Output    | Port 30: Output port                                                        |  |
| RD               |                | Output    | Read: Strobe signal for reading external memory                             |  |
| P31              | 1              | Output    | Port 31: Output port                                                        |  |
| WR               |                | Output    | Write: Strobe signal for writing data on pins AD0 to AD7                    |  |
| P32              | 1              | I/O       | Port 32: I/O port (with pull-up resistor)                                   |  |
| HWR              |                | Output    | High write: Strobe signal for writing data on pins AD8 to AD15              |  |
| P33              | 1              | I/O       | Port 33: I/O port (with pull-up resistor)                                   |  |
| WAIT             |                | Input     | Wait: in used to request CPU bus wait                                       |  |
| P34              | 1              | I/O       | Port 34: I/O port (with pull-up resistor)                                   |  |
| BUSRQ            |                | Input     | Bus request: Signal used to request bus release                             |  |
| P35              | 1              | I/O       | Port 35: I/O port (with pull-up resistor)                                   |  |
| BUSAK            |                | Output    | Bus acknowledge: Signal used to acknowledge bus release                     |  |
| P36              | 1              | I/O       | Port 36: I/O port (with pull-up resistor)                                   |  |
| $R/\overline{W}$ |                | Output    | Read/write: 1 represents read or dummy cycle; 0 represents write cycle.     |  |
| P37              | 1              | I/O       | Port 37: I/O port (with pull-up resistor)                                   |  |
| RAS              |                | Output    | Row address strobe: Outputs RAS strobe for DRAM.                            |  |
| P40              | 1              | I/O       | Port 40: I/O port (with pull-up resistor)                                   |  |
| CS0              |                | Output    | Chip select 0: Outputs 0 when address is within specified address area.     |  |
| CAS0             |                | Output    | Column address strobe 0: Outputs CAS strobe for DRAM when address is within |  |
|                  |                |           | specified address area.                                                     |  |

Note: This device's built-in memory or built-in I/O cannot be accessed by an external DMA controller using the BUSRQ and BUSAK signals.

Table 2.2.2 Pin Names and Functions (2/4)

| Pin Names    | Number of Pins | I/O    | Functions                                                                                               |  |
|--------------|----------------|--------|---------------------------------------------------------------------------------------------------------|--|
| P41          | 1              | I/O    | Port 41: I/O port (with pull-up resistor)                                                               |  |
| CS1          |                | Output | Chip select 1: Outputs 0 if address is within specified address area.                                   |  |
| CAS1         |                | Output | Column address strobe 1: Outputs CAS strobe for DRAM if address is within specified                     |  |
|              |                |        | address area.                                                                                           |  |
| P42          | 1              | I/O    | Port 42: I/O port (with pull-down resistor)                                                             |  |
| CS2          |                | Output | Chip select 2: Outputs 0 if address is within specified address area.                                   |  |
| CAS2         |                | Output | Column address strobe 2: Outputs $\overline{\text{CAS}}$ strobe for DRAM if address is within specified |  |
|              |                |        | address area.                                                                                           |  |
| P50 to P57   | 8              | Input  | Port 5: Input port                                                                                      |  |
| AN0 to AN7   |                | Input  | Analog input: Analog signal input for AD converter                                                      |  |
| VREFH        | 1              | Input  | Pin for high level reference voltage input to AD converter                                              |  |
| VREFL        | 1              | Input  | Pin for low level reference voltage input to AD converter                                               |  |
| P60 to P63   | 4              | I/O    | Ports 60 to 63: I/O ports that allow selection of I/O at the bit level                                  |  |
|              |                |        | (with pull-up resistor)                                                                                 |  |
| PG00 to PG03 |                | Output | Pattern generator ports: 00 to 03                                                                       |  |
| P64 to P67   | 4              | I/O    | Ports 64 to 67: I/O ports that allow selection of I/O on a bit basis                                    |  |
|              |                |        | (with pull-up resistor)                                                                                 |  |
| PG10 to PG13 |                | Output | Pattern generator ports: 10 to 13                                                                       |  |
| P70          | 1              | I/O    | Port 70: I/O port (with pull-up resistor)                                                               |  |
| TI0          |                | Input  | Timer input 0: Timer 0 input                                                                            |  |
| P71          | 1              | I/O    | Port 71: I/O port (with pull-up resistor)                                                               |  |
| TO1          |                | Output | Timer output 1: Timer 0 or timer 1 output                                                               |  |
| P72          | 1              | I/O    | Port 72: I/O port (with pull-up resistor)                                                               |  |
| TO2          |                | Output | PWM output 2: 8-bit PWM timer 2 output                                                                  |  |
| P73          | 1              | I/O    | Port 73: I/O port (with pull-up resistor)                                                               |  |
| TO3          |                | Output | PWM output 3: 8-bit PWM timer 3 output                                                                  |  |
| P80          | 1              | I/O    | Port 80: I/O port (with pull-up resistor)                                                               |  |
| TI4          |                | Input  | Timer input 4: Timer 4 count/capture trigger signal input Interrupt request pin 4:                      |  |
| INT4         |                | Input  | Interrupt request pin with programmable rising/falling edge                                             |  |
| P81          | 1              | I/O    | Port 81: I/O port (with pull-up resistor)                                                               |  |
| TI5          |                | Input  | Timer input 5: Timer 5 count/capture trigger signal input                                               |  |
| INT5         |                | Input  | Interrupt request pin 5: Interrupt request pin with rising edge                                         |  |
| P82          | 1              | I/O    | Port 82: I/O port (with pull-up resistor)                                                               |  |
| TO4          |                | Output | Timer output 4: Timer 4 output pin                                                                      |  |
| P83          | 1              | I/O    | Port 83: I/O port (with pull-up resistor)                                                               |  |
| TO5          |                | Output | Timer output 5: Timer 4 output pin                                                                      |  |

Table 2.2.3 Pin Names and Functions (3/4)

| Pin Names  | Number of Pins | I/O    | Functions                                                                            |  |
|------------|----------------|--------|--------------------------------------------------------------------------------------|--|
| P84        | 1              | I/O    | Port 84: I/O port (with pull-up resistor)                                            |  |
| TI6        |                | Input  | Timer input 6: Timer 5 count/capture trigger signal input                            |  |
| INT6       |                | Input  | Interrupt request pin 6: Interrupt request pin with programmable rising/falling edge |  |
|            |                |        |                                                                                      |  |
| P85        | 1              | I/O    | Port 85: I/O port (with pull-up resistor)                                            |  |
| TI7        |                | Input  | Timer input 7: Timer 5 count/capture trigger signal input                            |  |
| INT7       |                | Input  | Interrupt request pin 7: Interrupt request pin with rising edge                      |  |
| P86        | 1              | I/O    | Port 86: I/O port (with pull-up resistor)                                            |  |
| TO6        |                | Output | Timer output 6: Timer 5 output pin                                                   |  |
| P87        | 1              | I/O    | Port 87: I/O port (with pull-up resistor)                                            |  |
| INT0       |                | Input  | Interrupt request pin 0: Interrupt request pin with programmable level/rising edge   |  |
| P90        | 1              | I/O    | Port 90: I/O port (with pull-up resistor)                                            |  |
| TXD0       |                | Output | Serial data send 0                                                                   |  |
| P91        | 1              | I/O    | Port 91: I/O port (with pull-up resistor)                                            |  |
| RXD0       |                | Input  | Serial data receive 0                                                                |  |
| P92        | 1              | I/O    | Port 92: I/O port (with pull-up resistor)                                            |  |
| CTS0       |                | Input  | Serial data send enable 0 (Clear to send)                                            |  |
| SCLK0      |                | I/O    | Serial Clock I/O 0                                                                   |  |
| P93        | 1              | I/O    | Port 93: I/O port (with pull-up resistor)                                            |  |
| TXD1       |                | Output | Serial data send 1                                                                   |  |
| P94        | 1              | I/O    | Port 94: I/O port (with pull-up resistor)                                            |  |
| RXD1       |                | Input  | Serial data receive 1                                                                |  |
| P95        | 1              | I/O    | Port 95: I/O port (with pull-up resistor)                                            |  |
| SCLK1      |                | I/O    | Serial clock I/O 1                                                                   |  |
| PA0 to PA6 | 7              | I/O    | Ports A0 to A6: I/O ports                                                            |  |
| PA7        | 1              | I/O    | Port A7: I/O port                                                                    |  |
| SCOUT      |                | Output | System clock output: Outputs f <sub>FPH</sub> or f <sub>SYS</sub> clock.             |  |
| WDTOUT     | 1              | Output | Watchdog timer output pin                                                            |  |
| NMI        | 1              | Input  | Non-maskable interrupt request pin: Interrupt request pin with programmable falling  |  |
|            |                | F      | edge or with both edges programmable.                                                |  |
| CLK        | 1              | Output | Clock output: Outputs [f <sub>SYS</sub> ÷ 2] clock.                                  |  |
|            |                |        | Pulled-up during reset.                                                              |  |
|            |                |        | Can be disabled to reduce noise.                                                     |  |
| ĒĀ         | 1              | Input  | External access: On the TMP93CS41, the Vss pin should be connected.                  |  |
|            |                |        | On the TMP93CS40, the Vcc pin should be connected.                                   |  |

Table 2.2.4 Pin Names and Functions (4/4)

| Pin Names   | Number of Pins | I/O          | Functions                                                                    |  |  |
|-------------|----------------|--------------|------------------------------------------------------------------------------|--|--|
| AM8/ AM16   | 1              | Input        | Address mode: Selects external data bus width.                               |  |  |
|             |                |              | (On the TMP93CS40)                                                           |  |  |
|             |                |              | The Vcc pin should be connected. The data bus width for external             |  |  |
|             |                |              | access is set by the chip select/WAIT control register, port 1 control       |  |  |
|             |                |              | register.                                                                    |  |  |
|             |                |              | (On the TMP93CS41)                                                           |  |  |
|             |                |              | The Vss pin should be connected to access either fixed 16-bit bus            |  |  |
|             |                |              | width, or 16-bit bus interchangeable with 8-bit bus.                         |  |  |
|             |                |              | The Vcc pin should be connected to access a fixed 8-bit bus width.           |  |  |
| ALE         | 1              | Output       | Address latch enable                                                         |  |  |
|             |                |              | (Can be disabled to reduce noise.)                                           |  |  |
| RESET       | 1              | Input        | Reset: Initializes TMP93CS40/TMP93CS41. (with pull-up resistor)              |  |  |
| X1/X2       | 2              | I/O          | High-frequency oscillator connecting pin                                     |  |  |
| P96         | 1              | I/O          | Port 96: I/O port (open-drain output)                                        |  |  |
| XT1         |                | Input        | Low-frequency oscillator connecting pin                                      |  |  |
| P97         | 1              | I/O          |                                                                              |  |  |
| XT2         |                | Output       | Low-frequency oscillator connecting pin                                      |  |  |
| TEST1/TEST2 | 2              | Output/Input | TEST1 pin should be connected to TEST2 pin.                                  |  |  |
|             |                |              | Don't connect to any other pins.                                             |  |  |
| VCC         | 3              |              | Power supply pin (All VCC pins should be connected to the power supply pin.) |  |  |
| VSS         | 3              |              | GND pin (0 V) (All VSS pins should be connected to GND (0 V).)               |  |  |
| AVCC        | 1              |              | Power supply pin for AD converter                                            |  |  |
| AVSS        | 1              |              | GND pin for AD converter (0 V)                                               |  |  |

Note: All pins that have built-in pull-up/pull-down resistors (other than the RESET pin) can be disconnected from the built-in pull-up/pull-down resistor by software.

## 3. Operation

This section describes in blocks the functions and basic operations of TMP93CS40 and TMP93CS41 devices. Please also refer to section 7. Precautions in use, which describes some points requiring careful attention.

#### 3.1 CPU

TMP93CS40 and TMP93CS41 devices have a built-in high-performance 16-bit CPU (900/L CPU). (For basics of the CPU operation, see the information on the TLCS-900/L CPU in the previous chapter.)

This section describes some CPU functions unique to the TMP93CS40 and TMP93CS41, that are not described in the previous chapter, entitled TLCS-900/L CPU.

#### 3.1.1 Reset

When resetting the TMP93CS40 and TMP93CS41 microcontroller, ensure that the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then set the  $\overline{\text{RESET}}$  input to low level at least for 10 system clocks (16  $\mu$ s at 20 MHz). Thus, when turn on the switch, be set to the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then hold the  $\overline{\text{RESET}}$  input to low level at least for 10 system clocks.

Clock gear is initialized 1/16 mode by reset operation. It means that the system clock mode fSYS is set to fc/32 (= fc/16  $\times$  1/2).

When a reset signal is accepted, the CPU sets itself as follows:

The program counter (PC) is set according to the reset vector that is stored from 8000H to 8002H.

PC<7:0> ← Data in location 8000H PC<15:8> ← Data in location 8001H PC<23:16> ← Data in location 8002H

- The stack pointer (XSP) for system mode is set to 100H.
- The <IFF2:0> bits of the status register SR are set to 111. (Sets mask register to interrupt level 7.)
- The <MAX> bit of SR is set to 1. (Sets to maximum mode. See previous chapter.)
- The <RFP2:0> bits of SR are set to 000. (Clears register banks to 0.)

When the reset is released, instruction execution starts from PC (The reset vector). The reset makes no changes in any CPU internal registers other than those specifically mentioned above.

When a reset is received, signal and data processing for built-in I/Os, ports, and other pins is affected as follows:

- Initializes built-in I/O registers as per specifications.
- Sets port pins (including pins also used as built-in I/Os) to general-purpose input/output port mode.
- Sets the WDTOUT pin to 0. (The watchdog timer is set to enable after reset.)
- Pulls up the CLK pin to 1.
- Sets the ALE pin to 0 in the case of the TMP93CS41, and to high impedance (High-Z) in the case of TMP93CS40.
- Note 1: Resetting makes no change in any register in the CPU except the program counter (PC), status register (SR) and stack pointer (XSP), nor in the data in the internal RAM.
- Note 2: The CLK pin is pulled up during reset. When the voltage is externally reduced, there is a possibility of causing malfunctions.

Figure 3.1.1 and Figure 3.1.2 show the reset timing chart of the TMP93CS41 and TMP93CS40.



Figure 3.1.1 TMP93CS41 Reset Timing Chart



Figure 3.1.2 TMP93CS40 Reset Timing Chart

#### 3.1.2 AM8/AM16 Pin

#### (1) TMP93CS40

Set this pin to 1. Resetting accesses a built-in ROM via the internal 16-bit bus. When accessing externally, the bus width is set by the chip select/wait control register described in 3.6.3, and the registers of port 1.

### (2) TMP93CS41

1. With fixed 16-bit data bus or with 16-bit data bus interchangeable with 8-bit data bus.

Set this pin to 0. Port 1, AD8 to AD15 or A8 to A15 pins are fixed to AD8 to AD15 functions. Any values set in the port 1 control register or the port 1 function register are invalid.

The external data bus width is set by the chip select/wait control register.

After reset, it is necessary to set the program memory to be accessed, to 16-bit data bus.

### 2. With fixed external 8-bit data bus

Set this pin to 1. Port 1, AD8 to AD15 or A8 to A15 pins are fixed to A8 to A15 functions. Any values set in the port 1 control register or the port 1 function register are invalid.

The values of Bit4 <B0BUS>, <B1BUS> and <B2BUS> in the chip select/wait control register, which are described in 3.6.2, are invalid. The external 8-bit data bus is fixed.

## 3.2 Memory Map

Figure 3.2.1 is a memory map of the TMP93CS40 and TMP93CS41.



Note: The 256-byte area from FFFF00H to FFFFFH can not be used.

Figure 3.2.1 Memory Map

### 3.3 Dual Clock, Standby Function

Dual clock, standby control circuits are comprised of a system clock controller, prescaler clock controller, internal clock pin output function and standby controller.

The oscillator operating modes are classified as either (a) Single clock mode (using only the X1 and X2 pins), or (b) Dual clock mode (using the X1, X2, XT1, and XT2 pins).

Figure 3.3.1 shows state diagrams for the two clock modes. Figure 3.3.2 shows the corresponding block diagram, Figure 3.3.3 displays functions of the I/O registers and Table 3.3.1 lists correspondences between alternative states of the system clock and those of the CPU, oscillator and internal I/O components.



#### (a) Single Clock Mode State Diagram



(b) Dual Clock Mode State Diagram

Figure 3.3.1 State Diagrams

The clock frequency input from the X1 and X2 pins is called fc, and the clock frequency input from the XT1 and XT2 pins is called fs. The clock frequency selected by SYSCR1<SYSCK> and <GEAR2:0> is called the system clock fFPH. The divided clock of fFPH is defined as the system clock fSYS, and one cycle of fSYS is defined as one state.

Table 3.3.1 Relations between System Clock States and Other Internal Operations

|            | perating | Oscil                           | lator                 |         |              |                                                     |
|------------|----------|---------------------------------|-----------------------|---------|--------------|-----------------------------------------------------|
|            | Mode     | High<br>Frequency (fc)          | Low<br>Frequency (fs) | CPU     | Internal I/O | System Clock f <sub>SYS</sub>                       |
|            | RESET    |                                 |                       | Reset   | Reset        | fc/32                                               |
| clock      | NORMAL   |                                 |                       | Operate | Operate      | December                                            |
| 엉          | RUN      | Oscillation                     | Ston                  |         | Operate      | Programmable<br>(fc/2, fc/4, fc/8, fc/16,<br>fc/32) |
| Single     | IDLE2    |                                 | Stop                  | Cton    | Stop only AD |                                                     |
| S          | IDLE1    |                                 |                       | Stop    | Cton         | 10/32)                                              |
|            | STOP     | Stop                            |                       |         | Stop         | Stop                                                |
|            | RESET    |                                 | Stop                  | Reset   | Reset        | fc/32                                               |
| )ck        | NORMAL   | Oscillation                     | Programmable          | Operate | Operate      | Programmable<br>(fc/2, fc/4, fc/8, fc/16,<br>fc/32) |
| Dual clock | SLOW     | Programmable                    | Oscillation           |         |              | fs/2                                                |
| Dua        | RUN      | Oscillator being used as system |                       |         |              | Programmable                                        |
|            | IDLE2    | clock: Oscillation              |                       | Cton    | Stop only AD | (fc/2, fc/4, fc/8, fc/16,                           |
|            | IDLE1    | Other oscillator: Programmable  |                       | Stop    | Cton         | fc/32, fs/2)                                        |
|            | STOP     | Sto                             | ор                    |         | Stop         | Stop                                                |



Figure 3.3.2 Block Diagram of Dual Clock and Standby Circuits

|         |             | 7                          | 6                                                    | 5                         | 4                             | 3                     | 2                        | 1                     | 0                        |
|---------|-------------|----------------------------|------------------------------------------------------|---------------------------|-------------------------------|-----------------------|--------------------------|-----------------------|--------------------------|
| SYSCR0  | Bit symbol  | XEN                        | XTEN                                                 | RXEN                      | RXTEN                         | RSYSCK                | WUEF                     | PRCK1                 | PRCK0                    |
| (006EH) | Read/Write  |                            |                                                      |                           | R                             | W                     | •                        | •                     | •                        |
|         | After reset | 1                          | 0                                                    | 1                         | 0                             | 0                     | 0                        | 0                     | 0                        |
|         | Function    | High-                      | Low-                                                 | High-                     | Low-                          | Select clock          | Warm-up                  | Select prescale       | er clock                 |
|         |             | frequency                  | frequency                                            | frequency                 | frequency                     | after STOP<br>mode is | timer                    | 00: f <sub>FPH</sub>  |                          |
|         |             | oscillator (fc)<br>0: Stop | oscillator (fs)<br>0: Stop                           | oscillator (fc)<br>after  | oscillator<br>(fs) after      | released              | (Write)<br>0:Don't care  | 01: fs<br>10: fc/16   |                          |
|         |             | 1: Oscillation             | 1: Oscillation                                       | released                  | released                      | 0: fc                 | 1: Start timer           | 11: (Reserve          | d)                       |
|         |             |                            |                                                      | STOP mode                 | STOP mode                     | 1: fs                 | (Read)                   | ,                     | ,                        |
|         |             |                            |                                                      | 0: Stop<br>1: Oscillation | 0: Stop<br>1: Oscillation     |                       | 0: Warm up               |                       |                          |
|         |             |                            |                                                      | 1: Oscillation            | 1: Oscillation                |                       | complete 1: Continue     |                       |                          |
|         |             |                            |                                                      |                           |                               |                       | warm up                  |                       |                          |
| SYSCR1  | Bit symbol  |                            |                                                      |                           |                               | SYSCK                 | GEAR2                    | GEAR1                 | GEAR0                    |
| (006FH) | Read/Write  |                            |                                                      |                           |                               |                       | R                        | W                     |                          |
|         | After reset |                            |                                                      |                           |                               | 0                     | 1                        | 0                     | 0                        |
|         | Function    |                            |                                                      |                           |                               | Select                |                          | alue of high f        | requency (fc)            |
|         |             |                            |                                                      |                           |                               | system<br>clock       | 000: fc<br>001: fc/2     |                       |                          |
|         |             |                            |                                                      |                           |                               | 0: fc                 | 010: fc/4                |                       |                          |
|         |             |                            |                                                      |                           |                               | 1: fs                 | 011: fc/8                |                       |                          |
|         |             |                            |                                                      |                           |                               |                       | 100: fc/16               | D.                    |                          |
|         |             |                            |                                                      |                           |                               |                       | 101: (Rese<br>110: (Rese | ,                     |                          |
|         |             |                            |                                                      |                           |                               |                       | 111: (Rese               | ,                     |                          |
| WDMOD   | Bit symbol  | WDTE                       | WDTP1                                                | WDTP0                     | WARM                          | HALTM1                | HALTM0                   | RESCR                 | DRVE                     |
| (005CH) | Read/Write  |                            |                                                      |                           | R/                            | W                     | T                        |                       |                          |
|         | After reset | 1                          | 0                                                    | 0                         | 0                             | 0                     | 0                        | 0                     | 0                        |
|         | Function    | WDT                        | WDT detection                                        | time                      | Warm-up                       | Standby mode          |                          |                       |                          |
|         |             | control<br>1: Enable       | 00: 2 <sup>15</sup> /f <sub>SYS</sub>                |                           | timer<br>0: 2 <sup>14</sup> / | 00: RUN mode          | <b>,</b>                 | 1: Connects<br>WDT    | 1: Drives pin<br>even in |
|         |             | 1. LIIADIC                 | 00. 2 //SYS<br>01: 2 <sup>17</sup> /f <sub>SYS</sub> |                           | frequency                     | 01: STOP mod          |                          | output to             | STOP                     |
|         |             |                            | 10: 2 <sup>19</sup> /f <sub>SYS</sub>                |                           | input                         | 10: IDLE1 mod         |                          | reset pin             | mode                     |
|         |             |                            | 11: 2 <sup>21</sup> /f <sub>SYS</sub>                |                           | 1: 2 <sup>16</sup> /          | 11: IDLE mode         | 9                        | internally.           |                          |
|         |             |                            |                                                      |                           | frequency<br>input            |                       |                          |                       |                          |
| CKOCR   | Bit symbol  |                            |                                                      |                           |                               | SCOSE                 | SCOEN                    | ALEEN                 | CLKEN                    |
| (006DH) | Read/Write  |                            |                                                      |                           |                               |                       |                          | W                     | •                        |
|         | After reset |                            |                                                      |                           |                               | 0                     | 0                        | 0/1 (Note 2)          | 0/1 (Note 2)             |
|         | Function    |                            |                                                      |                           |                               | SCOUT                 | SCOUT                    | ALE pin               | CLK pin                  |
|         |             |                            |                                                      |                           |                               | select                | output                   | output                | output                   |
|         |             |                            |                                                      |                           |                               | 0: f <sub>FPH</sub>   | control<br>0: I/O port   | control<br>0: HZ port | control<br>0: HZ port    |
|         |             |                            |                                                      |                           |                               | 1: f <sub>SYS</sub>   | 1: SCOUT                 | 1: ALE                | 1: CLK                   |
|         |             |                            |                                                      |                           |                               |                       | output                   | output                | output                   |

Note 1: SYSCR1<br/>bit7:4> are always 1.

Note 2: In the TMP93CS40, resetting sets the <ALEEN> and <CLKEN> bits to 0. In the TMP93CS41, resetting sets the <ALEEN> and <CLKEN> bits to 1 (Output ALE and CLK). The CLK pin is internally pulled up during reset, regardless of the product types.

Note 3: Writing 0 to SYSCR1<SYSCK> enables the high-frequency oscillator regardless of the value of SYSCR0<XEN>.

Additionally, writing 1 to SYSCR1<SYSCK> enables the low-frequency oscillator regardless of the value of SYSCR0<XTEN>.

Figure 3.3.3 I/O Register about Dual Clock, Standby

### 3.3.1 System Clock Controller

The system clock controller generates the system clock signal (fSYS) for the CPU core and internal I/O. It contains two oscillation circuits and a clock gear circuit for high frequency (fc). The register SYSCR1<SYSCK> changes the system clock to either fc or fs, SYSCR0<XEN> and SYSCR0<XTEN> control enabling and disabling each oscillator, and SYSCR1<GEAR2:0> changes the high-frequency clock gear to either 1, 2, 4, 8, or 16 (fc, fc/2, fc/4, fc/8, or fc/16). These functions can reduce the power consumption of the equipment in which the device is installed.

The system clock (fSYS) is set to fc/32 (fc/16  $\times$  1/2) by the setting of  $\langle XEN \rangle = 1$ ,  $\langle XTEN \rangle = 0$ ,  $\langle SYSCK \rangle = 0$ , and  $\langle GEAR2:0 \rangle = 100$  upon resetting.

For example, fSYS is set to 0.625 MHz by resetting in the case where the 20 MHz oscillator is connected to the X1 and X2 pins.

The high frequency (fc) and low frequency (fs) clock signals can be easily obtained by connecting a resonator to the X1 and X2, XT1 and XT2 pins, respectively. Clock input from an external oscillator is also possible.

The XT1 and XT2 pins can also function as ports 96 and 97. Therefore in the case of single clock mode, the XT1 and XT2 pins can be used as I/O port pins.



Figure 3.3.4 Examples of Resonator Connection

Note 1: Note on using the low-frequency oscillation circuit.

In connecting the low-frequency resonator to ports 96 and 97, it is necessary to make the following settings to reduce the power consumption.

(Connecting with resonators) P9CR<P96C, P97C> = 11, P9<P96:97> = 00 (Connecting with oscillators) P9CR<P96C, P97C> = 11, P9<P96:97> = 10

Note 2: Accurate adjustment of the oscillation frequency

The CLK pin output at 1/2 the system clock frequency (f<sub>SYS</sub>/2) is used to monitor the oscillation clock.

With a system requiring adjustment of the oscillation frequency, an adjusting program must be written.

### (1) Switching from NORMAL to SLOW mode

When the resonator is connected to the X1 and X2, or to the XT1 and XT2 pins, the warm-up timer is used to change the operation frequency after stable oscillation is attained.

The warm-up time can be selected by WDMOD<WARM>.

This starting and stopping of the warm-up timer are performed by programming as in the following examples 1 and 2.

- Note 1: The warm-up timer is also used as a watchdog timer. So when it is to be used as a warm-up timer, the watchdog timer function must be disabled.
- Note 2: In the case of using an oscillator (not resonator) with stable oscillation, a warm-up timer is not needed.
- Note 3: The warm-up timer is operated by an oscillation clock. Therefore there is an error in, warm-up time.

Table 3.3.2 Warm-up Time

|   |                                     |                       |                     | _       |
|---|-------------------------------------|-----------------------|---------------------|---------|
|   | Warm-up time<br>WDMOD <warm></warm> | Change to NORMAL (fc) | Change to SLOW (fs) |         |
| l | 0 (2 <sup>14</sup> /frequency)      | 0.8192 ms             | 500 ms              | at fc = |
| 1 | 1 (2 <sup>16</sup> /frequency)      | 3.2768 ms             | 2000 ms             | fs =    |

at fc = 20 MHz, fs = 32.768 kHz

### Clock setting example 1:

Changing from high frequency (fc) to low frequency (fs).

| SYSCR0 | EQU | 006EH       |                                             |
|--------|-----|-------------|---------------------------------------------|
| SYSCR1 | EQU | 006FH       |                                             |
| WDCR   | EQU | 005DH       |                                             |
| WDMOD  | EQU | 005CH       |                                             |
|        | RES | 7, (WDMOD)  | ; ]                                         |
|        | LD  | (WDCR), B1H | Disables watchdog timer.                    |
|        | SET | 4, (WDMOD)  | ; Sets warm-up time to 2 <sup>16</sup> /fs. |
|        | SET | 6, (SYSCR0) | ; Enables low-frequency oscillation.        |
|        | SET | 2, (SYSCR0) | ; Clears and starts warm-up timer.          |
| WUP:   | BIT | 2, (SYSCR0) | ; Detects stopping of the warm-up timer.    |
|        | JR  | NZ, WUP     | ; Jetects stopping of the warm-up timer.    |
|        | SET | 3, (SYSCR1) | ; Changes f <sub>SYS</sub> from fc to fs.   |
|        | RES | 7, (SYSCR0) | ; Disables high-frequency oscillation.      |
|        | SET | 7, (WDMOD)  | ; Enables watchdog timer.                   |



### Clock setting example 2:

Changing from low frequency (fs) to high frequency (fc).

| SYSCR0 | EQU | 006EH       |                                             |
|--------|-----|-------------|---------------------------------------------|
| SYSCR1 | EQU | 006FH       |                                             |
| WDCR   | EQU | 005DH       |                                             |
| WDMOD  | EQU | 005CH       |                                             |
|        | RES | 7, (WDMOD)  | ; } ~                                       |
|        | LD  | (WDCR), B1H | Disables watchdog timer.                    |
|        | RES | 4, (WDMOD)  | ; Sets warm-up time to 2 <sup>14</sup> /fc. |
|        | SET | 7, (SYSCR0) | ; Enables high-frequency oscillation (fc).  |
|        | SET | 2, (SYSCR0) | ; Clears and starts warm-up timer.          |
| WUP:   | BIT | 2, (SYSCR0) | ; Detects stopping of the warm-up timer.    |
|        | JR  | NZ, WUP     | ; J Detects stopping of the warm-up times.  |
|        | RES | 3, (SYSCR1) | ; Changes f <sub>SYS</sub> from fs to fc.   |
|        | RES | 6, (SYSCR0) | ; Disables low-frequency oscillation.       |
|        | SET | 7, (WDMOD)  | ; Enables watchdog timer.                   |
|        |     |             |                                             |



#### (2) Clock gear controller

When the high-frequency clock fc is selected at SYSCR1<SYSCK> = "0", the clock gear select register SYSCR1<GEAR2:0> sets fpph to either fc, fc/2, fc/4, fc/8, or fc/16. Switching fpph with the clock gear reduces the power consumption.

Clock setting example 3:

Changing gear value of the high-frequency clock

```
SYSCR1 EQU 006FH

LD (SYSCR1), XXXX0000B ; Changes f<sub>SYS</sub> to fc/2.

X: Don't care
```

(High-frequency clock gear changing)

To change the frequency of the clock gear, write the value to the SYSCR1<GEAR2:0> register. It is necessary to continue the warm-up time until changing fFPH after writing the register value.

There is a possibility that the instruction immediately following the clock-gear-changing instruction will be executed by the clock gear before executing its gear change. To ensure that the instruction immediately following the clock-gear-changing instruction will only be executed by the clock gear after changing its gear ratio, input a dummy instruction (An instruction to execute a write cycle) as follows.

#### Example:

Instruction to be executed by the clock gear after changing its gear ratio.

#### 3.3.2 Prescaler Clock Controller

The 9-bit prescaler provides a clock signal to the 8-bit timer 0 and timer 1, 16-bit timer 4 and timer 5, and serial interface 0 and serial interface 1. The 5-bit prescaler provides a clock signal to the 8-bit PWM timer 0 and 1.

The clock input to the 5-bit prescaler is a clock signal which is selected as either fFPH, fc/16, or fs according to the value in the SYSCRO<PRCK1:0> register, and divided by 2.

The clock input to the 9-bit prescaler is a clock signal which is selected as either fFPH, fc/16, or fs according to the value in the SYSCRO<PRCK1:0> register, and divided by 4.

The <PRCK1:0> register is initialized to 00 by resetting.

When the IDLE1 mode (Operating only the oscillator) is being used, set TRUN<PRRUN> to 0 to reduce the power consumption before a HALT instruction is executed.

### 3.3.3 Internal Clock Pin Output Function

#### (1) PA7/SCOUT pin

The PA7/SCOUT pin outputs the internal clock signals fFPH or fSYS.

One bit in the port A control register PACR<PA7C>, and two bits in the clock output control register CKOCR<SCOEN and SCOSEL> specify the clock and the pins. The PA7/SCOUT pin is assigned as the input port in resetting.

Table 3.3.3 shows states of the SCOUT pin in the alternative operation modes which it can assume on condition that the PA7/SCOUT pin is specified as SCOUT output.

Operation Mode
Output Clock

NORMAL, SLOW
RUN, IDLE2, IDLE1
STOP

f<sub>FPH</sub>
Outputs f<sub>FPH</sub> clock.
f<sub>SYS</sub>
Outputs f<sub>SYS</sub> clock.
Fixed to 0 or 1.

Table 3.3.3 SCOUT Pin States in Alternative Operation Modes

### (2) CLK pin

The CLK pin outputs the internal clock signal fsys divided by 2.

The type of output is determined by one bit in the clock output control register, CKOCR<CLKEN>. Writing 1 sets the clock output, and writing "0" sets the CLK pin to high impedance. CKOCR<CLKEN> is set to "0" upon resetting.

During resetting, the CLK pin is internally pulled up regardless of the value of the <CLKEN> register.

Table 3.3.4 States of the <CLKEN> Register, and CLK Pin Operation after Reset

| Type No.  | CKOCR <clken></clken> | CLK Pin Operation                |
|-----------|-----------------------|----------------------------------|
| TMP93CS40 | 0                     | High impedance                   |
| TMP93CS41 | 1                     | f <sub>SYS</sub> /2 clock output |

Note: To set CKOCR<CLKEN> = "0" and set the CLK pin to high impedance, an external pull-up resistor is needed to prevent current from flowing to the input buffer of the CLK pin.

### 3.3.4 Standby Controller

#### (1) HALT mode

When the HALT instruction is executed, the operating mode changes to RUN, IDLE2, IDLE1 or STOP mode depending on the contents of the HALT mode setting register WDMOD<HALTM1:0>. Figure 3.3.5 shows the alternative states of the watchdog timer mode registers.



Figure 3.3.5 Watchdog Timer Mode Register

The features of the RUN, IDLE2, IDLE1, and STOP modes are as follows.

- 1. RUN: Only the CPU HALTs.
- 2. IDLE2: The built-in oscillator and the specified I/O operates.
- 3. IDLE1: Only the built-in oscillator operates, while all other built-in circuits stop.
- 4. STOP: All internal circuits including the built-in oscillator stop. This greatly reduces power consumption.

The operations in the halt state are described in Table 3.3.5.

HALT mode RUN IDLE2 IDLE1 **STOP** WDMOD<HALTM1:0> 00 10 01 11 HALT CPU I/O port Maintain the state when the HALT instruction was executed. See Table 3.3.8 8-bit timer 8-bit PWM timer Operate STOP 16-bit timer Pattern generator Serial interface AD converter Watchdog timer Interrupt controller

Table 3.3.5 I/O Operation during HALT Mode

#### (2) How to release the HALT mode

These halt states can be released by resetting or by requesting an interrupt. The halt release sources are determined by the combinations between the states of the interrupt mask register<IFF2:0> and the HALT modes. The details for releasing the halt status are shown in Table 3.3.6.

### • Release by requesting an interrupt

This method of releasing operation from the HALT mode depends on the interrupt-enabled status being in force. When the interrupt request level set before executing the HALT instruction exceeds the value of the interrupt mask register, the interrupt due to that source is processed after releasing the HALT mode, and then the CPU starts executing the next instruction that follows the HALT instruction. When the interrupt request level set before executing the HALT instruction is less than the value of the interrupt mask register, release of the HALT mode is not executed. (In non-maskable interrupts, interrupt processing is preformed after releasing the HALT mode regardless of the value of the mask register.)

INTO interrupts are a special case in which release of the HALT mode is executed even if the interrupt request level set before executing the HALT instruction is less than the value of the interrupt mask register. In this case interrupt processing is not performed, and the CPU starts executing the next instruction that follows the HALT instruction, but the interrupt request flag is held at 1.

Note: Usually, interrupts can release all halts status. However, the interrupts =  $(\overline{\text{NMI}}, \text{INT0})$  which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 3 clocks of  $f_{\text{FPH}}$ ) with IDLE1 or STOP mode (IDLE2 and RUN are not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficultly. The priority of this interrupt is compare with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

### • Release by resetting

Resetting releases all halt status settings.

It is necessary to allow enough resetting time (3 ms or more) for the operation of the oscillator to stabilize.

When releasing the HALT mode by resetting, the internal RAM data keeps the state before the "HALT" instruction is executed. However the other setting contents are initialized (Releasing due to interrupts keep the state before the "HALT" instruction is executed.)

When the HALT mode is released by resetting, the internal RAM data maintains the state it was in before the HALT instruction was executed.

However the other setting contents are initialized. (Release of the HALT mode due to interrupts maintains all setting contents in their states before the HALT instruction was executed.)

| Interrupt Receiving Status |           | Interrupt Enabled |                                      |       |      | Interrupt Disabled |                                      |       |      |      |
|----------------------------|-----------|-------------------|--------------------------------------|-------|------|--------------------|--------------------------------------|-------|------|------|
| interrupt Necelving Status |           |                   | (Interrupt level) ≥ (Interrupt mask) |       |      |                    | (Interrupt level) < (Interrupt mask) |       |      |      |
| HALT Mode                  |           | RUN               | IDLE2                                | IDLE1 | STOP | RUN                | IDLE2                                | IDLE1 | STOP |      |
| Halt release               | Interrupt | NMI               | •                                    | •     | •    | *1<br>•            | -                                    | -     | -    | -    |
| source                     |           | INTWDT            | •                                    | ×     | ×    | ×                  | _                                    | _     | _    | _    |
|                            |           | INT0              | •                                    | •     | •    | *1<br>•            | 0                                    | 0     | 0    | 0 *1 |
|                            |           | INT4 to INT7      | •                                    | •     | ×    | ×                  | ×                                    | ×     | ×    | ×    |
|                            |           | INTT0 to INTT3    | •                                    | •     | ×    | ×                  | ×                                    | ×     | ×    | ×    |
|                            |           | INTTR4 to INTTR7  | •                                    | •     | ×    | ×                  | ×                                    | ×     | ×    | ×    |
|                            |           | INTRX0, TX0       | •                                    | •     | ×    | ×                  | ×                                    | ×     | ×    | ×    |
|                            |           | INTRX1, TX1       | •                                    | •     | ×    | ×                  | ×                                    | ×     | ×    | ×    |
|                            |           | INTAD             | •                                    | ×     | ×    | ×                  | ×                                    | ×     | ×    | ×    |
|                            |           | RESET             | +                                    | +     | •    | •                  | •                                    | •     | •    | •    |

Table 3.3.6 Halt Release Sources and Halt Release Operations

Note: When release of the HALT mode is executed by an INT0 interrupt of the level mode in the interrupt enabled status, maintain level H until the start of interrupt processing. If level L is set before the start of interrupt processing, interrupt processing is correctly started.

### Example of releasing the RUN mode:

An INT0 interrupt releases the halt state when the RUN mode is on.



<sup>♦:</sup> After release of the HALT mode, the CPU starts interrupt processing. (RESET initializes LSI.)

o: After release of the HALT mode, the CPU starts executing the next instruction that follows the HALT instruction.

x: Cannot be used to release the HALT mode.

<sup>-:</sup> This combination type does not exist because the priority level (Interrupt request level) of non-maskable interrupts is fixed to the highest priority level 7.

<sup>\*1:</sup> Release the HALT mode is executed after the warm-up cycle is completed.

#### (3) Operation

#### 1. RUN mode

In the RUN mode, the system clock in the MCU continues to operate even after a HALT instruction is executed. Only the CPU stops executing further instructions.

In the halt state, an interrupt request is accepted on the falling edge of the CLK signal.

Release of the RUN mode is executed by the external or internal interrupts. (See Table 3.3.6 "Halt Release Sources and Halt Release Operations".)

Figure 3.3.6 shows the timing for releasing the halt state by interrupts in the RUN or IDLE2 modes.



Figure 3.3.6 Timing Chart for Releasing the Halt State by Interrupt in RUN/IDLE2 Modes

### 2. IDLE2 mode

In the IDLE2 mode, the system clock signal is supplied only to specific internal I/O devices, and the CPU stops executing the current instruction. In the IDLE2 mode, the halt state is released by an interrupt with the same timing as in the RUN mode. The IDLE2 mode is released by external or internal interrupts, except for INTWDT and INTAD interrupts. (See Table 3.3.6 "Halt Release Sources and Halt Release Operations".)

In the IDLE2 mode, the watchdog timer should be disabled before entering the halt status, to prevent the watchdog timer interrupt from occurring just after release of the HALT mode.

#### 3. IDLE1 mode

In the IDLE1 mode, only the internal oscillator operates. The system clock in the MCU stops, and the CLK pin is fixed at the level H in the output enabled state. (CKOCR<CLKEN> = 1)

In the halt state, an interrupt request is sampled unsyncronously with the system clock, however the halt release (Restart of operation) is performed synchronously with it.

IDLE1 mode is released by external interrupts (NMI, INT0). (See Table 3.3.6 "Halt Release Sources and Halt Release Operations".)

When the IDLE mode is used, set (TRUN<PRRUN> to 0) to stop the 9 bit and 5 bit prescaler before a HALT instruction is executed, to reduce the power consumption.

Figure 3.3.7 illustrates the timing for releasing the halt state by interrupts in the IDLE1 mode



Figure 3.3.7 Timing Chart of Halt State Release by Interrupts in IDLE1 Mode

#### 4. STOP mode

The STOP mode is selected to stop all internal circuits including the internal oscillator.

The pin status in the STOP mode depends on the setting of a bit in the watchdog timer mode register WDMOD<DRVE>. (See Table 3.3.8 for setting of WDMOD<DRVE>.) Table 3.3.8 summarizes the state of these pins in the STOP mode.

The STOP mode is released by external interrupts (NMI, INTO). When the STOP mode is released, the system clock output starts after the warm-up time required to attain stable oscillation.

The warm-up time can be set using WDMOD<WARM>. See the example of warm-up time setting (Table 3.3.7).

In a system which supplies a stable clock signal generated by an external oscillator, the warm-up time can be reduced by using the setting of T45CR<QCU>.

Figure 3.3.8 illustrates the timing for releasing the halt state by interrupts during the STOP mode.



Figure 3.3.8 Timing Chart of Halt State Release by Interrupts in STOP Mode

Table 3.3.7 Example of Warm-up Time after Releasing the STOP Mode

| Clock Operation Frequency after the | Warm-up                 | Clock                   |                 |  |
|-------------------------------------|-------------------------|-------------------------|-----------------|--|
| STOP Mode is Released               | WDMOD <warm> = 0</warm> | WDMOD <warm> = 1</warm> | Frequency       |  |
| fc                                  | 0.8192                  | 3.2768                  |                 |  |
| fc/2                                | 1.6384                  | 6.5536                  |                 |  |
| fc/4                                | 3.2768                  | 13.1072                 | fc = 20 MHz     |  |
| fc/8                                | 6.5536                  | 26.2144                 |                 |  |
| fc/16                               | 13.1072                 | 52.4288                 |                 |  |
| fs                                  | 500                     | 2000                    | fs = 32.768 kHz |  |

How to calculate the warm-up time

WDMOD<WARM> = 0: Clock operation frequency after the  $2^{14}$ /STOP mode WDMOD<WARM> = 1: Clock operation frequency after the  $2^{16}$ /STOP mode

The selection of NORMAL versus SLOW modes is possible after the STOP mode is released.

This selection is mode according to the contents of the SYSCR0<RSYSCK> register. Therefore, setting <RSYSCK>, <RXEN>, and <RXTEN> is necessary before the HALT instruction is executed.

#### Setting example:

In this illustrative case, the STOP mode is entered while the clock is operating at low frequency (fs). After the STOP mode is released by a NMI interrupt, the clock resumes operation at high frequency.



Note: When different operation modes are used before and after the STOP mode, and halt release interrupt request is accepted during execution of the HALT instruction (8 states), it is possible to release the HALT mode without changing the operation mode. In a system which accepts interrupts during execution of the HALT instruction, set the same operation mode before and after the STOP mode.

Table 3.3.8 Pin States in STOP Mode

| Pin name           | I/O                                            | TMP9              | 3CS40             | TMP93CS41                    |                   |  |
|--------------------|------------------------------------------------|-------------------|-------------------|------------------------------|-------------------|--|
| Pili name          | 1/0                                            | <drve> = 0</drve> | <drve> = 1</drve> | <drve> = 0</drve>            | <drve> = 1</drve> |  |
| P00 to P07         | Input mode<br>Output mode<br>AD8 to AD15       | <b>A</b>          | Output            | ×<br>×<br>-                  | ×<br>×<br>-       |  |
| P10 to P17         | Input mode<br>Output mode<br>AD0 to AD7        | <b>A</b>          | Output            | ×<br>×<br>-                  | ×<br>×<br>-       |  |
| P20 to P27         | Input mode<br>Output mode, A0 to A7/A16 to A23 | <b>A</b>          | ▲<br>Output       | <b>A</b>                     | ▲<br>Output       |  |
| P30 (RD), P31 (WR) | Output                                         | _                 | Output            | _                            | "H"               |  |
| P32 to P37         | Input mode Output mode                         | PU*<br>PU*        | Input<br>Output   |                              |                   |  |
| P40, P41           | Input mode<br>Output mode                      | PU*<br>PU*        | Input<br>Output   |                              |                   |  |
| P42 (CS2/CAS2)     | Input mode<br>Output mode                      | PD*<br>PD*        | Input<br>Output   |                              |                   |  |
| P5                 | Input mode                                     | <b>A</b>          | <b>A</b>          |                              |                   |  |
| P6                 | Input mode                                     | PU*<br>PU*        | Input             |                              |                   |  |
| P7                 | Output mode Input mode                         | PU*               | Output<br>Input   |                              |                   |  |
| F1                 | Output mode                                    | PU*               | Output            |                              |                   |  |
| P80 to P86         | Input mode                                     | PU*               | Input             |                              |                   |  |
|                    | Output mode                                    | PU*               | Output            |                              |                   |  |
| P87 (INT0)         | Input mode                                     | PU                | Input             |                              |                   |  |
|                    | Output mode                                    | PU                | Output            |                              |                   |  |
|                    | Input mode (INT0)                              | Input             | Input             |                              |                   |  |
| P90 to P95         | Input mode                                     | PU*               | Input             |                              |                   |  |
| D404 D40           | Output mode                                    | PU*               | Output            |                              |                   |  |
| PA0 to PA6         | Input mode                                     | _                 | Input             | The same as for<br>TMP93CS40 |                   |  |
| PA7                | Output mode Input mode                         |                   | Output<br>Input   |                              |                   |  |
| 1 //               | Output mode, SCOUT                             | _                 | Output            |                              |                   |  |
| NMI                | Input                                          | Input             | Input             |                              |                   |  |
| WDOUT              | Output                                         | Output            | Output            |                              |                   |  |
| ALE                | Output ( <aleen> = 1)</aleen>                  | "L"               | "L"               |                              |                   |  |
| CLK                | Output ( <clken> = 1)</clken>                  | _                 | "H"               |                              |                   |  |
| RESET              | Input                                          | Input             | Input             |                              |                   |  |
| ĒĀ                 | Input                                          | Input             | Input             |                              |                   |  |
| AM8/ AM16          | Input                                          | Input             | Input             |                              |                   |  |
| X1                 | Input                                          | при               | Input<br>_        |                              |                   |  |
| X2                 | Output                                         |                   |                   | †                            |                   |  |
| P96                | Input mode                                     | _                 | Input             |                              |                   |  |
| - <del>- •</del>   | Output mode<br>XT1                             | -<br>-            | Output*           |                              |                   |  |
| P97                | Input mode Output mode                         |                   | Input<br>Output*  |                              |                   |  |
|                    | XT2                                            | _                 | _                 |                              |                   |  |

### (Align)

-: Input is not accepted; output is at high impedance.

Input: Input gate in operation. Fix input voltage to "L" or "H" so that the input state pin stays constant.

Output: Output state.

Output\*: Open-drain output state. Input gate in operation. Set output to "L" or attach pull up on pin so that the input gate stays constant.

PU: Programmable pull-up pin. When a pull-up resistor is not set, fix the pin to avoid through current because the input gate always operates.

PU\*: Programmable pull-up pin in input gate disable state. No through current flows even if the pin is set to high impedance.

PD\*: Programmable pull-down pin in input gate disable state. No through current flows even if the pin is set to high

impedance.

★: When a HALT instruction is executed and CPU stops at the address of the port register, an input gate operates. Fix the pin to avoid through current, and change the program. In all other cases, input is not accepted; output is at high impedance.

x: Cannot be set.

Note: Port registers are used for controlling programmable pull up/pull down. If a pin can be used for an output function (e.g., P71/TO1) and the output function is specified, whether pull up or pull down is selected depends on the output function data. If a pin can be used for an input function, whether pull up or pull down is selected depends on the port register setting value only.

### 3.4 Interrupts

Interrupts are controlled by the CPU interrupt mask register SR<IFF2:0> and the built-in interrupt controller.

Altogether the TMP93CS40 and TMP93CS41 have the following 29 interrupt sources:

- Interrupts from the CPU, 9 sources (Software interrupts, and illegal (Undefined) instruction execution)
- Interrupts from external pins (NMI, INTO, and INT4 to INT7), 6 sources
- Interrupts from built-in I/Os, 14 sources

A fixed individual interrupt vector number is assigned to each interrupt source; any one of six levels of priority can also be assigned to each maskable interrupt. Non-maskable interrupts have a fixed priority of 7.

When an interrupt is generated, the interrupt controller sends the value of the priority of the interrupt source to the CPU. When more than one interrupt is generated simultaneously, the interrupt controller sends the value of the highest priority (7 for non-maskable interrupts is the highest) to the CPU.

The CPU compares the value of the priority sent, with the value in the CPU interrupt mask register <IFF2:0>. If the value sent is greater than in that the CPU interrupt mask register, the interrupt is accepted. However, software interrupts and illegal instruction execution interrupts are not compared with the <IFF2:0> register. They are given top priority. The value in the CPU interrupt mask register <IFF2:0> can be changed using the EI instruction. Executing EI n changes the contents of <IFF2:0> to n. For example, programming EI 3 enables acceptance of maskable interrupts with a priority of 3 or greater, and non-maskable interrupts which are set in the interrupt controller. When EI or EI 0 is programmed, maskable interrupts with a priority of 1 or greater, and non-maskable interrupts are enabled in the interrupt instructions (In the same way as the EI 1).

The DI instruction operates in the same way as the EI 7 instruction, setting <IFF2:0> = 7. Since the priority values for maskable interrupts are 0 to 6, the DI instruction is used to disable acceptance of maskable interrupts. The EI instruction becomes effective immediately after execution. (With the TLCS-90, the EI instruction becomes effective after execution of the next following instruction.)

In addition to the general-purpose interrupt processing mode described above, there is also a micro DMA processing mode. Micro DMA is a mode used by the CPU to automatically transfer byte or word data. It enables the CPU to process interrupts such as data saves to built-in I/Os at high speed.

Figure 3.4.1 is a flowchart showing overall interrupt processing.



Figure 3.4.1 Interrupt Processing Flowchart

### 3.4.1 General-purpose Interrupt Processing

When accepting an interrupt, the CPU operates as follows. In the cases of software interrupts or interrupts generated by the CPU because of attempts to execute illegal instructions, the following steps (1) and (3) are not executed.

- (1) The CPU reads the interrupt vector from the interrupt controller. When more than one interrupt with the same priority level is generated simultaneously, the interrupt controller generates interrupt vectors in accordance with the default priority, then clears the interrupt request. The default priority is fixed as follows: The smaller the vector value, the higher the priority.
- (2) The CPU pushes the program counter and the status register to the system stack area (Area indicated by the system mode stack pointer (XSP)).
- (3) The CPU sets a value in the CPU interrupt mask register <IFF2:0> that is higher by 1 than the priority level value of the accepted interrupt. However, if the accepted interrupt's priority value is 7, 7 is set without an increment.
- (4) The CPU increments the interrupt nesting counter (INTNEST).
- (5) The CPU jumps to an address stored in the 8000H + interrupt vector, then starts the interrupt processing routine.

The following table shows the number of processing states corresponding to steps 1 to 5 above.

| Bus Width of | Bus Width of Interrupt | Number of Interrupt Processing States |          |  |
|--------------|------------------------|---------------------------------------|----------|--|
| Stack Area   | Vector Area            | Max Mode                              | Min Mode |  |
| 8 bits       | 8 bits                 | 35                                    | 31       |  |
| o Dits       | 16 bits                | 31                                    | 27       |  |
| 16 hita      | 8 bits                 | 29                                    | 27       |  |
| 16 bits      | 16 bits                | 25                                    | 23       |  |

The RETI instruction is usually used to complete the interrupt processing. Executing this instruction restores the contents of the program counter and the status registers, and decrements the interrupt nesting counter (INTNEST).

Though acceptance of non-maskable interrupts cannot be disabled by programming, acceptance of maskable interrupts can. A priority can be set for each source of maskable interrupts. The CPU accepts any interrupt request with a priority higher than the current value in the CPU mask register <IFF2:0>. The CPU mask register <IFF2:0> is then set to a value higher by 1 than the priority of the accepted interrupt. Thus, if another interrupt is generated with a priority level higher than the interrupt currently being processed, the CPU accepts the interrupt with the higher level, causing interrupt processing to nest.

If an interrupt request with a priority higher than the currently-processed interrupt is generated during the time that CPU is processing the above steps (1) to (5), and is accepted before the first instruction in the interrupt processing routine is executed, this will cause interrupt processing to nest. (The nesting process is the same as in the case of overlapping each non-maskable interrupt (Level 7).) The CPU does not accept an interrupt request of the same priority level as that of the interrupt currently being processed.

Resetting initializes the CPU mask registers <IFF2:0> to the value 7; therefore, acceptance of all maskable interrupts is disabled.

#### (1) Maskable interrupt



During execution of the main program, the CPU accepts an interrupt request. The CPU then increments IFF so that no new interrupts of priority level 1 will be accepted during processing of the interrupt routine.

#### (2) Non-maskable interrupt



The DI instruction is executed in the main program, so that only interrupts of priority level 7 are accepted. In this state the CPU does not increment the IFF even if the CPU accepts an interrupt request of level 7.

#### (3) Interrupt nesting



During processing an interrupt of priority level 3, the IFF is set to 4. When an interrupt with a level higher than 4 is generated, the CPU accepts the interrupt with the higher priority level, causing interrupt processing to nest.

### (4) Software interrupt



The CPU accepts a software interrupt request during DI status (IFF = 7) because the request has a priority of level 7. The IFF is not changed by the software interrupt.

## (5) Timing of interrupt acceptance



If an interrupt with a priority level higher than the interrupt currently being processed is generated, the CPU accepts the interrupt with the higher level. The program counter which returns at [5] is the state address of the INTTO interrupt routine.

\_\_\_ (underline): Instruction [1], [2], ...: Execution flow

The addresses  $008000 \rm{H}$  to  $0080 \rm{FFH}$  (256 bytes) of the TMP93CS40 and TMP93CS41 are assigned as interrupt vector areas.

Table 3.4.1 TMP93CS40/TMP93CS41 Interrupt Table

| Default<br>Priority | Туре     | Interrupt Source                   | Vector Value |   | ne | R | efe | ldre<br>errii<br>'ect | ng t | to | Micro DMA<br>Start Vector |   |     |
|---------------------|----------|------------------------------------|--------------|---|----|---|-----|-----------------------|------|----|---------------------------|---|-----|
| 1                   |          | Reset, or SWI0 instruction         | 0            | 0 | 0  | 0 | Н   | 8                     | 0    | 0  | 0                         | I | _   |
| 2                   |          | SWI 1 instruction                  | 0            | 0 | 0  | 4 | Н   | 8                     | 0    | 0  | 4                         | Н | _   |
| 3                   |          | Illegal instruction, or SWI2       | 0            | 0 | 0  | 8 | Н   | 8                     | 0    | 0  | 8                         | Н | _   |
| 4                   |          | SWI 3 instruction                  | 0            | 0 | 0  | С | Н   | 8                     | 0    | 0  | С                         | Н | _   |
| 5                   | Non-     | SWI 4 instruction                  | 0            | 0 | 1  | 0 | Н   | 8                     | 0    | 1  | 0                         | Н | _   |
| 6                   | maskable | SWI 5 instruction                  | 0            | 0 | 1  | 4 | Н   | 8                     | 0    | 1  | 4                         | Н | _   |
| 7                   |          | SWI 6 instruction                  | 0            | 0 | 1  | 8 | Н   | 8                     | 0    | 1  | 8                         | Н | _   |
| 8                   |          | SWI 7 instruction                  | 0            | 0 | 1  | С | Н   | 8                     | 0    | 1  | С                         | Н | _   |
| 9                   |          | NMI: NMI pin input                 | 0            | 0 | 2  | 0 | Н   | 8                     | 0    | 2  | 0                         | Н | H80 |
| 10                  |          | INTWD: Watchdog timer              | 0            | 0 | 2  | 4 | Н   | 8                     | 0    | 2  | 4                         | Н | 09H |
| 11                  |          | INT0: INT0 pin input               | 0            | 0 | 2  | 8 | Н   | 8                     | 0    | 2  | 8                         | Н | 0AH |
| 12                  |          | INT4: INT4 pin input               | 0            | 0 | 2  | С | Н   | 8                     | 0    | 2  | С                         | Н | 0BH |
| 13                  |          | INT5: INT5 pin input               | 0            | 0 | 3  | 0 | Н   | 8                     | 0    | 3  | 0                         | Н | 0CH |
| 14                  |          | INT6: INT6 pin input               | 0            | 0 | 3  | 4 | Н   | 8                     | 0    | 3  | 4                         | Н | 0DH |
| 15                  |          | INT7: INT7 pin input               | 0            | 0 | 3  | 8 | Н   | 8                     | 0    | 3  | 8                         | Н | 0EH |
| _                   |          | (Reserved)                         | 0            | 0 | 3  | С | Н   | 8                     | 0    | 3  | С                         | Н | _   |
| 16                  |          | INTT0: 8-bit timer 0               | 0            | 0 | 4  | 0 | Н   | 8                     | 0    | 4  | 0                         | Н | 10H |
| 17                  |          | INTT1: 8-bit timer 1               | 0            | 0 | 4  | 4 | Н   | 8                     | 0    | 4  | 4                         | Н | 11H |
| 18                  |          | INTT2: 8-bit timer 2/PWM 0         | 0            | 0 | 4  | 8 | Н   | 8                     | 0    | 4  | 8                         | Н | 12H |
| 19                  |          | INTT3: 8-bit timer 3/PWM 1         | 0            | 0 | 4  | С | Н   | 8                     | 0    | 4  | С                         | Н | 13H |
| 20                  | Maskable | INTTR4: 16-bit timer 4 (TREG4)     | 0            | 0 | 5  | 0 | Н   | 8                     | 0    | 5  | 0                         | Н | 14H |
| 21                  | Maskable | INTTR5: 16-bit timer 4 (TREG5)     | 0            | 0 | 5  | 4 | Н   | 8                     | 0    | 5  | 4                         | Н | 15H |
| 22                  |          | INTTR6: 16-bit timer 5 (TREG6)     | 0            | 0 | 5  | 8 | Н   | 8                     | 0    | 5  | 8                         | Н | 16H |
| 23                  |          | INTTR7: 16-bit timer 5 (TREG7)     | 0            | 0 | 5  | С | Н   | 8                     | 0    | 5  | С                         | Н | 17H |
| 24                  |          | INTRX0: Serial receive (Channel 0) | 0            | 0 | 6  | 0 | Н   | 8                     | 0    | 6  | 0                         | Н | 18H |
| 25                  |          | INTTX0: Serial send (Channel 0)    | 0            | 0 | 6  | 4 | Н   | 8                     | 0    | 6  | 4                         | Н | 19H |
| 26                  |          | INTRX1: Serial receive (Channel 1) | 0            | 0 | 6  | 8 | Н   | 8                     | 0    | 6  | 8                         | Н | 1AH |
| 27                  |          | INTTX1: Serial send (Channel 1)    | 0            | 0 | 6  | С | Н   | 8                     | 0    | 6  | С                         | Н | 1BH |
| 28                  |          | INTAD: AD conversion completion    | 0            | 0 | 7  | 0 | Н   | 8                     | 0    | 7  | 0                         | Н | 1CH |
| -                   |          | (Reserved)                         | 0            | 0 | 7  | 4 | Н   | 8                     | 0    | 7  | 4                         | Н | -   |
|                     |          |                                    |              |   | to |   |     |                       |      | to |                           |   | to  |
| _                   |          | (Reserved)                         | 0            | 0 | F  | С | Н   | 8                     | 0    | F  | С                         | Н | -   |

Setting to reset and interrupt vectors

1. Reset vector

| H0008 | PC<7:0>   |
|-------|-----------|
| 8001H | PC<15:8>  |
| 8002H | PC<23:16> |
| 8003H | XX        |
|       |           |

The vector base addresses are dependent on the products.

| Type No.                                                                | Vector Base Address | PC Setting Sequence after Reset                                                                                | Notes                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMP93CS40/CS41<br>TMP93CM40<br>TMP93PS40<br>TMP93CW40/CW41<br>TMP93PW40 | 008000Н             | PC (7:0) ← Data in location 8000H<br>PC (15:8) ← Data in location 8001H<br>PC (23:16) ← Data in location 8002H | P27 to P20 and A23 to A16 pins are defined as input ports and are pulled down in resetting. The logic data item is 00H. When port 2 is used for the A23 to A16 pins to access the program ROM, set PC (23 to 16) to 00H and set the reset vector to lie within the area 0000H to FFFFH. (This is applicable mainly to products without ROM.) |

2. Interrupt vector (except reset vector)

Address refers to vector +0

+0 PC<7:0> +1 PC<15:8> +2 PC<23:16> +3 XX

XX: Don't care

## Setting example:

Set the reset vector to 8100H, NMI vector to 9ABCH and INTAD vector to 123456H.

| ORG<br>DL | 8000H<br><u>008100</u> H | ; Reset = 8100H                                                     |
|-----------|--------------------------|---------------------------------------------------------------------|
| ORG<br>DL | 8020H<br><u>009ABC</u> H | ; NMI = 9ABCH                                                       |
| ORG<br>DL | 8070H<br><u>123456</u> H | ; INTAD = 123456H                                                   |
| ORG<br>LD | 8100H<br>A, B            | Note: ORG and DL are assembler directives.                          |
| ORG<br>LD | 9ABCH<br>B, C            | ORG: Control location counter  (DL: Defines long word (32-bit) data |
| ORG<br>LD | 123456H<br>C, A          |                                                                     |

#### 3.4.2 Micro DMA

In addition to the conventional interrupt processing, the TMP93CS40 and TMP93CS41 also have a micro DMA function. When an interrupt is accepted, in addition to an interrupt vector, the CPU receives data indicating whether it is to be processed in micro DMA mode or in general-purpose interrupt mode. The CPU performs micro DMA processing only if that mode is requested.

The micro DMA of the TMP93CS40 and TMP93CS41 can process at very high speed compared with the TLCS-90 micro DMA because it has transfer parameters in dedicated registers in the CPU. Since those dedicated registers are assigned as CPU control registers, they can only be accessed by the LDC instruction.

### (1) Micro DMA operation

Micro DMA operation starts when the accepted interrupt vector value matches the micro DMA start vector value set in the interrupt controller. The micro DMA has four channels, so that it can be set for up to four types of interrupt sources at the same time.

When a micro DMA interrupt is accepted, data are automatically transferred from the transfer source address to the transfer destination address set in the control register, and the transfer counter is decremented. If the value in the counter after decrementing is other than "0", micro DMA processing is completed; if the value in the counter after decrementing is "0", general-purpose interrupt processing is performed. In read-only mode, which provides for DRAM refresh, the value in the counter is ignored and a dummy read operation is repeated.

32-bit control registers are used for setting transfer source and destination addresses. However, the TMP93CS40 and TMP93CS41 have only 24 address pins for output. A 16-Mbyte space is available for the micro DMA.

There are two data transfer modes: One-byte mode and one-word mode. Incrementing, decrementing, and fixing the transfer source and destination addresses after transfer can be done in both modes. Therefore data can easily be transferred between I/O and memory and between different I/Os. For details of transfer modes, see the description of transfer mode registers.

The transfer counter has 16 bits, so up to 65536 transfers (The maximum when the initial value of the transfer counter is 0000H) can be performed for one interrupt source by micro DMA processing.

When the transfer counter is decremented to "0" after data are transferred by the micro DMA, general-purpose interrupt processing is performed. After processing the general-purpose interrupt, restarting the interrupts of the same channel restarts the transfer counter from 65536. It is necessary to reset the transfer counter in the general-purpose interrupt processing routine.

Interrupt sources handled by micro DMA processing are 20 in total, and the micro DMA start vectors are listed in Table 3.4.1.

The following timing chart is a micro DMA cycle of the transfer address increment (INC) mode (The other modes are the same as this except for the read-only mode).

(Conditions: MAX mode, 16-bit bus width for 16 Mbytes, 0 waits.)



Note 1: These 2 states are added in the case that the bus width of the source address area is 8 bits.

Note 2: These 2 states are added in the case that the bus width of the destination address area is 8 bits.

Note 3: This may be a dummy cycle with an instruction queue buffer.

Figure 3.4.2 Micro DMA Cycle (Count  $\neq$  0)



Figure 3.4.3 Micro DMA Cycle (Count = 0)

93CS40-43 2004-02-10

## (2) Register configuration (CPU control registers)



These control registers can only be set with the "LDC cr, r" instruction.

## Example:

LD XWA, 100H LDC DMAS0, XWA LD XWA, 50H LDC DMAD0, XWA LD WA, 40H LDC DMAC0, WA LD A, 05H LDC DMAM0, A

### (3) Transfer mode register details



Note 1: n: corresponds to micro DMA channels 0 to 3.

DMADn+/DMASn+: Post-increment (Increments register value after transfer.)

DMADn-/DMASn-: Post-decrement (Decrements register value after transfer.)

Note 2: Execution time: When setting source address/destination address area to 16-bit bus, 0 waits. Clock condition: fc = 20 MHz, clock gear: 1 (fc)

Note 3: Do not use any codes for transfer mode registers other than those indicated above.

<Example for usage of read-only mode (DRAM refresh)>

\* Clock condition

System clock: fc Clock gear: 1 (fc)

When the hardware configuration is as follows:

DRAM mapping size: = 1 Mbyte
DRAM data bus size: = 8 bits

DRAM mapping address range: = 100000H to 1FFFFFH

Set the following registers first; refresh is performed automatically.

1. Register initial value setting

LD XIX, 100000H

LDC DMAS0, XIX ... Mapping start address

LD A, 00001010B

LDC DMAM0, A ... Read only mode (for DRAM refresh)

2. Timer setting

Set the timers so that interrupts are generated at intervals of 62.5 µs or less.

3. Interrupt controller setting

Set the timer interrupt mask higher than the mask for other interrupts. Write the above timer interrupt vector value into the micro DMA start vector register, DMA0V.

(Operation description)

The DRAM data bus is an 8-bit bus and the micro DMA is in read-only mode (4 bytes), so refresh is performed four times per interrupt.

When a 512-refresh per 8 ms DRAM is connected, DRAM refresh is performed sufficiently if the micro DMA is started every 15.625  $\mu$ s  $\times$  4 = 62.5  $\mu$ s or less, since the timing is 15.625  $\mu$ s per refresh.

## (Overhead)

Each processing time for read-only mode by the micro DMA is  $1.8~\mu s$  (18~states) at 20~MHz with an 8-bit data bus.

In the above example, the micro DMA is started every 62.5  $\mu$ s, and 1.8  $\mu$ s ÷ 62.5  $\mu$ s = 0.0288; thus, the overhead factor is 2.88%.

Note: When the bus which must wait to accept the interrupt is released (BUSAK = "0"), DRAM refresh is not performed because the micro DMA is generated by an interrupt.

#### 3.4.3 Interrupt Controller

Figure 3.4.4 is a block diagram of the interrupt circuits. The left half of the diagram shows the interrupt controller; the right half includes the CPU interrupt request signal circuit and the halt release signal circuit.

Each interrupt channel (Total of 20 channels) in the interrupt controller has an interrupt request flag, interrupt priority setting register, and a register for storing the micro DMA start vector. The interrupt request flag is used to latch interrupt requests from peripheral devices.

The flag is cleared to 0 when any of the following conditions are met.

- Upon resetting
- When the CPU reads the interrupt vector after acceptance of an interrupt.
- When the CPU executes an instruction that clears the interrupt from that channel (Writes 0 in <IxxC> of the interrupt priority setting register).

For example, to clear the INT0 interrupt request, after the <u>DI instruction</u> set the register INTE0AD as follows.

```
INTEOAD \leftarrow ---- 0 --- Clears the INTO flip-flop.
```

The status of the interrupt request flag is detected by reading the corresponding clear bit. This also allows the interrupt to be identified by the software.

The interrupt priority can be set by writing the priority in the interrupt priority setting register (e.g., INTE0AD or INTE45) provided for each interrupt source. Interrupt priority levels to be set range from or 1 to 6. Except for NMIs (Non-maskable interrupts), writing 0 or 7 as the interrupt priority disables the corresponding interrupt request. The priority of non-maskable interrupt sources ( $\overline{\text{NMI}}$  pin, watchdog timer, etc.) is fixed to 7. If interrupt requests with the same interrupt level are generated simultaneously, interrupts are accepted in accordance with the default ranking of priorities.

The interrupt controller selects the interrupt request with the highest priority among the simultaneous interrupts, and sends it and its vector address to the CPU. The CPU compares the priority value <IFF2:0> set in the status register, with the priority value sent by the interrupt request signal; if the latter is higher, the interrupt is accepted. Then the CPU sets in CPU SR<IFF2:0> a value equal to one plus the priority value of the interrupt request just received. Interrupt requests whose priority values equal or are higher than the value set in the register are accepted concurrently with execution of the previous interrupt routine. When interrupt processing is completed (after execution of the RETI instruction), the CPU restores to CPU SR<IFF2:0> the priority value saved in the stack before the interrupt was generated.

The interrupt controller also has four registers used to store the micro DMA start vector. Unlike other micro DMA registers (DMAS, DMAD, DMAM, and DMAC), these are I/O registers. Writing the start vector of the interrupt source for micro DMA processing (See Table 3.4.1), enables the corresponding interrupt to be processed by micro DMA. Please note that appropriate values must be set in the micro DMA parameter registers (e.g., DMAS and DMAD) prior to the beginning of micro DMA processing.



Figure 3.4.4 Block Diagram of Interrupt Controller

## (1) Interrupt priority setting register

| Sv         | mbol                          | Addı | ress | 7      | 6               | 5                                    | 4           | 3                | 2             | 1            | 0         |               |
|------------|-------------------------------|------|------|--------|-----------------|--------------------------------------|-------------|------------------|---------------|--------------|-----------|---------------|
|            |                               |      |      |        | IN <sup>-</sup> | TAD                                  |             |                  | IN.           | IT0          | <u>I</u>  | ←Interrupt so |
|            |                               |      |      | IADC   | IADM2           | IADM1                                | IADM0       | I0C              | I0M2          | IOM1         | IOMO      | ←Bit symbol   |
| INT        | E0AD                          | 007  | 70H  | R/W    | IADIVIZ         | W                                    | IADIVIO     | R/W              | IOIVIZ        | W            | 101010    | ←Read/Write   |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         | ←After reset  |
|            |                               |      |      |        |                 | IT5                                  |             |                  |               | IT4          | V         | -Aitel leset  |
|            |                               |      |      | I5C    | I5M2            | I5M1                                 | I5M0        | I4C              | I4M2          | I4M1         | I4M0      |               |
| IN         | TE45                          | 007  | ′1H  | R/W    |                 | W                                    |             | R/W              |               | W            |           | 1             |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         | 1             |
|            |                               |      |      | U      | •               | IT7                                  | U           | 0                |               | IT6          | U         | 1             |
|            |                               |      |      | I7C    | 17M2            | 17M1                                 | 17M0        | I6C              | I6M2          | I6M1         | I6M0      | †             |
| IN         | TE67                          | 007  | '2H  | R/W    | 17 1012         | W                                    | 171010      | R/W              | IOIVIZ        | W            | IOIVIO    | 1             |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         | †             |
|            |                               |      |      | U      |                 |                                      | U           | 0                |               |              | U         |               |
|            |                               |      |      | IT1C   |                 | (Timer1)                             | IT4MO       | ITOC             |               | (Timer0)     | ITOMO     | ┨             |
| IN         | ГЕТ10                         | 007  | '3H  | IT1C   | IT1M2           | IT1M1                                | IT1M0       | IT0C             | IT0M2         | ITOM1        | IT0M0     | 1             |
|            |                               |      |      | R/W    | -               | W                                    | _           | R/W              | _             | W            |           | ┨             |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         | 4             |
|            |                               |      |      |        |                 | ner3/PWM1)                           |             |                  |               | ner2/PWM0)   |           | 1             |
| INT        | EPW10                         | 007  | '4H  | IPW1C  | IPW1M2          | IPW1M1                               | IPW1M0      |                  | IPW0M2        | IPW0M1       | IPW0M0    | 4             |
|            |                               |      |      | R/W    |                 | W                                    | 1           | R/W              |               | W            | 1         |               |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         |               |
|            |                               |      |      |        | INTTR5          | (TREG5)                              |             |                  | INTTR4        | (TREG4)      |           | ļ             |
| INIT       | ГЕТ54                         | 007  | 7EU  | IT5C   | IT5M2           | IT5M1                                | IT5M0       | IT4C             | IT4M2         | IT4M1        | IT4M0     | ]             |
| INTE154 00 | 007                           | эп   | R/W  |        | W               |                                      | R/W         |                  | W             |              | ]         |               |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         |               |
|            |                               |      |      |        | INTTR7          | (TREG7)                              |             |                  | INTTR6        | (TREG6)      |           |               |
| INIT       | FET70                         | 007  | 7011 | IT7C   | IT7M2           | IT7M1                                | IT7M0       | IT6C             | IT6M2         | IT6M1        | IT6M0     | Ī             |
| IIN        | ГЕТ76                         | 007  | оп   | R/W    |                 | W                                    |             | R/W              |               | W            |           | Ī             |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         | Ì             |
|            |                               |      |      |        | INT             | TX0                                  |             |                  | INT           | RX0          |           |               |
|            |                               |      |      | ITX0C  | ITX0M2          | ITX0M1                               | ITX0M0      | IRX0C            | IRX0M2        | IRX0M1       | IRX0M0    |               |
| IN.        | TES0                          | 007  | 7H   | R/W    |                 | W                                    |             | R/W              |               | W            |           | 1             |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         | 1             |
|            |                               |      |      | 0      | •               | TX1                                  | U           | 0                | •             | RX1          | U         |               |
|            |                               |      |      | ITX1C  | ITX1M2          | ITX1M1                               | ITX1M0      | IRX1C            | IRX1M2        | IRX1M1       | IRX1M0    | 1             |
| IN         | TES1                          | 007  | '8H  | R/W    | TIXTIVIZ        | W                                    | TIXTINO     | R/W              | ITOXTIVIZ     | W            | ITOXTIVIO | 1             |
|            |                               |      |      | 0      | 0               | 0                                    | 0           | 0                | 0             | 0            | 0         | 1             |
|            |                               | !    |      |        |                 | U                                    | U           |                  |               |              | U         |               |
|            |                               |      |      | •      |                 |                                      |             |                  |               |              |           |               |
| <b>↓</b> [ | IxxM                          | 12   | Is   | cxM1   | IxxM0           | <u> </u>                             |             | Function (Wr     | rite)         |              |           |               |
|            |                               | -    | '    |        |                 | Drobibite !                          | ntorm:=t == | ,                |               |              | -         |               |
|            | 0                             |      |      | 0      | 0               | Prohibits i                          | -           | •                |               |              |           |               |
|            | 0                             |      |      | 0      | 1               |                                      |             | st level to "1". |               |              |           |               |
|            | 0                             |      |      | 1      | 0               | Sets interr                          | rupt reque  | st level to "2". | -             |              |           |               |
|            | 0                             |      |      | 1      | 1               | Sets interr                          | rupt reque  | st level to "3". |               |              |           |               |
| 1          |                               |      |      | 0      | 0               | Sets interr                          | rupt reque  | st level to "4". | •             |              |           |               |
|            | 1                             |      |      | 0      | 1               | Sets interrupt request level to "5". |             |                  |               |              |           |               |
|            | 1                             |      |      | 1      | 0               |                                      |             | st level to "6". |               |              |           |               |
|            | 1                             |      |      | 1      | 1               | Prohibits i                          |             |                  | •             |              |           |               |
| L          |                               |      | l    | 1      | 1               | ו זיייווטונט ו                       | - Remapt 16 | oqueot.          |               |              |           | _             |
| →          | IxxC                          |      |      |        | Function (Re    | ad)                                  |             |                  | Function      | (Write)      |           |               |
|            | 0                             |      |      | Indica | tes no interru  | ot request.                          |             | Clea             | ars interrupt | request flag | g.        |               |
| Ţ          | 1                             |      |      | India  | ates interrupt  | request.                             |             |                  | Don't o       | care         |           |               |
|            | 1 Maleates interrupt request. |      |      |        |                 |                                      |             |                  | 1             |              |           |               |

Note 1: Read-modify-write is prohibited.

Note 2: This note is about clearing interrupt request flags. The interrupt request flags of INTAD, INTRX0, and INTRX1 are not cleared by writing "0" to IxxC because they are level-sense interrupts.

Figure 3.4.5 Interrupt Priority Setting Register

Note 3: Read-modify-write is prohibited. Note 4: IMC<br/>bit7:3> are always read as "1".

Note 5: See electrical characteristics in section 4 for external interrupt input pulse.

## (2) External interrupt control

#### Interrupt Input Mode Control Register 7 2 1 0 IIMC IOIE **IOLE NMIREE** Bit symbol (007BH) Read/Write W W W After reset 0 1: INT0 0: INT0 1: Can be Function input accepted edgeenable sense in NMI mode rising 1: INT0 edge. levelsense mode INT0 input enable (Note 1) NMI rising edge enable INTO disable (P87 function only) Interrupt request generation at 1 Input enable falling edge Interrupt request generation at Note 1: The INT0 pin can also be used for standby release as described in section 3.3.4. Even rising and falling edge if the pin is not used for standby release, setting this register to "0" maintains the port function during standby mode. INT0 level enable (Note 2) Note 2: This is a case of changing from level-sence to edge-sence for INTO pin mode. Rising edge detect interrupt Execution example: High level interrupt LD (INTE0AD) ,xxxx0000B ; INT0 disable, clear the request flag. LD (IIMC) ,xxxxx10xB ; Change from level to edge. LD (INTE0AD) ,xxxx0nnnB ; Set interrupt level "n" for INT0, clear the request flag.

Figure 3.4.6 Interrupt Input Mode Control Register

Table 3.4.2 Setting of External Interrupt Pin Function

| Interrupt | Pin Name | Mode                     | Setting Method                                       |
|-----------|----------|--------------------------|------------------------------------------------------|
|           |          | <br>Falling edge         | IIMC <nmiree> = 0</nmiree>                           |
| NMI       | _        | Falling and rising edges | IIMC <nmiree> = 1</nmiree>                           |
| INITO     | D07      | <br>Rising edge          | IIMC <i0le> = 0, <i0ie> = 1</i0ie></i0le>            |
| INT0      | P87      | <br>High level           | IIMC <i0le> = 1, <i0ie> = 1</i0ie></i0le>            |
| IN IT 4   | Doo      | <br>Rising edge          | T4MOD <cap12m1:0> = 0, 0 or 0, 1 or 1, 1</cap12m1:0> |
| INT4      | P80      | Falling edge             | T4MOD <cap12m1:0> = 1, 0</cap12m1:0>                 |
| INT5      | P81      | <br>Rising edge          |                                                      |
| INITO     | D0.4     | <br>Rising edge          | T5MOD <cap34m1:0> = 0, 0 or 0, 1 or 1, 1</cap34m1:0> |
| INT6      | P84      | Falling edge             | T5MOD <cap34m1:0> = 1, 0</cap34m1:0>                 |
| INT7      | P85      | <br>Rising edge          |                                                      |

### (3) Micro DMA start vector

When the CPU reads the interrupt vector after accepting an interrupt, it simultaneously compares the bits 2 to 6 of the interrupt vector with each channel's micro DMA start vector. When the two match, the interrupt from the channel whose value matched is processed in micro DMA mode.

If the interrupt vector matches more than one channel, the channel with the lower channel number has a higher priority.

#### Micro DMA 0 State Vector 7 6 5 3 2 1 0 DMA0V4 DMA0V3 DMA0V Bit symbol DMA0V2 DMA0V1 DMA0V0 (007CH) Read/Write W After reset 0 Function Micro DMA channel 0 processed by matching bits 2 to 6 of the interrupt vector

#### Micro DMA 1 State Vector 7 4 3 6 5 2 1 0 DMA1V Bit symbol DMA1V4 DMA1V3 DMA1V2 DMA1V1 DMA1V0 (007DH) Read/Write After reset 0 0 0 0 Function Micro DMA channel 1 processed by matching bits 2 to 6 of the interrupt vector.

|         |                                                                                         |   | IVII | cro DIMA 2 | State vect | or     |        |        |        |
|---------|-----------------------------------------------------------------------------------------|---|------|------------|------------|--------|--------|--------|--------|
|         |                                                                                         | 7 | 6    | 5          | 4          | 3      | 2      | 1      | 0      |
| DMA2V   | Bit symbol                                                                              |   |      |            | DMA2V4     | DMA2V3 | DMA2V2 | DMA2V1 | DMA2V0 |
| (007EH) | Read/Write                                                                              |   |      |            |            |        | W      |        |        |
|         | After reset                                                                             |   |      |            | 0          | 0      | 0      | 0      | 0      |
|         | Function Micro DMA channel 2 processed by matching bits 2 to 6 of the interrupt vector. |   |      |            |            |        |        |        |        |

|         | _           |           | Mi            | icro DMA 3   | State Vect     | or               |                |        |        |
|---------|-------------|-----------|---------------|--------------|----------------|------------------|----------------|--------|--------|
|         |             | 7         | 6             | 5            | 4              | 3                | 2              | 1      | 0      |
| DMA3V   | Bit symbol  |           |               |              | DMA3V4         | DMA3V3           | DMA3V2         | DMA3V1 | DMA3V0 |
| (007FH) | Read/Write  |           |               |              |                |                  | W              |        |        |
|         | After reset |           |               |              | 0              | 0                | 0              | 0      | 0      |
|         | Function    | Micro DMA | channel 3 pro | cessed by ma | atching bits 2 | to 6 of the inte | errupt vector. |        |        |

Note: Read-modify-write is not possible for DMA0V to DMA3V.

Figure 3.4.7 Micro DMA State Vector Register

93CS40-51 2004-02-10

#### (4) Notes

The instruction execution unit and the bus interface unit of this CPU operate independently of each other. Therefore, if the instruction used to clear the interrupt request flag of an interrupt is fetched before the interrupt is generated, it is possible that the CPU might accept the interrupt and execute the fetched instruction to clear the interrupt request flag while reading the interrupt vector. If so, the CPU would start the interrupt processing from the address "8028H".

To avoid the above occurring, clear the interrupt request flag by entering the instruction to clear the flag after the DI instruction. In the case of setting an interrupt enable again by EI instruction after the execution of clearing instruction, execute EI instruction after clearing instruction and following more than one instruction are executed. When EI instruction is placed immediately after clearing instruction, an interrupt becomes enable before interrupt request flags are cleared.

In the case of changing the value of the interrupt mask register <IFF2:0> by execution of POR SR instruction, disable an interrupt by DI instruction before execution of POP SR instruction.

## 3.5 Functions of Ports

The TMP93CS40 has 79 bits for I/O ports. The TMP93CS41 has 61 bits for I/O ports because port 0, port 1, P30, and P31 are dedicated pins for AD0 to AD7, AD8 to AD15 or A8 to A15,  $\overline{\text{RD}}$ , and  $\overline{\text{WR}}$ .

These port pins have I/O functions for the built-in CPU and internal I/Os as well as general-purpose I/O port functions. Table 3.5.1 lists the function of each port pin. Table 3.5.2 lists I/O registers and their specifications.

Table 3.5.1 Functions of Ports

| Port No. | Pin No.    | Number of Pins | Direction | R            | Direction<br>Setting Unit | Pin Name for Built-in Function |
|----------|------------|----------------|-----------|--------------|---------------------------|--------------------------------|
| Port 0   | P00 to P07 | 8              | I/O       | _            | Bit                       | AD0 to AD7                     |
| Port 1   | P10 to P17 | 8              | I/O       | _            | Bit                       | AD8 to AD15/A8 to A15          |
| Port 2   | P20 to P27 | 8              | I/O       | $\downarrow$ | Bit                       | A0 to A7/A16 to A23            |
| Port 3   | P30        | 1              | Output    | _            | (Fixed)                   | RD                             |
|          | P31        | 1              | Output    | _            | (Fixed)                   | WR                             |
|          | P32        | 1              | I/O       | <b>↑</b>     | Bit                       | HWR                            |
|          | P33        | 1              | I/O       | <b>↑</b>     | Bit                       | WAIT                           |
|          | P34        | 1              | I/O       | <b>↑</b>     | Bit                       | BUSRQ                          |
|          | P35        | 1              | I/O       | <b>↑</b>     | Bit                       | BUSAK                          |
|          | P36        | 1              | I/O       | <b>↑</b>     | Bit                       | R/W                            |
|          | P37        | 1              | I/O       | <b>↑</b>     | Bit                       | RAS                            |
| Port 4   | P40        | 1              | I/O       | <b>↑</b>     | Bit                       | CS0 / CAS0                     |
|          | P41        | 1              | I/O       | <b>↑</b>     | Bit                       | CS1 / CAS1                     |
|          | P42        | 1              | I/O       | $\downarrow$ | Bit                       | CS2 / CAS2                     |
| Port 5   | P50 to P57 | 8              | Input     | _            | (Fixed)                   | AN0 to AN7                     |
| Port 6   | P60 to P67 | 8              | I/O       | $\uparrow$   | Bit                       | PG00 to PG03, PG10 to PG13     |
| Port 7   | P70        | 1              | I/O       | <b>↑</b>     | Bit                       | TIO                            |
|          | P71        | 1              | I/O       | <b>↑</b>     | Bit                       | TO1                            |
|          | P72        | 1              | I/O       | <b>↑</b>     | Bit                       | TO2                            |
|          | P73        | 1              | I/O       | <b>↑</b>     | Bit                       | TO3                            |
| Port 8   | P80        | 1              | I/O       | <b>↑</b>     | Bit                       | TI4/INT4                       |
|          | P81        | 1              | I/O       | <b>↑</b>     | Bit                       | TI5/INT5                       |
|          | P82        | 1              | I/O       | <b>↑</b>     | Bit                       | TO4                            |
|          | P83        | 1              | I/O       | <b>↑</b>     | Bit                       | TO5                            |
|          | P84        | 1              | I/O       | <b>↑</b>     | Bit                       | TI6/INT6                       |
|          | P85        | 1              | I/O       | <b>↑</b>     | Bit                       | TI7/INT7                       |
|          | P86        | 1              | I/O       | 1            | Bit                       | TO6                            |
|          | P87        | 1              | I/O       | 1            | Bit                       | INT0                           |
| Port 9   | P90        | 1              | I/O       | <b>↑</b>     | Bit                       | TXD0                           |
|          | P91        | 1              | I/O       | 1            | Bit                       | RXD0                           |
|          | P92        | 1              | I/O       | 1            | Bit                       | CTS0 /SCLK0                    |
|          | P93        | 1              | I/O       | 1            | Bit                       | TXD1                           |
|          | P94        | 1              | I/O       | 1            | Bit                       | RXD1                           |
|          | P95        | 1              | I/O       | 1            | Bit                       | SCLK1                          |
|          | P96        | 1              | I/O       | _            | Bit                       | XT1                            |
|          | P97        | 1              | I/O       | _            | Bit                       | XT2                            |
| Port A   | PA0 to PA6 | 7              | I/O       | -            | Bit                       |                                |
|          | PA7        | 1              | I/O       | _            | Bit                       | SCOUT                          |

R:  $\uparrow$  = With programmable pull-up resistor

 $<sup>\</sup>downarrow$  = With programmable pull-down resistor.

Table 3.5.2 I/O Registers and Specifications (1/2)

| Port 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Dowt No. | Din No       | Function                  |      | I/O Registe | r    |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------|---------------------------|------|-------------|------|--|
| Port 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Port No. | Pin No.      | Function                  | Pn   | PnCR        | PnFC |  |
| Port 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Port 0   | P00 to P07   | Input port (Note 1)       | ×    | 0           |      |  |
| Port 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |              | Output port (Note 1)      | ×    | 1           | None |  |
| Port 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |              | AD0 to AD7 bus            | ×    | ×           |      |  |
| AB to AD15 bus (Note 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Port 1   | P10 to P17   | Input port (Note 1)       | ×    | 0           | 0    |  |
| Port 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |              | Output port (Note 1)      | ×    | 1           | 0    |  |
| Port 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |              | AD8 to AD15 bus (Note 2)  | ×    | 0           | 1    |  |
| Input port (with PD)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |              | A8 to A15 output (Note 2) | ×    | 1           | 1    |  |
| Output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Port 2   | P20 to P27   | Input port (without PD)   | 1    | 0           | 0    |  |
| Port 3   P30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |              | Input port (with PD)      | 0    | 0           | 0    |  |
| Port 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |              | Output port               | ×    | 1           | 0    |  |
| Port 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |              | • •                       | 1    | 0           | 1    |  |
| Port 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |              |                           | 1    | 1           | 1    |  |
| Outputs RD only when accessing external space                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Port 3   | P30          | •                         |      |             |      |  |
| Always outputs RD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |              | • • • •                   |      | None        | 1    |  |
| P31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |              |                           |      |             |      |  |
| P32 to P37   Input port (without PU)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          | P31          |                           |      |             |      |  |
| P32 to P37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |              | • • • •                   | None |             |      |  |
| Input port (with PU)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          | P32 to P37   |                           |      | 0           |      |  |
| Output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |              |                           |      |             |      |  |
| P32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |              | · · ·                     |      |             |      |  |
| P33   WAIT input (without PU)   0   0   0   None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          | P32          |                           |      |             |      |  |
| None   WAIT input (with PU)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |              | ·                         | 0    |             |      |  |
| P34         BUSRQ input (without PU)         0         0         1           BUSRQ input (with PU)         1         0         1           P35         BUSAK output         ×         1         1           P36         R/W output         ×         1         1           P37         RAS output         ×         1         1           Port 4         P40 to P41         Input port (without PU)         0         0         0           Input port (with PU)         1         0         0         0           Input port (with PU)         1         0         0         0           P42         Input port (without PD)         1         0         0         0           Input port (with PD)         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         1         1         1 |          |              |                           |      |             | None |  |
| BUSRQ input (with PU)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          | P34          | <del> </del>              |      |             | 1    |  |
| P35   BUSAK output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |              |                           |      |             |      |  |
| P36                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          | P35          |                           |      |             |      |  |
| P37   RAS output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |              | R/W output                |      |             |      |  |
| Port 4         P40 to P41         Input port (without PU)         0         0         0           Input port (with PU)         1         0         0           Output port         ×         1         0           P42         Input port (without PD)         1         0         0           Input port (with PD)         0         0         0         0           Output port         ×         1         0         0           P40         CSO output (Note 3)         ×         1         1           P41         CSI output (Note 3)         ×         1         1           P42         CS2 output (Note 3)         ×         1         1           Port 5         P50 to P57         Input port         ×         None           Port 6         P60 to P67         Input port (without PU)         0         0         0           Input port (with PU)         1         0         0           Output port         ×         1         0         0                                                                                                                                                                   |          |              |                           |      |             |      |  |
| Input port (with PU)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Port 4   |              | ·                         |      |             |      |  |
| P42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |              |                           |      |             |      |  |
| P42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |              |                           |      |             |      |  |
| Input port (with PD)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          | P42          | •                         |      |             |      |  |
| Output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          | · ·-         |                           |      |             |      |  |
| P40         CSO output (Note 3)         x         1         1           P41         CS1 output (Note 3)         x         1         1           P42         CS2 output (Note 3)         x         1         1           Port 5         P50 to P57         Input port AN0 to AN7 input (Note 4)         x         None           Port 6         P60 to P67         Input port (without PU)         0         0         0           Input port (with PU)         1         0         0           Output port         x         1         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |              |                           |      |             |      |  |
| P41         CSI output (Note 3)         x         1         1           P42         CS2 output (Note 3)         x         1         1           Port 5         P50 to P57         Input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          | P40          | • •                       |      |             |      |  |
| P42         CS2 output (Note 3)         x         1         1           Port 5         P50 to P57         Input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |              |                           |      |             |      |  |
| Port 5         P50 to P57         Input port AN0 to AN7 input (Note 4)         X         None           Port 6         P60 to P67         Input port (without PU)         0         0         0           Input port (with PU)         1         0         0           Output port         X         1         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |              |                           |      | 1           |      |  |
| None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Port 5   |              | , ,                       |      |             | •    |  |
| Port 6         P60 to P67         Input port (without PU)         0         0         0           Input port (with PU)         1         0         0           Output port         ×         1         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |              | • •                       |      | No          | one  |  |
| Input port (with PU)         1         0         0           Output port         ×         1         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Port 6   | P60 to P67   | 1 \ /                     |      | n           | 0    |  |
| Output port × 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0        | . 55 .5 . 57 |                           |      |             |      |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |              |                           |      |             |      |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |              | • •                       | 1    | 1           |      |  |

#### x: Don't care

- Note 1: In the case of the TMP93CS41F, this function is not available.
- Note 2: In the case of the TMP93CS41F, this function is fixed by AM8/  $\overline{\text{AM16}}\,$  pin.
- Note 3: CS/WAIT control register BnCH<BnCAS> selects the wave form output from P40 to P42 pins,  $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$  or  $\overline{\text{CAS0}}$  to  $\overline{\text{CAS2}}$ .
- Note 4: The channel for AD input is selected by ADMOD2<ADCHn> for P50 to P57 pins.
- Note 5: PU = pull-up resistor; PD = pull-down resistor.

Table 3.5.3 I/O Registers and Specifications (2/2)

| Port No. | Din No       | Function                      |    | I/O Registe | r     |  |  |
|----------|--------------|-------------------------------|----|-------------|-------|--|--|
| POIL NO. | Pin No.      | Function                      | Pn | PnCR        | PnFC  |  |  |
| Port 7   | P70 to P73   | Input port (without PU)       | 0  | 0           | 0     |  |  |
|          |              | Input port (with PU)          | 1  | 0           | 0     |  |  |
|          |              | Output port                   | ×  | 1           | 0     |  |  |
|          | P70          | TI0 input (without PU)        | 0  | 0           | None  |  |  |
|          |              | TI0 input (with PU)           | 1  | 0           | None  |  |  |
|          | P71          | TO1 output                    | ×  | 1           | 1     |  |  |
|          | P72          | TO2 output                    | ×  | 1           | 1     |  |  |
|          | P73          | TO3 output                    | ×  | 1           | 1     |  |  |
| Port 8   | P80 to P87   | Input port (without PU)       | 0  | 0           | 0     |  |  |
|          |              | Input port (with PU)          | 1  | 0           | 0     |  |  |
|          |              | Output port                   | ×  | 1           | 0     |  |  |
|          | P80          | TI4/INT4 input (without PU)   | 0  | 0           | NI    |  |  |
|          |              | TI4/INT4 input (with PU)      | 1  | 0           | None  |  |  |
|          | P81          | TI5/INT5 input (without PU)   | 0  | 0           | Niere |  |  |
|          |              | TI5/INT5 input (with PU)      | 1  | 0           | None  |  |  |
|          | P84          | TI6/INT6 input (without PU)   | 0  | 0           |       |  |  |
|          |              | TI6/INT6 input (with PU)      | 1  | 0           | None  |  |  |
|          | P85          | TI7/INT7 input (without PU)   | 0  | 0           |       |  |  |
|          |              | TI7/INT7 input (with PU)      | 1  | 0           | None  |  |  |
| P82      | P82          | TO4 output                    | ×  | 1           | 1     |  |  |
|          | P83          | TO5 output                    | ×  | 1           | 1     |  |  |
|          | P86          | TO6 output                    | ×  | 1           | 1     |  |  |
|          | P87 (Note 5) | INT0 input (without PU)       | 0  | 0           |       |  |  |
|          | , ,          | INT0 input (with PU)          | 1  | 0           | None  |  |  |
| Port 9   | P90 to P95   | Input port (without PU)       | 0  | 0           | 0     |  |  |
|          |              | Input port (with PU)          | 1  | 0           | 0     |  |  |
|          |              | Output port                   | ×  | 1           | 0     |  |  |
|          | P90          | TXD0 output                   | ×  | 1           | 1     |  |  |
|          | P93          | TXD1 output                   | ×  | 1           | 1     |  |  |
|          | P91          | RXD0 input (without PU)       | 0  | 0           |       |  |  |
|          |              | RXD0 input (with PU)          | 1  | 0           | None  |  |  |
|          | P94          | RXD1 input (without PU)       | 0  | 0           |       |  |  |
|          |              | RXD1 input (with PU)          | 1  | 0           | None  |  |  |
|          | P92          | SCLK0 output                  | ×  | 1           | 1     |  |  |
|          |              | CTS0/SCLK0 input (without PU) | 0  | 0           | 0     |  |  |
|          |              | CTS0/SCLK0 input (with PU)    | 1  | 0           | 0     |  |  |
|          | P95          | SCLK1 output                  | ×  | 1           | 1     |  |  |
|          |              | SCLK1 input (without PU)      | 0  | 0           | 0     |  |  |
|          |              | SCLK1 input (with PU)         | 1  | 0           | 0     |  |  |
|          | P96 to P97   | Input port                    | ×  | 0           |       |  |  |
|          |              | Output port (Note 6)          | ×  | 1           | None  |  |  |
|          |              | XT1/2 (Note 7)                | ×  | 0           | 1     |  |  |
| Port A   | PA0 to PA7   | Input port                    | ×  | 0           |       |  |  |
|          |              | Output port × 1               |    | None        |       |  |  |
|          | PA7          | SCOUT output (Note 8)         | ×  | 1           |       |  |  |

×: Don't care

Note 5: When the P87 pin is used as INT0, the IIMC register has to be set to enable interrupt.

Note 6: When using P96 to P97 as output ports, output goes through the open-drain buffer.

Note 7: When P96 to P97 are used as XT1 to XT2, the SYSCR0<XTEN> has to be set to "1".

Note 8: When PA7 is used as SCOUT, the PACR and CKOCR must have the appropriate values written to them.

Resetting makes the port pins listed below function as general-purpose I/O ports.

I/O pins programmable for input or output are then set to function as input ports, except for P96/XT1 and P97/XT2.

A program is needed to set port pins for built-in functions.

Because the TMP93CS41 needs external ROMs, some ports are permanently assigned for memory interfacing.

• P00 to P07  $\rightarrow$  AD0 to AD7

- $P30 \rightarrow \overline{RD}$
- P10 to P17  $\rightarrow$  AD8 to AD15 (or A8 to A15)
- $P31 \rightarrow \overline{WR}$
- \* Note about the bus release and programmable pull-up/pull-down I/O ports.

When the bus is released ( $\overline{BUSAK}$  = "0"), the output buffers of AD0 to AD15 and A0 to A23, as well as the control signals ( $\overline{RD}$ ,  $\overline{WR}$ ,  $\overline{HWR}$ ,  $R/\overline{W}$ ,  $\overline{RAS}$ ,  $\overline{CSO}$ / $\overline{CAS0}$  to  $\overline{CS2}$ / $\overline{CAS2}$ ) are all set to OFF and they go into a high-impedance state.

However, the states of the built-in programmable pull-up/pull-down resistors are retained when the bus is released. These programmable pull-up/pull-down resistors can be switched ON or OFF by programming when they are used as input ports.

When they are used as output ports, they cannot be switched by programming.

Table 3.5.4 shows the pin states when the bus is released ( $\overline{BUSAK} = "0"$ )

Table 3.5.4 Pin States (when the bus is released)

| Pin Name                                                            | Pin States (when the                                                                                                         | he bus is released)                                                                                                          |
|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Fili Name                                                           | Used as a Port                                                                                                               | Used for a Function                                                                                                          |
| P00 to P07<br>(AD0 to AD7)<br>P10 to P17<br>(AD8 to AD15/A8 to A15) | The state is not changed. (does not go to high-impedance (High-Z).)                                                          | Goes to high-impedance (High-Z).                                                                                             |
| P30 (RD)<br>P31 (WR)                                                | Goes to high-impedance (High-Z).                                                                                             | Goes to high-impedance (High-Z).                                                                                             |
| P32 ( <del>NWR</del> )<br>P37 ( <del>RAS</del> )                    | The output buffer is OFF. The programmable pull-up resistor is ON only in the case that the output latch is equal to "1".    | The output buffer is OFF.  The programmable pull-up resistor is ON irrespective of the output latch.                         |
| P36 (R/W)<br>P40 (CS0 / CAS0)<br>P41 (CS1 / CAS1)                   | The output buffer is OFF. The programmable pull-up resistor is ON only in the case that the output latch is equal to "1".    | The output buffer is OFF. The state of the programmable pull-up resistor is retained when the bus is released.               |
| P42 ( CS2 / CAS2 )                                                  | The output buffer is OFF.  The programmable pull-down resistor is ON only in the case that the output latch is equal to "0". | The output buffer is OFF. The state of the programmable pull-down resistor is retained when the bus is released.             |
| P20 to P27 (A16 to A23)                                             | The state is not changed. (does not go to high-impedance (High-Z).)                                                          | The output buffer is OFF.  The programmable pull-down resistor is ON only in the case that the output latch is equal to "0". |

Figure 3.5.1 shows an example of an interface circuit using some of the pins described in Table 3.5.4, in a case when the bus releasing function is used.

When the bus is released, neither internal memory nor internal I/O can be accessed. However, the internal I/O continues to operate, so the watchdog timer (WDT) also continues to run. Therefore, be careful about bus releasing time and setting of the detection time of the WDT.



Figure 3.5.1 Example of an Interface Circuit using the Bus Releasing Function

A circuit like the one shown above is needed to fix the signal level in the case when the bus is released.

Resetting sets P30 ( $\overline{\text{RD}}$ ) and P31 ( $\overline{\text{WR}}$ ) to output; P40 ( $\overline{\text{CS0}}$ ), P41 ( $\overline{\text{CS1}}$ ), P32 ( $\overline{\text{HWR}}$ ), P36 ( $\overline{\text{R/W}}$ ), P37 ( $\overline{\text{RAS}}$ ), and P35 ( $\overline{\text{BUSAK}}$ ) all to input with pull-up resistor; as well as P42 ( $\overline{\text{CS2}}$ ) and P20 to P27 (A16 to A23) to input with pull-down resistor.

A circuit like the one above is also needed to fix the signal level after resetting, because of the possibility of conflict between the external pull-up resistor and the internal pull-down resistor. The resistance of the external pull-up resistor must be 3 to  $5 \text{ k}\Omega$ , and the resistance of the internal pull-down resistor is about  $50 \text{ to } 150 \text{ k}\Omega$ .

Using a pull-down resistor is recommended for P20 to P27 (A16 to A23); however, if this is not possible, a switching circuit like the one used for P42 ( $\overline{\text{CS2}}$ ) may be used.

## 3.5.1 Port 0 (P00 to P07)

Port 0 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis using the control register PoCR. Resetting resets all bits of PoCR to "0", and sets port 0 to input mode.

In addition to functioning as a general-purpose I/O port, port 0 also functions as an address data bus (AD0 to AD7). To access external memory, port 0 functions as an address data bus (AD0 to AD7), and all bits of the control register P0CR are cleared to "0".

In the TMP93CS41, which needs external ROMs, port 0 always functions as an address data bus (AD0 to AD7) regardless of the value set in control register P0CR.



Figure 3.5.2 Port 0

## 3.5.2 Port 1 (P10 to P17)

Port 1 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis using control register P1CR and function register P1FC. Resetting resets all bits of output latch P1, control register P1CR, and function register P1FC to 0, and sets port 1 to input mode.

In addition to functioning as a general-purpose I/O port, port 1 also functions as an address data bus (AD8 to AD15) or an address bus (A8 to A15).

In the TMP93CS41, which needs external ROMs, port 1 always functions either as an address data bus (AD8 to AD15) when AM8/ $\overline{\rm AM16}$  = "0", or as an address bus (A8 to A15) when AM8/ $\overline{\rm AM16}$  = "1", regardless of the value set in control register P1CR.



Figure 3.5.3 Port 1

#### Port 0 Register 7 6 5 3 2 1 0 P0 Bit symbol P07 P06 P05 P04 P03 P02 P01 P00 Read/Write (0000H)R/W After reset Input mode (Output latch register becomes undefined.) Port 0 Control Register 6 5 4 3 2 1 0 P0CR P07C P06C P05C P04C P03C P02C P01C P00C Bit symbol (0002H)Read/Write R/W After reset 0 0 0 0 0 0 0 0 0: Input 1: Output (when externally accessed, port 0 becomes AD7 to AD0 and P0CR is cleared to 0. Function

0 Input 1 Output

Port 0 I/O setting

# Port 1 Register

P1 (0001H)

|             | 7   | 6                                                     | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|-------------|-----|-------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--|
| Bit symbol  | P17 | P16                                                   | P15 | P14 | P13 | P12 | P11 | P10 |  |  |
| Read/Write  | R/W |                                                       |     |     |     |     |     |     |  |  |
| After reset |     | Input mode (Output latch register is cleared to "0".) |     |     |     |     |     |     |  |  |

### Port 1 Control Register

P1CR (0004H)

|             | 7                                    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |
|-------------|--------------------------------------|------|------|------|------|------|------|------|--|
| Bit symbol  | P17C                                 | P16C | P15C | P14C | P13C | P12C | P11C | P10C |  |
| Read/Write  | R/W                                  |      |      |      |      |      |      |      |  |
| After reset | 0                                    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |
| Function    | < <see below.="" table="">&gt;</see> |      |      |      |      |      |      |      |  |

## Port 1 Function Register

P1FC (0005H)

|             | 7                                    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |  |  |
|-------------|--------------------------------------|------|------|------|------|------|------|------|--|--|--|
| Bit symbol  | P17F                                 | P16F | P15F | P14F | P13F | P12F | P11F | P10F |  |  |  |
| Read/Write  | RW                                   |      |      |      |      |      |      |      |  |  |  |
| After reset | 0                                    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |  |  |
| Function    | < <see below.="" table="">&gt;</see> |      |      |      |      |      |      |      |  |  |  |
|             |                                      |      |      |      |      |      |      |      |  |  |  |

Note 1: Read-modify-write is prohibited for registers P0CR, P1CR, and P1FC. Note 2: <P1XF> is bit X in register P1FC;

<P1XC> is bit X in register P1CR.



Figure 3.5.4 Registers for Ports 0 and 1

## 3.5.3 Port 2 (P20 to P27)

Port 2 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis using the control register P2CR and function register P2FC. Resetting resets all bits of output latch P2, control register P2CR and function register P2FC to "0". It also sets port 2 to input mode and connects a <u>pull-down resistor</u>.

In addition to functioning as a general-purpose I/O port, port 2 also functions as an address bus (A0 to A7) or (A16 to A23). To use port 2 as an address bus, write 1 to the output latches to turn off the programmable pull-down resistors.



Figure 3.5.5 Port 2

# Port 2 Register

P2 (0006H)

|             | 7                                                     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|-------------|-------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|--|--|
| Bit symbol  | P27                                                   | P26 | P25 | P24 | P23 | P22 | P21 | P20 |  |  |
| Read/Write  | RW                                                    |     |     |     |     |     |     |     |  |  |
| After reset | Input mode (Output latch register is cleared to "0".) |     |     |     |     |     |     |     |  |  |

## Port 2 Control Register

P2CR (0008H)

|             | 7                                    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |
|-------------|--------------------------------------|------|------|------|------|------|------|------|--|
| Bit symbol  | P27C                                 | P26C | P25C | P24C | P23C | P22C | P21C | P20C |  |
| Read/Write  | W                                    |      |      |      |      |      |      |      |  |
| After reset | 0                                    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |
| Function    | < <see below.="" table="">&gt;</see> |      |      |      |      |      |      |      |  |

## Port 2 Function Register

P2FC (0009H)

|             | 7                                    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------------|--------------------------------------|------|------|------|------|------|------|------|
| Bit symbol  | P27F                                 | P26F | P25F | P24F | P23F | P22F | P21F | P20F |
| Read/Write  | W                                    |      |      |      |      |      |      |      |
| After reset | 0                                    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Function    | < <see below.="" table="">&gt;</see> |      |      |      |      |      |      |      |
|             |                                      |      |      |      |      |      |      |      |

Note 1: Read-modify-write is prohibited for registers P2CR and P2FC.

Note 2: When port P2 is used in the input mode, P2 register controls the built-in pull-down resistor. Read-modify-write is prohibited in the input mode or the I/O mode, as it may affect the states of the pull-up/pull-down resistors.

Note 3: <P2XF> is bit X in register P2FC; <P2XC> is bit X in register P2CR.

To set as an address bus A23 to A16, set P2FC after setting P2CR.

→ Port 2 function setting

| P2FC <p2xf><br/>P2CR<br/><p2xc></p2xc></p2xf> | 0           | 1                              |  |  |  |
|-----------------------------------------------|-------------|--------------------------------|--|--|--|
| 0                                             | Input port  | Address data bus<br>(A7 to A0) |  |  |  |
| 1                                             | Output port | Address bus<br>(A23 to A16)    |  |  |  |

Figure 3.5.6 Registers for Port 2

## 3.5.4 Port 3 (P30 to P37)

Port 3 is an 8-bit general-purpose I/O port.

I/O can be set on a bit basis, but note that P30 and P31 are used for output only. I/O is set using control register P3CR and function register P3FC. Resetting sets all bits of output latch P3 to P1, and control register P3CR (bits 0 and 1 are unused) and function register P3FC to 0. Resetting also outputs 1 from P30 and P31, sets P32 to P37 to input mode, and connects a pull-up resistor.

In addition to functioning as a general-purpose I/O port, port 3 also functions as an I/O for the CPU's control/status signal.

When the P30 pin is defined as  $\overline{RD}$  signal output mode (<P30F> = 1), in the TMP93CS40 or the TMP93CS41 is used, clearing the output latch register <P30> to 0 outputs the  $\overline{RD}$  strobe (used for the pseudo-static RAM) from the P30 pin even when the internal address area is accessed.

If the output latch register P30 remains 1, the  $\overline{RD}$  strobe signal is output only when the external address area is accessed.

In the TMP93CS41, which needs external ROMs, P30 outputs the  $\overline{\text{RD}}$  signal and P31 outputs the  $\overline{\text{WR}}$  signal, regardless of the values set in function registers P30F and P31F.



Figure 3.5.7 Port 3 (P30, P31, P32, P35, P36, P37)





Figure 3.5.8 Port 3 (P33, P34)



Figure 3.5.9 Registers for Port 3

# 3.5.5 Port 4 (P40 to P42)

Port 4 is a 3-bit general-purpose I/O port. I/O can be set on a bit basis using control register P4CR and function register P4FC. Resetting does the following:

- Sets the P40 and P41 output latch registers to 1.
- Resets all bits of the P42 output latch register, the control register P4CR, and the function register P4FC to 0.
- Sets P40 and P41 to input mode and connects a pull-up resistor.
- Sets P42 to input mode and connects a pull-down resistor.

In addition to functioning as a general-purpose I/O port, port 4 also functions as a chip select output signal ( $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$  or  $\overline{\text{CAS0}}$  to  $\overline{\text{CAS2}}$ ).





Figure 3.5.10 Port 4



Note 4: P4<bit7:3> are always read as "1".

Figure 3.5.11 Registers for Port 4

# 3.5.6 Port 5 (P50 to P57)

Port 5 is an 8-bit input port, also used as an analog input pin for the internal AD converter.



Figure 3.5.12 Port 5

# Port 5 Register

P5 (000DH)

|             | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|-------------|-----|------------|-----|-----|-----|-----|-----|-----|--|--|
| Bit symbol  | P57 | P56        | P55 | P54 | P53 | P52 | P51 | P50 |  |  |
| Read/Write  | R   |            |     |     |     |     |     |     |  |  |
| After reset |     | Input mode |     |     |     |     |     |     |  |  |

Note: The input channel selection of the AD converter is set by AD converter mode register ADMOD2.

Figure 3.5.13 Registers for Port 5

# 3.5.7 Port 6 (P60 to P67)

Port 6 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis. Resetting sets port 6 as an input port and connects a pull-up resistor. It also sets all bits of the output latch to 1. In addition to functioning as a general-purpose I/O port, port 6 also functions as a pattern generator of PG0 or PG1 output. PG0 is assigned to P60 to P63; PG1, to P64 to P67. Writing 1 in the appropriate bit of the port 6 function register (P6FC) enables PG output. Resetting resets the function register P6CR, P6FC value to "0", and sets all bits to input ports.



Figure 3.5.14 Port 6

P6

#### Port 6 Register 2 7 6 5 4 3 1 0 Bit symbol P67 P66 P65 P64 P63 P62 P61 P60 (0012H) Read/Write R/W After reset 1 1 1 1 1 1 1 1 Function Input mode (Pull up) Port 6 Control Register 6 5 4 3 2 1 0 P6CR P67C P66C P65C P64C P63C P61C Bit symbol P62C P60C (0014H)Read/Write W After reset 0 0 0 0 0 0 0 0 Function 0: Input 1: Output Port 6 I/O setting 0 Input Output Port 6 Function Register

P6FC (0016H)

|             | 7    | 6       | 5          | 4    | 3                  | 2    | 1    | 0    |
|-------------|------|---------|------------|------|--------------------|------|------|------|
| Bit symbol  | P67F | P66F    | P65F       | P64F | P63F               | P62F | P61F | P60F |
| Read/Write  | W    |         |            |      |                    |      |      |      |
| After reset | 0    | 0       | 0          | 0    | 0                  | 0    | 0    | 0    |
| Function    |      | 0: Port | 1: PG1-OUT |      | 0: Port 1: PG0-OUT |      |      |      |
|             |      |         |            |      |                    |      |      |      |

Note 1: Read-modify-write is prohibited for registers P6CR and P6FC.

Note 2: When port P6 is used in the input mode, the P6 register controls the built-in pull-up resistor. Read-modify-write is prohibited in the input mode or the I/O mode, as it may affect the states of the pull-up/pull-down resistors.

General-purpose port Stepping motor control/pattern generation port

➤ Port 6 function setting

Figure 3.5.15 Registers for Port 6

93CS40-72 2004-02-10

# 3.5.8 Port 7 (P70 to P73)

Port 7 is a 4-bit general-purpose I/O port. I/O can be set on a bit basis. Resetting sets port 7 as an input port and connects a pull-up resistor. In addition to functioning as a general-purpose I/O port, port 70 also functions as an input clock pin TIO; port 71 as an 8-bit timer output (TO1), port 72 as a PWM0 output (TO2), and port 73 as a PWM1 output (TO3) pin. Writing 1 in the corresponding bit of the port 7 function register (P7FC) enables output of the timer. Resetting resets the function register P7CR, P7FC value to 0, and sets all bits to input ports.



Figure 3.5.16 Port 7



Figure 3.5.17 Registers for Port 7

# 3.5.9 Port 8 (P80 to P87)

Port 8 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis. Resetting sets port 8 as an input port and connects a pull-up resistor. It also sets all bits of the output latch register P8 to 1. In addition to functioning as a general-purpose I/O port, port 8 also functions as an input for 16-bit timer 4 and 5 clocks, an output for 16-bit timer F/F 4, 5, and 6 output, and an input for INTO. Writing "1" in the corresponding bit of the port 8 function register (P8FC) enables those functions. Resetting resets the function register P8CR, P8FC value to "0" and sets all bits to input ports.

#### (1) P80 to P86



Figure 3.5.18 Port 8 (P80 to P86)

# (2) P87 (INT0)

Port 87 is a general-purpose I/O port, and is also used as an INTO pin for external interrupt request input.



Figure 3.5.19 Port 87



Figure 3.5.20 Registers for Port 8

# 3.5.10 Port 9 (P90 to P97)

#### Ports 90 to 95

Ports 90 to 95 constitute a 6-bit general-purpose I/O ports. I/Os can be set on a bit basis.

Resetting sets P90 to P95 to an input port and connects a pull-up resistor.

It also sets all bits of the output latch register to 1.

In addition to functioning as a general-purpose I/O port, P90 to P95 can also function as an I/O for serial channels 0 and 1. Writing "1" in the corresponding bit of the port 9 function register (P9FC) enables those functions.

Resetting resets the function register P9CR, P9FC value to "0" and sets all bits to input ports.

#### • Ports 96 to 97

Ports 96 to 97 form a 2-bit general-purpose I/O port. I/Os can be set on a bit basis.

The output buffer for P96 to P97 is an open-drain type buffer.

Resetting sets the output latch and control registers to "1" and outputs high-impedance (High-Z).

In addition to functioning as a general-purpose I/O port, P96 to P97 can also function as a low-frequency oscillator connecting pin for dual clock mode. The dual clock function can be set by programming system clock control register SYSCR0 and 1.

# (1) Ports 90, 93 (TXD0/TXD1)

Ports 90 and 93 also function as serial channel TXD output pins in addition to I/O ports.

They have a programmable open-drain function.



Figure 3.5.21 Ports 90 and 93

# (2) Port 91, 94 (RXD0, RXD1)

Ports 91 and 94 are I/O ports, and are also used as RXD input pins for serial channels.



Figure 3.5.22 Ports 91 and 94

# (3) Port 92 (CTSO /SCLKO)

Port 92 is an I/O port, and is also used as a  $\overline{\text{CTS0}}$  input pin and as a SCLK0 I/O pin for serial channels.



Figure 3.5.23 Port 92

# (4) Port 95 (SCLK1)

Port 95 is a general-purpose I/O port. It is also used as a SCLK1 I/O pin for serial channel 1.



Figure 3.5.24 Port 95

# (5) Port 96 (XT1), 97 (XT2)

Ports 96 and 97 are general purpose I/O ports. They are also used as low-frequency oscillator connecting pins.



Figure 3.5.25 Ports 96 and 97



Figure 3.5.26 Registers for Port 9

# 3.5.11 Port A (PA0 to PA7)

Port A is an 8-bit general-purpose I/O port. I/Os can be set on a bit basis by control register PACR.

Resetting sets port A to an input port by resetting PACR.

It also sets all bits of the output latch register to "1".

In addition to functioning as a general-purpose I/O port (Only PA7), PA7 can also function as an internal clock output pin.

The output clock is fFPH or fSYS that is selected as oscillator output clock. It is selected by CKOCR<SCOSEL>.

The SCOUT function is enabled by setting PACR<PA7C> and CKOCR<SCOEN>.



Figure 3.5.27 Port A0 to A6



Figure 3.5.28 Port A7



Figure 3.5.29 Registers for Port A

# 3.6 Chip Select/Wait Controller, AM8/ AM16 pin

The TMP93CS40 and TMP93CS41 have a built-in chip select/wait controller used to control chip select ( $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$  pins), wait ( $\overline{\text{WAIT}}$  pin), and data bus size (8 or 16 bits) for any of the three block address areas.

In addition, the AM8/ AM16 pin selects external data bus width.

### 3.6.1 AM8/AM16 pin

### (1) Usage in the TMP93CS40

Set this pin to "1". After resetting, the CPU accesses the internal ROM with 16-bit bus width. The bus width when the CPU accesses an external area is set by the chip select/wait control register (described in section 3.6.3), P1CR and P1FC. (If this pin is set to 1, that value will be ignored and the value set by register will be active.)

#### (2) Usage in the TMP93CS41

(2-1) When 16-bit bus width and 8-bit bus width are both used, or when 16-bit bus width only is used:

Set this pin to "0". Then the AD8 to AD15 or A8 to A15 pins of port 1 are fixed to their A8 to A15 function compulsorily, and the values of P1CR and P1FC are ignored.

The bus width when the CPU accesses an external area is set by the chip select/wait control register described in section 3.6.2.

After a reset, 16-bit external program memory must be accessed before any other memory is accessed.

### (2-2) When 8-bit bus width only is used:

Set this pin to "1". Then the AD8 to AD15 or A8 to A15 pins of port 1 are fixed to their A8 to A15 function compulsorily, and the values of P1CR and P1FC are ignored. The values of bit4 in <B0BUS>, <B1BUS>, or <B2BUS>, described in section 3.6.3, are ignored and the bus width is fixed to 8 bits.

# 3.6.2 Address/Data Bus Pins

Port 0, port 1 and port 2 function as an address and data bus for connecting the microcontroller to the external memories and I/O peripherals.

|                  |                      | 1.                   | 2.                              | 3.                                            | 4.                                              |  |
|------------------|----------------------|----------------------|---------------------------------|-----------------------------------------------|-------------------------------------------------|--|
| Products         |                      | TMP93CS4             | 1F (Note 4)                     | TMP93CS40F (Note 2), (Note 3)                 |                                                 |  |
|                  | of Address<br>s Pins | max24 (to 16 Mbytes) | max24 (to 16 Mbytes)            | max16 (to 64 Kbytes)                          | max8 (to 256 Kbytes)                            |  |
|                  | of Data Bus<br>Pins  | 8                    | 16                              | 8                                             | 16                                              |  |
|                  | nber of<br>exed Pins | 8                    | 16                              | 0                                             | 0                                               |  |
| Mode             | ĒΑ                   | V                    | IL                              | V <sub>IH</sub>                               |                                                 |  |
| Pins             | AM8/ AM16            | V <sub>IH</sub>      | V <sub>IL</sub>                 | V <sub>IH</sub>                               |                                                 |  |
|                  | Port 0               | AD0 to AD7           | AD0 to AD7                      | AD0 to AD7                                    | AD0 to AD7                                      |  |
| Port<br>Function | Port 1               | A8 to A15            | AD8 to AD15                     | A8 to A15                                     | AD8 to AD15                                     |  |
|                  | Port 2               | A16 to A23           | A16 to A23                      | A0 to A7                                      | A0 to A7                                        |  |
| Timir            | ng Chart             | A23 to A23 to A8     | A23 to A23 to A16               | A15 to A15 to A0                              | A7 to A0 A7 to A0                               |  |
|                  |                      | AD7 to AD0 (D7)      | AD15 to (A15) (D15) AD0 (to D0) | AD7 to (Note 1)<br>AD0 (to A0) (D7)<br>to A0) | AD15 to (Note 1)<br>AD0 (A15)<br>to A0) (to D0) |  |
|                  |                      | ALE _                | ALE _                           | ALE                                           | ALE _                                           |  |
|                  |                      | RD                   | RD                              | RD                                            | RD                                              |  |

- Note 1: In the cases of 3. and 4., the data bus signals output the addresses because the signals are also used as the address bus. By writing "0" to bit CKOCR<ALEEN>, the ALE signal can be prevented from outputting.
- Note 2: After a reset operation, port 0, port 1, and port 2 of the TMP93CS40F function as input ports.
- Note 3: In the case of the TMP93CS40F, all the options a. to d. can be made available using the P1CR, P1FC, P2CR, and P2FC registers. ( $\overline{EA} = VIH, AM8/\overline{AM16} = VIH$ )
- Note 4: In the case of the TMP93CS41F, options 3. and 4. cannot be made available.

# 3.6.3 Control Registers

Table 3.6.1 shows control registers.

One block of the address areas is controlled by each of the 1-byte CS/WAIT control registers B0CS, B1CS, and B2CS.

#### (1) Master enable bits

Bit7 of the control registers (B0E, B1E, and B2E) are master bits used to specify setting enable (1) or disable (0).

Resetting sets B0E and B1E to disable (0) and B2E to enable (1).

#### (2) CS/CAS waveform select

Bit5 of the control registers (B0CAS, B1CAS, and B2CAS) are used to specify the waveform mode output from the chip select pin (from  $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$ , or from  $\overline{\text{CAS0}}$  to  $\overline{\text{CAS2}}$ ). Setting these bits to 0 specifies  $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$  waveforms; setting them to 1 specifies  $\overline{\text{CAS0}}$  to  $\overline{\text{CAS2}}$  waveforms.

Resetting clears bits 5 to 0.

# (3) Data bus size select

Bit4 (B0BUS, B1BUS, and B2BUS) of the control register is used to specify data bus size. Setting this bit to 0 accesses the memory in 16-bit data bus mode; setting it to 1 accesses the memory in 8-bit data bus mode.

Changing data bus size depending on the access address is called dynamic bus sizing. Table 3.6.2 shows the details of the bus operation.

This bit is changed by changing the state of the AM8/ AM16 pin.

#### (4) Wait control

Control register bits 3 and 2 <80W1:0, B1W1:0, and B2W1:0> are used to specify the number of waits. Setting these bits to 00 inserts a 2-state wait regardless of the  $\overline{\text{WAIT}}$  pin status. Setting them to 01 inserts a 1-state wait regardless of the  $\overline{\text{WAIT}}$  status. Setting them to 10 inserts a 1-state wait and samples the  $\overline{\text{WAIT}}$  pin status. If the pin is Low, inserting the wait maintains the bus cycle until the pin goes high. Setting them to 11 completes the bus cycle without a wait, regardless of the  $\overline{\text{WAIT}}$  pin status.

Resetting sets these bits to 00 (2-state wait mode).

### (5) Address area specification

Control register bits 1 and 0 <B0C1:0, B1C1:0, and B2C1:0> are used to specify the target address area. Setting these bits to 00 enables settings (e.g.,  $\overline{\text{CS}}$  output, wait state, and bus size) as follows:

- \* The CS0 setting is enabled when the address space 7F00H to 7FFFH is accessed.
- \* The CS1 setting is enabled when the address space 880H to 7FFFH is accessed.
- \* The CS2 setting is enabled when the address space 8000H to 3FFFFFH is accessed in the TMP93CS41, which does not have a built-in ROM.

The CS2 setting is enabled when the address space 18000H to 3FFFFFH is accessed in the TMP93CS40, which has built-in ROM.

Setting these bits to 01 enables settings ( $\overline{\text{CS}}$  output, wait state...) for all CS's blocks and outputs a low strobe signal (from  $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$ , or from  $\overline{\text{CAS0}}$  to  $\overline{\text{CAS2}}$ ) from the chip select pins when the address space 400000H to 7FFFFFH is accessed. Setting these bits to 10 enables the address space 800000H to BFFFFFH to be accessed. Setting these bits to 11 enables the address space C00000H to FFFFFFH to be accessed.

Code Name Address 7 4 2 1 0 **B0CAS B0BUS** B0E B0W1 B0W0 B<sub>0</sub>C<sub>1</sub> B0C0 W W W W W W W Block0 0 0 0 0 n n 0 CS/WAIT **BOCS** 0: CS0 0068H 0: 16-bit 00: 2 waits 00: 7F00H to 7FFFH : Master bit control 1: CASO 01: 400000H to 01: 1 wait of bit0 to 6 bus register 10: 800000H to 1: 8-bit 10: (1 + n) waits 11: 0 waits 11: C00000H to bus B1C0 B1E **B1CAS B1BUS** B1W1 B1W0 B1C1 W W W W W W W Block1 0 0 0 0 0 0 CS/WAIT B1CS 0069H 0: CS1 1: Master bit 0: 16-bit 00: 2 waits 00: 880H to 7FFFH control 1: CAS1 of bit0 to 6 bus 01: 1 wait 01: 400000H to register 1: 8-bit 10: (1 + n) waits 10: 800000H to bus 11: 0 waits 11: C00000H to B2E B2CAS B2BUS B2W1 B2W0 B2C0 B2C1 W W W W W W W Block2 0 0 n 0 CS/WAIT B2CS 006AH 0: CS2 0: 16-bit 00: 2 waits 00: 8000H to : Master bit control 1: CAS2 01: 400000H to of bit0 to 6 bus 01: 1 wait register 1: 8-bit 10: (1 + n) waits 10: 800000H to bus 11: 0 waits 11: C00000H to

Table 3.6.1 Chip Select/Wait Control Register

Note: Read-modify-write is prohibited for B0CS, B1CS, and B2CS.

Table 3.6.2 Dynamic Bus Sizing

| Operand Data | Operand Start | Memory Data | CPU Address | CPU Data   |            |  |
|--------------|---------------|-------------|-------------|------------|------------|--|
| Size         | Address       | Size        | CPU Address | D15 to D8  | D7 to D0   |  |
| 8 bits       | 2n + 0        | 8 bits      | 2n + 0      | xxxxx      | b7 to b0   |  |
|              | (Even number) | 16 bits     | 2n + 0      | xxxxx      | b7 to b0   |  |
|              | 2n + 1        | 8 bits      | 2n + 1      | xxxxx      | b7 to b0   |  |
|              | (Odd number)  | 16 bits     | 2n + 1      | b7 to b0   | xxxxx      |  |
| 16 bits      | 2n + 0        | 8 bits      | 2n + 0      | xxxxx      | b7 to b0   |  |
|              | (Even number) |             | 2n + 1      | xxxxx      | b15 to b8  |  |
|              |               | 16 bits     | 2n + 0      | b15 to b8  | b7 to b0   |  |
|              | 2n + 1        | 8 bits      | 2n + 1      | xxxxx      | b7 to b0   |  |
|              | (Odd number)  |             | 2n + 2      | XXXXX      | b15 to b8  |  |
|              |               | 16 bits     | 2n + 1      | b7 to b0   | xxxxx      |  |
|              |               |             | 2n + 2      | XXXXX      | b15 to b8  |  |
| 32 bits      | 2n + 0        | 8 bits      | 2n + 0      | xxxxx      | b7 to b0   |  |
|              | (Even number) |             | 2n + 1      | xxxxx      | b15 to b8  |  |
|              |               |             | 2n + 2      | XXXXX      | b23 to b16 |  |
|              |               |             | 2n + 3      | XXXXX      | b31 to b24 |  |
|              |               | 16 bits     | 2n + 0      | b15 to b8  | b7 to b0   |  |
|              |               |             | 2n + 2      | b31 to b24 | b23 to b16 |  |
|              | 2n + 1        | 8 bits      | 2n + 1      | xxxxx      | b7 to b0   |  |
|              | (Odd number)  |             | 2n + 2      | xxxxx      | b15 to b8  |  |
|              |               |             | 2n + 3      | xxxxx      | b23 to b16 |  |
|              |               |             | 2n + 4      | XXXXX      | b31 to b24 |  |
|              |               | 16 bits     | 2n + 1      | b7 to b0   | xxxxx      |  |
|              |               |             | 2n + 2      | b23 to b16 | b15 to b8  |  |
|              |               |             | 2n + 4      | XXXXX      | b31 to b24 |  |

xxxxx: During a read, data input to the bus is ignored. While writing, the bus is at high impedance and the write strobe signal remains in active.

### 3.6.4 Chip Select Addresses Image

An image of the actual addresses which can be specified by chip select is shown below. Out of the whole memory area, address areas that can be specified are divided into four parts. Addresses from 000000H to 3FFFFFH are further divided as follows: 7F00H to 7FFFH is specified for CS0; 880H to 7FFFH, for CS1; and 8000H to 3FFFFFH, for CS2. The reason is that a device other than ROM (e.g., RAM or I/O) might be connected externally.

7F00 to 7FFFH (256 bytes) designated as CS0 are mapped mainly for possible expansions to external I/O.

880H to 7FFFH (approx. 31 Kbytes) designated as CS1 are mapped mainly for possible extensions to external RAM.

8000H to 3FFFFFH (approx. 4 Mbytes) designated as CS2 are mapped mainly for possible extensions to external ROM. After resetting, CS2 is enabled in a 16-bit bus and 2-wait configuration. In the case of the TMP93CS41, which does not have a built-in ROM, the program is externally read at address 8000H with these settings (16-bit bus, 2 waits). With the TMP93CS40, which does have a built-in ROM, addresses from 8000H to 17FFFH are used as the internal ROM area; CS2 is disabled in this area. After resetting, the CPU reads the program from the built-in ROM in 16-bit bus, 0-wait mode.



- Note 1: Access priority is highest for built-in I/O, then built-in memory, and lowest for the chip select/wait controller.
- Note 2: External areas other than  $\overline{CSO}$  to  $\overline{CSO}$  are accessed in 0 wait mode. For the TMP93CS40, the data bus width is fixed at 16 bits. For the TMP93CS41, the data bus width is 16 bits when AM8/ $\overline{AM16} = 0$ , and 8 bits when AM8/ $\overline{AM16} = 1$ .

When using the chip select/wait controller, do not specify the same address area more than once. (However, when specifications overlap, only one of them will be utilized. For example, when addresses 7F00H to 7FFFH for CS0 are specified at the same time as 880H to 7FFFH for CS1, only the CS0 setting and pin will be active.)

Note 3: When the bus is released (BUSAK = "0"), the CS0 to CS2 pins are also released (the output buffer is OFF). For further information about the state of pins, refer to the note about the bus release in section 3.5 "Functions of Ports".

# 3.6.5 Example of Usage

# (1) Example of usage -1

Figure 3.6.1 is an example in which an external memory is connected to the TMP93CS41. In this example, a ROM is connected using a 16-bit bus; a RAM is connected using an 8-bit bus.



Figure 3.6.1 Example of External Memory Connection (ROM = 16 bits, RAM and I/O = 8 bits)

Resetting sets pins  $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$  to input port mode.  $\overline{\text{CS0}}$  and  $\overline{\text{CS1}}$  are set high due to an internal pull-up resistor;  $\overline{\text{CS2}}$  is set low due to an internal pull-down resistor. The program used to set these pins is as follows.

```
P4CR
            EQU
                        0EH
P4FC
            EQU
                        10H
B<sub>0</sub>CS
            EQU
                        68H
B1CS
            EQU
                        69H
B2CS
            EQU
                        6AH
LD
            (B0CS), 1X010000B
                                            ; CS0 = 8 bits, 2 waits, 7F00H to 7FFFH
LD
            (B1CS), 1X011100B
                                            ; CS1 = 8 bits, 0 waits, 880H to 7EFFH
LD
            (B2CS), 1X000100B
                                             ; CS2 = 16 bits, 1 wait, 8000H to 3FFFFH
LD
            (P4CR), XXXXX111B
                                              \overline{\text{CS0}}\,,\;\overline{\text{CS1}}\,,\;\overline{\text{CS2}}\, output mode setting
LD
            (P4FC), XXXXX111B
```

X: Don't care

### (2) Example of usage -2

Figure 3.6.2 is an example in which an external memory is connected to the TMP93CS41. In this example, a ROM, RAM, and I/O are each connected using an 8-bit bus.



Figure 3.6.2 Example of External Memory Connection (ROM, RAM and I/O = 8 Bits)

Resetting sets pins  $\overline{\text{CS0}}$  to  $\overline{\text{CS2}}$  to input port mode.  $\overline{\text{CS0}}$  and  $\overline{\text{CS1}}$  are set high due to an internal pull-up resistor;  $\overline{\text{CS2}}$  is set low due to an internal pull-down resistor. The program used to set these pins is as follows.

```
P4CR
          EQU
                    0EH
          EQU
P4FC
                    10H
B<sub>0</sub>CS
          EQU
                    68H
          EQU
                    69H
B1CS
B2CS
          EQU
                    6AH
          (B0CS), 1X010000B
                                     ; CS0 = 8 bits, 2 waits, 7F00H to 7FFFH
LD
LD
          (B1CS), 1X011100B
                                     ; CS1 = 8 bits, 0 waits, 880H to 7EFFH
          (B2CS), 1X000100B
                                      ; CS2 = 8 bits, 1 wait, 8000H to 3FFFFFH
LD
LD
          (P4CR), XXXXX111B
                                       CS0, CS1, CS2 output mode setting
LD
          (P4FC), XXXXX111B
```

X: Don't care

### (3) Example of usage -3

Figure 3.6.3 is an example in which an external memory is connected to the TMP93CS40. In this example, a 128-Kbyte ROM is connected using a 16-bit bus, and a 256-Kbyte RAM is connected using a 16-bit bus.



Figure 3.6.3 Example of External Memory Connection (ROM & RAM = 16 bits)

The TMP93CS40 has built-in ROM and RAM. When ROM and RAM have insufficient capacity, it is possible to connect an external memory following the usage examples for this purpose. In this example, the memory configuration is as follows.

| Ме   | mory     | Memory Size | Address            | CS Pin | Data Bus |
|------|----------|-------------|--------------------|--------|----------|
| ROM  | Internal | 64 Kbytes   | 008000H to 017FFFH | -      | 16 bits  |
|      | External | 128 Kbytes  | 400000H to 41FFFFH | CS2    | 16 bits  |
| SRAM | Internal | 2 Kbytes    | 000080H to 00087FH | _      | 16 bits  |
|      | External | 256 Kbytes  | 800000H to 83FFFFH | CS2    | 16 bits  |

### 3.7 8-Bit Timers

The TMP93CS40 and S41 contain two 8-bit timers (Timers 0 and 1), each of which can be operated independently. The cascade connection also allows these timers to be used together as a 16-bit timer. The following four operating modes are supported for the 8-bit timers:

- 8-bit interval timer mode (2 timers)
- 16-bit interval timer mode (1 timer)
- 8-bit programmable square wave pulse generation (PPG: Variable duty with variable cycle) output mode (1 timer)
- 8-bit pulse width modulation (PWM: Variable duty with constant cycle) output mode (1 timer)

Figure 3.7.1 shows the block diagram of the 8-bit timers (Timer 0 and timer 1).

Each timer consists of an 8-bit up counter, 8-bit comparator, and 8-bit timer register. Besides, one timer flip-flop (TFF1) is provided for the pair consisting of timer 0 and timer 1.

Among the input clock sources for the timers, the internal clocks of  $\phi T1$ ,  $\phi T4$ ,  $\phi T16$ , and  $\phi T256$  are obtained from the 9-bit prescaler shown in Figure 3.7.2.

The operation modes and timer flip-flops of the 8-bit timers are controlled by the three control registers TMOD, TFFCR, and TRUN.



Figure 3.7.1 Block Diagram of 8-Bit Timers (Timers 0 and 1)

#### 1. Prescaler

There are 9-bit prescaler and prescaler clock selection registers to generate input clock signals for the 8-bit timers 0 and 1, the 16-bit timers 4 and 5, and the serial interfaces 0 and 1

Figure 3.7.2 shows the corresponding block diagram, and Table 3.7.1 shows prescaler clock signal resolution into 8 and 16-bit timers.



Figure 3.7.2 Block Diagram of the Prescaler

Table 3.7.1 Prescaler Clock Resolution to 8 and 16-Bit Timers

at fc = 20 MHz, fs = 32.768 kHz Select System Select Prescaler Prescaler Clock Resolution Gear Value Clock Clock <GEAR2:0> <SYSCK> <PRCK1:0> φΤ1 **φ**Τ4 φT16 φT256 fs/23 fs/2<sup>5</sup> fs/27 XXX(244 µs) fs/2<sup>11</sup> (62.5 ms) 1 (fs)  $(977 \mu s)$ (3.9 ms)000 (fc) fc/23 fc/2<sup>5</sup> fc/27 fc/2<sup>11</sup> (102.4 μs)  $(0.4 \mu s)$  $(1.6 \mu s)$  $(6.4 \mu s)$ fc/24 00 fc/2<sup>12</sup> (204.8 μs) 001 (fc/2)  $(0.8 \mu s)$ fc/26  $(3.2 \mu s)$ fc/28 (12.8 µs) 0 (fc) (f<sub>FPH</sub>) 010 (fc/4) fc/2<sup>5</sup>  $(1.6 \mu s)$ fc/27  $(6.4 \mu s)$ fc/29 (25.6 µs) fc/2<sup>13</sup> (409.6 μs) fc/26 fc/2<sup>10</sup> fc/2<sup>14</sup> (0.82 ms) fc/28 011(fc/8)  $(3.2 \mu s)$  $(12.8 \mu s)$  $(51.2 \mu s)$ fc/2<sup>15</sup> (1.64 ms) 100 (fc/16) fc/27 (6.<u>4 μ</u>s) fc/29 fc/2<sup>11</sup> (102.4 µs)  $(25.6 \mu s)$ 01 fs/2<sup>11</sup> (62.5 ms) XXX XXXfs/23 (244 µs) fs/2<sup>5</sup> (977 µs) fs/27 (3.9 ms)(Low-frequency clock) 10 (Note) XXXfc/27 fc/29  $fc/2^{11}$  (102.4 µs) fc/2<sup>15</sup> (1.64 ms) XXX  $(6.4 \mu s)$  $(25.6 \mu s)$ (fc/16 clock) XXX: Don't care 16-bit timer Note: The fc/16 clock cannot be used as a 8-bit timer prescaler clock when the fs is used as a system clock.

The timer clock selected among fFPH, fc/16, and fs is divided by 4 and input to this prescaler. The selection is made by system clock control register SYSCR0<PRCK1:0>.

Resetting sets < PRCK1:0> to 00, which selects the fFPH clock input to be divided by 4.

The 8-bit timers 0 and 1 select among 4 clock inputs:  $\phi$ T1,  $\phi$ T4,  $\phi$ T16, and  $\phi$ T256 of the prescaler output.

This prescaler can be run or stopped by the timer control register TRUN<PRRUN>. Counting starts when <PRRUN> is set to "1". The prescaler is cleared to zero and stops operation when <PRRUN> is set to "0".

Resetting clears <PRRUN> to "0" and stops the prescaler.

When the IDLE1 mode (in which only the oscillator operates) is used, set TRUN <PRRUN> to "0" to reduce the power consumption of the prescaler before the "HALT" instruction is executed.

#### 2. Up counter

This is an 8-bit binary counter which counts up by the input clock pulse specified by TMOD.

The input clock of timer 0 is selected from among the external clock from the TI0 pin, and the three internal clocks  $\phi$ T1,  $\phi$ T4, and  $\phi$ T16, according to the value set in the TMOD register.

The input clock used by timer 1 depends on the operation mode. When 16-bit timer mode is set, the overflow output of timer 0 is used as the input clock. When any mode other than 16-bit timer mode is set, the input clock is selected from among the internal clocks  $\phi T1$ ,  $\phi T16$ , and  $\phi T256$  as well as the comparator output (Match detection signal) of timer 0 according to the set value of the TMOD register.

Example: When TMOD<T10M1:0> = 01, the overflow output of timer 0 becomes the input clock of timer 1 (16-bit timer mode).

When TMOD<T10M1:0> = 00 and TMOD<T1CLK1:0> = 01,  $\phi$ T1 becomes the input of timer 1 (8-bit timer mode).

Similarly, operation mode is also set by the TMOD register. When reset, it is initialized to TMOD < T01M1:0 > = 00 whereby the up counter is placed in the 8-bit timer mode.

The counting and stop and clear of the up counter can be controlled for each interval timer by the timer operation control register TRUN. When reset, all up counters will be cleared to stop the timers.

#### 3. Timer registers

These are 8-bit registers for setting a time interval. When the values of the timer registers match the values of the corresponding up counters, the comparator match detect signal becomes active. If the set value is 00H, this signal becomes active when the up counter overflows.

Timer register TREG0 has a double buffer.

The timer flip-flop control register TFFCR<DBEN> bit controls whether the double buffer structure should be enabled or disabled. It is disabled when <DBEN> = "0" and enabled when it is set to "1".

In the double buffer enable state, the data set in the register buffer are transferred to the timer register when the  $2^n - 1$  overflow occurs in PWM mode, or at the PPG cycle in PPG mode. Therefore, during timer mode, the double buffer cannot be used.

Upon resetting, TFFCR will be initialized to <DBEN> = "0", disabling the double buffer. To use the double buffer, write data in the timer register, set <DBEN> to "1", and write the following data in the register buffer.



Figure 3.7.3 Configuration of Timer Register 0

Note: The timer register and the register buffer are allocated at the same memory address. When <DBEN> = 0, the same value is written in the register buffer and in the timer register, while when <DBEN> = 1 the value is written only into the register buffer.

The memory address of each timer register is as follows.

TREG0: 000022H TREG1: 000023H

Both of these registers are write-only and cannot be read.

#### 4. Comparator

A comparator compares the value in the up counter with the values to which the timer register is set. When they match, the up counter is cleared to zero and an interrupt signal (INTTO and INTT1) is generated. If the timer flip-flop inversion is enabled, the timer flip-flop is inverted at the same time.

# 5. Timer flip-flop

The timer flip-flop (TFF1) is a flip-flop inverted by the match detect signal (8-bit comparator output).

Inverting is enabled or disabled by the timer flip-flop control register TFFCR<TFF1IE>.

After a reset operation, the value of TFF1 is undefined. Writing "01" or "10" to TFFCR<TFF1C1:0> sets "0" or "1" to TFF1. Additionally, writing 00 to this bit inverts the value of TFF1. (Software inversion.)

The value in TFF1 can be output to the TO1 pin (also used as P71). When using the TFF1 contents as the timer output, the timer flip-flop should be set by the port 7 function register P7FC beforehand.



Figure 3.7.4 Timer Operation Control Register/System Clock Control Register



Figure 3.7.5 Timer Mode Control Register (TMOD)



Note: TFFCR<br/>bit7:5>, <bit3:2> are read as "1".

Figure 3.7.6 Timer Flip-Flop Control Register (TFFCR)

The operation of 8-bit timers will be described below:

### (1) 8-bit timer mode

Two interval timers, designated "0" and "1", can be used independently as 8-bit interval timers. All interval timers operate in the same manner, and thus only the operation of timer 1 will be explained below.

### 1. Generating interrupts in a fixed cycle

To generate timer 1 interrupts at constant intervals using timer 1 (INTT1), first stop timer 1. Set the operation mode and input clock speed by setting TMOD, and the cycle time by setting TREG1. Then, enable interrupt INTT1 and start the counting of timer 1.

Example: To generate timer 1 interrupt every 1 second at fs = 32 kHz, set each register in the following manner.

# Clock condition

System clock: Low frequency (fs)
Prescaler clock: Low frequency (fs)

| MSB     |     |   |   | LSB |   |   |   |   |                                                                      |
|---------|-----|---|---|-----|---|---|---|---|----------------------------------------------------------------------|
|         | 7   | 6 | 5 | 4   | 3 | 2 | 1 | 0 |                                                                      |
| TRUN    | ← - | Χ | _ | _   | _ | _ | 0 | _ | Stop timer 1, and clear it to "0".                                   |
| TMOD    | ← 0 | 0 | Χ | Χ   | 1 | 0 | _ | _ | Set the 8-bit timer mode, and select $\phi T16$ (4 $$ ms at fs $=32$ |
|         |     |   |   |     |   |   |   |   | kHz) as the input clock.                                             |
| TREG1   | ← 1 | 1 | 1 | 1   | 1 | 0 | 1 | 0 | Set the timer register 1, 1 s $\div$ $\phi$ T16 = 250 = FAH (H       |
|         |     |   |   |     |   |   |   |   | signifies hexadecimal).                                              |
| INTET10 | ← 1 | 1 | 0 | 1   | _ | _ | _ | _ | Enable INTT1, and set it to "Level 5".                               |
| TRUN    | ← 1 | Χ | _ | _   | _ | _ | 1 | _ | Start timer 1 counting.                                              |

X: Don't care, -: No change

Use Table 3.7.1 for selecting the input clock.

Note: The input clock choices available for timer 0 and timer 1 differ from each other as follows.

Timer 0: TI0 input,  $\phi$ T1,  $\phi$ T4,  $\phi$ T16

Timer 1: Match detect signal of timer 0,  $\phi$ T1,  $\phi$ T16,  $\phi$ T256

### 2. Generating a 50% duty, square-wave pulse

The timer flip-flop (TFF1) is inverted at constant intervals, and its status is output to timer output pin (TO1).

Example: To output a  $2.4~\mu s$  square wave pulse from the TO1 pin at fc = 20~MHz, set each register by the following procedures. Either timer 0 or timer 1 may be used, but this example uses timer 1.

\* Clock condition







Figure 3.7.7 Square Wave (50% duty) Output Timing Chart

3. Making timer 1 count up by matching the signal from the timer 0 comparator

Set the 8-bit timer mode, and set the comparator output of timer 0 as the input clock to timer 1.



Figure 3.7.8 Timer 1 Count Up Regulated by Timer 0

### (2) 16-bit timer mode

A 16-bit interval timer is configured by using timer 0 and timer 1 as a pair.

Setting timer mode register TMOD<T10M1:0> to "01" establishes a 16-bit timer mode.

When set in 16-bit timer mode, the overflow output of timer 0 will become the input clock of timer 1, regardless of the set value of TMOD<T1CLK1:0>. Table 3.7.1 shows the selection of timer 0 input clock.

The lower 8 bits of the timer (interrupt) cycle are set by the timer register TREG0, and the upper 8 bits are set by TREG1. Note that TREG0 always must be set first. (Writing data into TREG0 disables the comparator temporarily, and the comparator is restarted by writing data into TREG1.)

Setting example: To generate an interrupt INTT1 every 0.4 seconds at fc = 20 MHz, set the following values for timer registers TREG0 and TREG1.

Clock condition

System clock: High frequency (fc)

Clock gear: 1 (fc)
Prescaler clock: f<sub>FPH</sub>

When counting with the \$\phi T16\$ input clock (6.4 \mus at 20 MHz)

 $0.4 \text{ s} \div 6.4 \text{ } \mu\text{s} = 62500 = F424H$ 

Therefore, set TREG1 = F4H and TREG0 = 24H, respectively.

The comparator signal is output from timer 0 each time the up counter UC0 matches TREGO, when the up counter UC0 is not to be cleared.

With the timer 1 comparator, the match detect signal is output at each comparator check when the up counter UC1 and TREG1 values are found to match. When the match detect signal is output simultaneously from the comparators of both timer 0 and timer 1, the up counters UC0 and UC1 are cleared to 0, and the interrupt INTT1 is generated. If inversion is enabled, the value of the timer flip-flop TFF1 is inverted.

Example: When TREG1 = 04H and TREG0 = 80H



Figure 3.7.9 Timer Output by 16-Bit Timer Mode

## (3) 8-bit PPG (Programmable pulse generation) output mode

Square wave pulse can be generated at any frequency and duty by timer 0. The output pulse may be either low-active or high-active. In this mode, timer 1 cannot be used.

Timer 0 outputs a pulse to the TO1 pin (also used as P71).



Figure 3.7.10 8-Bit PPG Output Waveforms

In this mode, a programmable square wave is generated by inverting the timer output each time the 8-bit up counter (UCO) matches the timer registers TREGO and TREG1.

However, it is necessary for the set value of TREGO to be smaller than that of TREG1.

Though the up counter (UC1) of timer 1 is not used in this mode, UC1 should be set for counting by setting TRUN<T1RUN> to "1".

Figure 3.7.11 shows the block diagram for this mode.



Figure 3.7.11 Block Diagram of 8-Bit PPG Output Mode

When the double buffer of TREG0 is enabled in this mode, the value of the register buffer will be shifted in TREG0 each time TREG1 matches UC0.

Use of the double buffer makes the handling of low duty waves easy (when duty is varied).



Figure 3.7.12 Operation of Register Buffer

Example: Generating 1/4 duty 62.5 kHz pulse (at fc = 20 MHz)



Clock condition

System clock: High frequency (fc)

Clock gear: 1 (fc) Prescaler clock: f<sub>FPH</sub>

• Calculate the value to be set in the timer register.

To obtain a frequency of 62.5 kHz, the pulse cycle time t should be: t=1/62.5 kHz = 16  $\mu$ s. Given  $\phi$ T1 = 0.4  $\mu$ s (at 20 MHz),

$$16 \mu s \div 0.4 \mu s = 40$$

Consequently, set the timer register 1 (TREG1) to TREG1 = 40 = 28H and then to obtain a duty of 1/4,  $t \times 1/4 = 16 \mu s \times 1/4 = 4 \mu s$ 

$$4 \mu s \div 0.4 \mu s = 10$$

Therefore, set timer register 0 (TREG0) to TREG0 = 10 = 0AH.



X: Don't care, -: No change

### (4) 8-bit PWM output mode

This mode is valid only for timer 0. In this mode, the maximum 8-bit resolution of the PWM pulse can be output.

The PWM pulse is output to the TO1 pin (also used as P71) when using timer 0. Timer 1 can also be used as an 8-bit timer.

Timer output is inverted when the up counter (UC0) matches the set value of timer register TREG0, or when  $2^n - 1$  (n = 6, 7, or 8; specified by TMOD<PWMM1:0>) counter overflow occurs. Up counter UC0 is cleared when  $2^n - 1$  counter overflow occurs.

To use this PWM mode, the following conditions must be satisfied.

(Set value of timer register) < (Set value of  $2^n - 1$  counter overflow)

(Set value of timer register)  $\neq 0$ 



Figure 3.7.13 8-Bit PWM Waveforms

Figure 3.7.14 shows the block diagram of operations in this mode.



Figure 3.7.14 Block Diagram of Operations in 8-Bit PWM Mode

In this mode, the value of the register buffer will be shifted into TREG0 if a  $2^n-1$  overflow is detected while the double buffer of TREG0 is enabled.

Use of the double buffer makes easy the handling of small-duty waves.



Figure 3.7.15 Operation of Register Buffer

Example: To output the following PWM waves to the TO1 pin at fc = 20 MHz.



Clock conditions

System clock: High frequency (fc)

Clock gear: 1 (fc) Prescaler clock: f<sub>FPH</sub>

To implement a PWM cycle of 50.8  $\mu$ s by utilizing  $\phi$ T1 = 0.4  $\mu$ s (at fc = 20 MHz),

$$50.8~\mu s \div 0.4~\mu s = 127 = 2^n - 1$$

Consequently, n should be set to 7.

As the period of low level is  $28.8 \mu s$ , for  $\phi T1 = 0.4 \mu s$ ,

set the following value for TREGO.

$$28.8 \, \mu s \div 0.4 \, \mu s = 72 = 48 H$$

|       | MSB                                     | LSB                                                                |
|-------|-----------------------------------------|--------------------------------------------------------------------|
|       | 7 6 5 4 3 2 1                           | 1 0                                                                |
| TRUN  | ← - X                                   | - 0 Stop timer 0 and clear it.                                     |
| TMOD  | ← 1 1 1 0 0                             | Set 8-bit PWM mode (cycle: $2^7 - 1$ ) and select $\phi$ T1 as the |
|       |                                         | input clock.                                                       |
| TREG0 | $\leftarrow$ 0 1 0 0 1 0 0              | 0 0 Writes "48H".                                                  |
| TFFCR | $\leftarrow \ \ X  X  X  X  X  1  0  1$ | 1 X Clear TFF1, enable the inversion and double buffer.            |
| P7CR  | ← X X X X 1                             | 1 - Cot D71 so the TO1 pin                                         |
| P7FC  | ← X X X X 1                             | Set P71 as the TO1 pin.                                            |
| TRUN  | ← 1 X                                   | - 1 Start timer 0 counting.                                        |

X: Don't care, -: No change

Table 3.7.2 PWM Cycle

at fc = 20 MHz, fs = 32.768 kHz

| Select System   | Select                         | Gear Value  | PWM Cycle |                    |          |          |                    |          |          |                    |          |  |  |
|-----------------|--------------------------------|-------------|-----------|--------------------|----------|----------|--------------------|----------|----------|--------------------|----------|--|--|
| Clock           | Prescaler Clock                |             |           | 2 <sup>6</sup> – 1 |          |          | 2 <sup>7</sup> – 1 |          |          | 2 <sup>8</sup> – 1 |          |  |  |
| <sysck></sysck> | <prck1:0></prck1:0>            | 102/111210/ | φΤ1       | φΤ4                | φT16     | φΤ1      | φΤ4                | φT16     | φT1      | φΤ4                | φT16     |  |  |
| 1 (fs)          |                                | XXX         | 15.4 ms   | 61.5 ms            | 246 ms   | 31.0 ms  | 124 ms             | 496 ms   | 62.3 ms  | 249 ms             | 996 ms   |  |  |
|                 |                                | 000 (fc)    | 25.2 μs   | 100.8 μs           | 403.2 μs | 50.8 μs  | 203.2 μs           | 812.8 μs | 102.0 μs | 408.0 μs           | 1.63 ms  |  |  |
|                 | 00<br>(f <sub>FPH</sub> )      | 001 (fc/2)  | 50.4 μs   | 201.6 μs           | 806.4 μs | 101.6 μs | 406.4 μs           | 1.63 ms  | 204.0 μs | 816.0 μs           | 3.26 ms  |  |  |
| 0 (fc)          |                                | 010 (fc/4)  | 100.8 μs  | 403.2 μs           | 1.61 ms  | 203.2 μs | 812.8 μs           | 3.26 ms  | 408.0 μs | 1.63 ms            | 6.53 ms  |  |  |
|                 |                                | 011 (fc/8)  | 201.6 μs  | 806.4 μs           | 3.23 ms  | 406.4 μs | 1.63 ms            | 6.52 ms  | 816.0 μs | 3.26 ms            | 13.06 ms |  |  |
|                 |                                | 100 (fc/16) | 403.2 μs  | 1.61 ms            | 6.45 ms  | 812.8 μs | 3.25 ms            | 13.04 ms | 1.63 ms  | 6.53 ms            | 26.11 ms |  |  |
| XXX             | 01<br>(Low-frequency<br>clock) | XXX         | 15.4 ms   | 61.5 ms            | 246 ms   | 31.0 ms  | 124 ms             | 496 ms   | 62.3 ms  | 249 ms             | 996 ms   |  |  |
| XXX             | 10<br>(fc/16 clock)            | XXX         | 403.2 μs  | 1.61 ms            | 6.45 ms  | 812.8 μs | 3.25 ms            | 13.04 ms | 1.63 ms  | 6.53 ms            | 26.11 ms |  |  |

XXX: Don't care

(5) The list of 8-bit timer modes

Table 3.7.3 shows the list of 8-bit timer modes.

Table 3.7.3 Timer Mode Setting Registers

| Table 611 to Times Med Colling Regionals |            |                                                                         |                                                        |                                                       |                                                         |  |  |  |  |
|------------------------------------------|------------|-------------------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------|--|--|--|--|
| Register Name                            |            | TFFCR                                                                   |                                                        |                                                       |                                                         |  |  |  |  |
| Bit Name                                 | T10M       | PWMM                                                                    | PWMM T1CLK                                             |                                                       | TFF1IS                                                  |  |  |  |  |
| Function                                 | Timer Mode | PWM Cycle                                                               | Upper Timer<br>Input Clock                             | Lower Timer<br>Input Clock                            | Timer F/F Invert<br>Signal Select                       |  |  |  |  |
| 16-bit timer mode                        | 01         | -                                                                       | -                                                      | External clock,<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | -                                                       |  |  |  |  |
| 8-bit timer x 2 channels                 | 00         | -                                                                       | Lower timer match:<br>φT1, 16, 256<br>(00, 01, 10, 11) | External clock,<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | O: Lower timer     output     1: Upper timer     output |  |  |  |  |
| 8-bit PPG × 1 channel                    | 10         | -                                                                       | -                                                      | External clock,<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | -                                                       |  |  |  |  |
| 8-bit PWM × 1 channel                    | 11         | 2 <sup>6</sup> - 1, 2 <sup>7</sup> - 1, 2 <sup>8</sup> - 1 (01, 10, 11) | -                                                      | External clock,<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | -                                                       |  |  |  |  |
| 8-bit timer × 1 channel                  | 11         | -                                                                       | φT1, φT16, φT256<br>(01, 10, 11)                       | -                                                     | Output disabled                                         |  |  |  |  |

-: Don't care

# 3.8 8-Bit PWM Timers

The TMP93CS40 and TMP93CS41 have two built-in 8-bit PWM timers (Timers 2 and 3). Each of these timers has two operating modes.

- 8-bit PWM output mode
- 8-bit interval timer mode

Figure 3.8.1, Figure 3.8.2 are block diagram of 8-bit PWM timers 0 and 1 (Timers 2 and 3).

PWM timers consist of an 8-bit up counter, 8-bit comparator, and 8-bit timer register. Two timer flip-flops (TFF2 for timer 2 and TFF3 for timer 3) are provided.

Input clocks  $\phi$ P1,  $\phi$ P4, and  $\phi$ P16 for the PWM timers can be obtained using the 5-bit built-in prescaler (PWM dedicated prescaler).

PWM timer operating mode and timer flip-flops are controlled by four control registers (P0MOD, P1MOD, PFFCR, and TRUN).

PWM timers 0 and 1 can be used independently.

All PWM timers operate in the same manner, and thus only the operation of PWM timer 0 will be explained below.



Figure 3.8.1 Block Diagram of 8-Bit PWM Timer 0 (Timer 2)



Figure 3.8.2 Block Diagram of 8-Bit PWM Timer 1 (Timer 3)

# 1. Prescaler

There are 5-bit prescaler and prescaler clock selection registers to generate clock inputs for 8-bit PWM timers 0 and 1.

Figure 3.8.3 shows the block diagram. Table 3.8.1 shows prescaler clock resolution into 8-bit PWM timers 0 and 1.



Figure 3.8.3 Block Diagram of the Prescaler

Table 3.8.1 Prescaler Clock Resolution to 8-Bit PWM Timers 0 and 1

at fc = 20 MHz, fs = 32.768 kHz

|                          | Select Prescaler               | Gear Value          | Prescaler Clock Resolution |                             |                              |  |  |  |  |
|--------------------------|--------------------------------|---------------------|----------------------------|-----------------------------|------------------------------|--|--|--|--|
| Clock<br><sysck></sysck> | Clock<br><prck1:0></prck1:0>   | <gear2:0></gear2:0> | φР1                        | φР4                         | φΡ16                         |  |  |  |  |
| 1 (fs)                   |                                | XXX                 | fs/2 <sup>2</sup> (122 μs) | fs/2 <sup>4</sup> (488 μs)  | fs/2 <sup>6</sup> (1.95 ms)  |  |  |  |  |
|                          |                                | 000 (fc)            | fc/2 <sup>2</sup> (0.2 μs) | fc/2 <sup>4</sup> (0.8 μs)  | fc/2 <sup>6</sup> (3.2 μs)   |  |  |  |  |
|                          | 00                             | 001 (fc/2)          | fc/2 <sup>3</sup> (0.4 μs) | fc/2 <sup>5</sup> (1.6 μs)  | fc/2 <sup>7</sup> (6.4 μs)   |  |  |  |  |
| 0 (fc)                   | (f <sub>FPH</sub> )            | 010 (fc/4)          | fc/2 <sup>4</sup> (0.8 μs) | fc/2 <sup>6</sup> (3.2 μs)  | fc/2 <sup>8</sup> (12.8 μs)  |  |  |  |  |
|                          |                                | 011 (fc/8)          | fc/2 <sup>5</sup> (1.6 μs) | fc/2 <sup>7</sup> (6.4 μs)  | fc/2 <sup>9</sup> (25.6 μs)  |  |  |  |  |
|                          |                                | 100 (fc/16)         | fc/2 <sup>6</sup> (3.2 μs) | fc/2 <sup>8</sup> (12.8 μs) | fc/2 <sup>10</sup> (51.2 μs) |  |  |  |  |
| XXX                      | 01<br>(Low-frequency<br>clock) | xxx                 | fs/2² (122 μs)             | fs/2 <sup>4</sup> (488 μs)  | fs/2 <sup>6</sup> (1.95 ms)  |  |  |  |  |
| XXX                      | 10<br>(fc/16 clock)            | XXX                 | fc/2 <sup>6</sup> (3.2 μs) | fc/2 <sup>8</sup> (12.8 μs) | fc/2 <sup>10</sup> (51.2 μs) |  |  |  |  |

XXX: Don't care

Note: The fc/16 clock cannot be used as a prescaler clock when the fs is used as a system clock.

The clock selected among fFPH, fc/16, and fs is divided by 2 and input to this prescaler. The selection is made by the system clock control register SYSCR0<PRCK1:0>.

Resetting sets <PRCK1:0> to 00, selecting the f<sub>FPH</sub> clock input to be divided by 2. The TRUN<PRRUN> register which controls this prescaler, is also used for the other timers. So, this prescaler cannot be operated independently.

The 8-bit PWM timers 0 and 1 select one of the clock inputs:  $\phi$ P1,  $\phi$ P4, and  $\phi$ P16, from among the three prescaler outputs.

This prescaler also can be run or stopped by TRUN<PRRUN> as described in discussion of the 8-bit timer.

Counting starts when <PRRUN> is set to 1. The prescaler is cleared and stops operation when <PRRUN> is set to 0.

Resetting clears <PRRUN> and stops the prescaler.

When the IDLE1 mode (with only the oscillator operating) is used, set TRUN<PRRUN> to "0" to reduce the power consumption of the prescaler before the "HALT" instruction is executed.

## 2. Up counter

The up counter is an 8-bit binary counter which counts up using the input clock specified by PWM0 mode register P0MOD<T2CLK1:0>.

The input clock for the up counter is selected from among the internal clocks  $\phi$ P1,  $\phi$ P4, and  $\phi$ P16 (PWM dedicated prescaler output) depending on the value in <T2CLK1:0>.

Operating mode is set by P0MOD<PWM0M>. At reset, <PWM0M> is initialized to "0", and thus the up counter is placed in PWM mode. In PWM mode, the up counter is cleared when a  $2^n-1$  overflow occurs; in timer mode, the up counter is cleared at compare and match

Count/stop and clear of the up counter can be controlled for each PWM timer using the timer operation control register TRUN. Resetting clears all up counters and stops all PWM timers.

## 3. Timer register

The 8-bit register is used for setting a time interval. When the value set in the timer register (TREG2) matches the value in the up counter, the match detect signal of the comparator becomes active.

Timer register TREG2 is paired with a register buffer to make a double buffer structure.

TREG2 controls double buffer enable/disable by P0MOD<DB2EN>. The double buffer is disabled when  $\langle DB2EN \rangle = 0$ , and enabled when  $\langle DB2EN \rangle = 1$ .

In double buffer enable state, data are transferred from register buffer to timer register when a  $2^n-1$  overflow occurs in PWM mode, or when compare and match occur in 8-bit timer mode. A PWM timer can be operated in timer mode in double buffer enable state, whereas timers 0 and 1 cannot.

At reset, <DB2EN> is initialized to 0 to disable the double buffer. The same value is set in both the register buffer and the timer register. To use the double buffer, write the data in the timer register first, then set <DB2EN> to 1 and write the following data in the register buffer.



Figure 3.8.4 Structure of Timer Registers 2

Memory addresses of the timer registers are as follows:

TREG2: 000026H (PWM timer 0) TREG3: 000027H (PWM timer 1)

The timer register and register buffer are allocated to the same memory address. When  $\mbox{DB2EN>} = 0$ , the same value is written to both the register buffer and timer register. When

<DB2EN> = 1, a value is written to the register buffer only.

Register buffer values can be read when reading the above addresses. The timer register is write-only and it cannot be read.

#### 4. Comparator

This element compares the value in the up counter with the value in the timer register (TREG2). When they match, the comparator outputs the match detect signal. A timer interrupt (INTT2) is generated at compare and match if the interrupt select bit <PWM0INT> of the mode register (P0MOD) is set to 1. In timer mode, the comparator clears the up counter at compare and match. It also inverts the value of the timer flip-flop if timer flip-flop invert is enabled.

# 5. Timer flip-flop

The value of the timer flip-flop is inverted by the match detect signal (comparator output) of each interval timer or by  $2^n - 1$  overflow. The flip-flop value can be output to the timer output pin TO2 (also used as P72).



Figure 3.8.5 8-bit PWM0 Mode Control Register



Figure 3.8.6 8-Bit PWM 1 Mode Control Register



Figure 3.8.7 8-Bit PWM Flip-flop Control Register



Figure 3.8.8 Timer Operation Control Register/System Clock Control Register

The following explains PWM timer operations.

# (1) PWM timer mode

PWM output changes under the following two conditions.

### Condition 1:

- TFF2 is cleared when the value in the up counter (UC2) matches the value set in the TREG2.
- TFF2 is set to 1 when a  $2^n 1$  counter overflow (n = 6, 7, or 8) occurs.

#### Condition 2:

- TFF2 is set to 1 when the value in the up counter (UC2) matches the value set in TREG2.
- TFF2 is cleared when a  $2^n 1$  counter overflow (n = 6, 7, or 8) occurs.

The up counter (UC2) is cleared by a  $2^{n} - 1$  counter overflow.

The PWM timer can output 0% to 100% duty pulses because a  $2^n-1$  counter overflow has a higher priority. That is, to obtain 0% output (Always low), the mode used to set TFF2 to 0 due to overflow (PFFCR<FF2TRG1:0> = 10) must be set and  $2^n-1$  (A value indicating an overflow) must be set in TREG2. To obtain 100% output (Always high), the mode must be changed by setting PFFCR<FF2TRG1:0> = 11 and then TREG2 must be set to  $2^n-1$ .

#### PWM timing



Figure 3.8.9 Output Waves in PWM Timer Mode

Note: The waves pictured above are obtained in the mode in which the flip-flop is set by a match with the timer register (TREG), and is reset by an overflow.

Figure 3.8.10 is a block diagram of this mode.



Figure 3.8.10 Block Diagram of PWM Timer Mode (PWM0)

In this mode, enabling double buffer is very useful. The register buffer value shifts into TREG2 when a  $2^n - 1$  overflow is detected, when double buffer is enabled.

Use of the double buffer makes the handling of low duty waves easy.



Figure 3.8.11 Register Buffer Operation

Example: To output the following PWM waves to the TO2 pin using PWM0 at  $\ensuremath{\text{fc}} = 20 \ensuremath{\,\text{MHz}}$ 

# Clock condition

System clock: High frequency (fc)

Clock gear: 1 (fc)
Prescaler clock: f<sub>FPH</sub>



To implement 25.4  $\mu s$  as the PWM cycle regulated by  $\phi P1$  = 0.2  $\mu s$  (at fc = 20 MHz)

$$2^{n} - 1 = 25.4 \ \mu s \div 0.2 \ \mu s = 127.$$

Consequently, set n to 7.

Since the low level cycle = 12  $\mu s;$  for  $\phi P1$  = 0.2  $\mu s$ 

$$3CH = 12 \ \mu s \div 0.2 = 60$$

set the 3CH in TREG2.

|       | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                                                     |
|-------|------------|---|---|---|---|---|---|---|---------------------------------------------------------------------|
| TRUN  | ← -        | Χ | _ | _ | _ | 0 | _ | _ | Stops PWM0 and clears it.                                           |
| P0MOD | ← -        | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Sets PWM (2 <sup>7</sup> − 1) mode, input clock $\phi$ P1, overflow |
|       |            |   |   |   |   |   |   |   | interrupt, and disables double buffer.                              |
| TREG2 | ← 0        | 0 | 1 | 1 | 1 | 1 | 0 | 0 | Writes 3CH.                                                         |
| P0MOD | ← -        | 1 | 0 | 0 | 0 | 0 | 0 | 1 | Enables double buffer.                                              |
| PFFCR | ← -        | - | _ | _ | 0 | 1 | 1 | 0 | Sets TFF2 and the mode in which TFF2 is set by compare              |
|       |            |   |   |   |   |   |   |   | and match, and cleared by overflow.                                 |
| P7CR  |            | Χ | Χ | Χ | _ | 1 | _ | _ | Sets P72 as TO2 pin.                                                |
| P7FC  | ← X<br>← X | Χ | Χ | Χ | _ | 1 | _ | Χ | Sets P72 as 102 pm.                                                 |
| TRUN  | ← 1        |   |   |   |   |   | _ | _ | Starts PWM0 counting.                                               |

X: Don't care, -: No change

Table 3.8.2 PWM Cycle

at fc = 20 MHz, fs = 32.768 kHz

| Select System   | Select                |                                   | PWM cycle |                    |          |          |                    |          |                    |          |          |  |  |
|-----------------|-----------------------|-----------------------------------|-----------|--------------------|----------|----------|--------------------|----------|--------------------|----------|----------|--|--|
| , i             | Prescaler Clock       | Gear Value<br><gear2:0></gear2:0> |           | 2 <sup>6</sup> – 1 |          |          | 2 <sup>7</sup> – 1 |          | 2 <sup>8</sup> – 1 |          |          |  |  |
| <sysck></sysck> | <prck1:0></prck1:0>   | <b>VOLVIII.</b>                   | φΡ1       | φΡ4                | φP16     | φΡ1      | φΡ4                | φP16     | φΡ1                | φΡ4      | φP16     |  |  |
| 1 (fs)          |                       | XXX                               | 7.69 ms   | 30.8 ms            | 123 ms   | 15.5 ms  | 62.0 ms            | 248 ms   | 31.1 ms            | 125 ms   | 498 ms   |  |  |
|                 |                       | 000 (fc)                          | 12.6 μs   | 50.4 μs            | 201.6 μs | 25.4 μs  | 101.6 μs           | 406.4 μs | 51.0 μs            | 204.0 μs | 816.0 μs |  |  |
|                 | 00                    | 001 (fc/2)                        | 25.2 μs   | 100.8 μs           | 403.2 μs | 50.8 μs  | 203.2 μs           | 812.8 μs | 102.0 μs           | 408.0 μs | 1.63 ms  |  |  |
| 0 (fc)          | (f <sub>FPH</sub> )   | 010 (fc/4)                        | 50.4 μs   | 201.6 μs           | 806.4 μs | 101.6 μs | 406.4 μs           | 1.63 ms  | 204.0 μs           | 816.0 μs | 3.26 ms  |  |  |
|                 |                       | 011 (fc/8)                        | 100.8 μs  | 403.2 μs           | 1.61 ms  | 203.2 μs | 812.8 μs           | 3.25 ms  | 408.0 μs           | 1.63 ms  | 6.53 ms  |  |  |
|                 |                       | 100 (fc/16)                       | 201.6 μs  | 806.4 μs           | 3.23 ms  | 406.4 μs | 1.63 ms            | 6.50 ms  | 816.0 μs           | 3.26 ms  | 13.06 ms |  |  |
| XXX             | 01<br>(Low frequency) | XXX                               | 7.69 ms   | 30.8 ms            | 123 ms   | 15.5 ms  | 62.0 ms            | 248 ms   | 31.1 ms            | 125 ms   | 498 ms   |  |  |
| XXX             | 10<br>(fc/16 clock)   | XXX                               | 201.6 μs  | 806.4 μs           | 3.23 ms  | 406.4 μs | 1.63 ms            | 6.50 ms  | 816.0 µs           | 3.26 ms  | 13.06 ms |  |  |

XXX: Don't care

#### (2) 8-bit timer mode

Both PWM timers can be used independently as 8-bit interval timers. Since both timers operate in exactly the same way, PWM0 (timer 2) is used for the purposes of explanation.

### 1. Generating interrupts at a fixed interval

To generate timer 2 interrupt (INTT2) at a fixed interval using the PWM0 timer, first stop PWM0, then set the operating mode, input clock, and interval in the P0MOD and TREG2 registers. Next, enable INTT2 and start counting PWM0.

Example: To generate a timer 2 interrupt every 32  $\mu s$  at fc = 20 MHz, set registers as follows:

#### Clock condition

System clock: High frequency (fc)

Clock gear: 1 (fc)
Prescaler clock: f<sub>FPH</sub>

|          | 7              | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                                              |
|----------|----------------|---|---|---|---|---|---|---|--------------------------------------------------------------|
| TRUN     | ← -            | Χ | _ | _ | _ | 0 | _ | _ | Stops PWM timer 0 and clears it.                             |
| P0MOD    | $\leftarrow X$ | 0 | 1 | 1 | 0 | 0 | Χ | Χ | Sets 8-bit timer mode and selects $\phi P1~(0.2\mu s)$ and   |
|          |                |   |   |   |   |   |   |   | compare interrupt.                                           |
| TREG2    | ← 1            | 0 | 1 | 0 | 0 | 0 | 0 | 0 | Sets A0H (= 32 $\mu$ s ÷ 0.2 $\mu$ s) in the timer register. |
| INTEPW10 | ← -            | _ | _ | _ | 1 | 1 | 0 | 0 | Enables INTT2 and sets interrupt level 4.                    |
| TRUN     | ← 1            | Х | _ | _ | _ | 1 | _ | _ | Starts counting PWM0.                                        |

# X: Don't care, -: No change

Select an input clock using Table 3.8.1.

Note: To generate interrupts in 8-bit timer mode, bit5 (Interrupt control bit <PWM0INT> of P0MOD) must be set to 1.

### 2. Generating a 50% square wave

To generate a 50% square wave, invert the timer flip-flop at a fixed interval and output the timer flip-flop value to the timer output pin (TO2).

Example: To output a  $2.4\,\mu s$  square wave at fc =  $20\,MHz$  from the TO2 pin, set the registers as follows.

Clock condition
System clock: High frequency (fc)
Clock gear: 1 (fc)
Prescaler clock: f<sub>FPH</sub>



### X: Don't care, -: No change



Figure 3.8.12 Square Wave (50% duty) Output Timing Chart

This mode is as shown in Figure 3.8.13 below.



Figure 3.8.13 Block Diagram of 8-Bit Timer Mode

# 3.9 16-Bit Timers

The TMP93CS40 and TMP93CS41 contain two multifunctional 16-bit timer/event counters (Timer 4 and timer 5) which support the following operation modes.

- 16-bit interval timer mode
- 16-bit event counter mode
- 16-bit programmable pulse generation (PPG) mode
- Frequency measurement mode
- Pulse width measurement mode
- Time differential measurement mode

Each timer/event counter consists of a 16-bit up counter, two 16-bit timer registers (One with a double-buffer), two 16-bit capture registers, two comparators, a capture input controller, a timer flip-flop and the control circuit.

Timer/event counters are controlled by 4 control registers: T4MOD/T5MOD, T4FFCR/T5FFCR, TRUN and T45CR.

Figure 3.9.1, Figure 3.9.2 show the block diagram of the 16-bit timer/event counters (Timer 4 and timer 5).

Timers 4 and 5 can be used independently.

All timers operate in the same manner except for the following points, and thus only the operation of timer 4 will be explained below.

Points Differing between Timers 4 and 5

|                                    | 16-Bit Timer 4                   | 16-Bit Timer 5     |
|------------------------------------|----------------------------------|--------------------|
| Timer out pin                      | TO4 pin (TFF4)<br>TO5 pin (TFF5) | TO6 pin (TFF6)     |
| Different phased pulse output mode | Yes                              | No<br>(No TO7 pin) |



Figure 3.9.1 Block Diagram of 16-Bit Timer (Timer 4)



Figure 3.9.2 Block Diagram of 16-Bit Timer (Timer 5)



Figure 3.9.3 16-Bit Timer Mode Control Register (T4MOD) (1/2)



CAP2T5: Inverted when the up counter value is latched to CAP2 EQ5T5: Inverted when the up counter matches TREG5

Figure 3.9.4 16-Bit Timer Controller Register (T4MOD) (2/2)



Figure 3.9.5 16-Bit Timer 4 F/F Control (T4FFCR)



Figure 3.9.6 16-Bit Timer Mode Control Register (T5MOD) (1/2)



Figure 3.9.7 16-Bit Timer Control Register (T5MOD) (2/2)



CAP4T6: Inverted when the up counter value is latched to CAP4 CAP3T6: Inverted when the up counter value is latched to CAP3

EQ7T6: Inverted when up counter matches TREG7 EQ6T6: Inverted when up counter matches TREG6

Figure 3.9.8 16-Bit Timer 5 F/F Control (T5FFCR)



Note 1: In case of not using the 7 stage binary counter as a warm-up timer, a stable clock signal must be input from an external circuit.

Note 2: T45CR<bit6:4> are always read as "1".

Figure 3.9.9 16-Bit Timer Trigger Control Register (T45CR)



Figure 3.9.10 Timer Operation Control Register/System Clock Control Register

#### 1. Prescaler

There are 9-bit prescaler and prescaler clock-selection registers to generate input clock signals for 8-bit timers 0 and 1, 16-bit timers 4 and 5, and serial interfaces 0 and 1.

Figure 3.9.11 shows the block diagram. Table 3.9.1 shows prescaler clock resolution into 8-/16-bit timers.



Figure 3.9.11 Block Diagram of Prescaler

Table 3.9.1 Prescaler Clock Resolution into 8-/16-Bit Timers

at fc = 20 MHz, fs = 32.768 kHzSelect Prescaler Clock Resolution Gear Value Select Prescaler Clock System Clock <PRCK1:0> <GEAR2:0> φΤ1 φ**T**4 φT16 φT256 <SYSCK> fs/2<sup>11</sup> (62.5 ms) fs/2<sup>3</sup> (244 μs) fs/2<sup>5</sup> (977 μs) fs/27 (3.9 ms) 1 (fs) XXX000 (fc)  $fc/2^3$  (0.4 µs)  $fc/2^5$  (1.6 µs)  $fc/2^7$  (6.4 µs) fc/2<sup>11</sup> (102.4 μs) 001 (fc/2) fc/24 (0.8 μs)  $fc/2^6$  (3.2 µs) fc/28 (12.8 μs) fc/2<sup>12</sup> (204.8 μs 00 (f<sub>FPH</sub>) 010 (fc/4) fc/2<sup>5</sup> (1.6 μs)  $fc/2^7$  (6.4 µs) fc/2<sup>9</sup> (25.6 μs) fc/2<sup>13</sup> (409.6 μs) 0 (fc) fc/2<sup>6</sup> (3.2 μs) fc/28 (12.8 μs) fc/2<sup>10</sup> (51.2 μs) fc/2<sup>14</sup> (819.2 ms 011 (fc/8) 100 (fc/16) fc/2<sup>7</sup> (6.4 μs) fc/29 (25.6 μs) fc/2<sup>11</sup> (102.4 μs) fc/2<sup>15</sup> (1.64 ms) 01 XXXXXXfs/2<sup>3</sup> (244 μs) fs/2<sup>5</sup> (977 μs) fs/2<sup>7</sup> (3.9 ms) fs/2<sup>11</sup> (62.5 ms) (Low-frequency clock) XXX10 fc/2<sup>11</sup> (102.4 μs) fc/2<sup>15</sup> (1.64 ms) XXX $fc/2^{7}$  (6.4 µs) fc/29 (25.6 μs) (fc/16 clock) XXX: Don't care 16-bit timer Note: The fc/16 clock cannot be used as a prescaler clock when the fs is used as a system clock. 8-bit timer

The clock selected from among fFPH, fc/16, and fs is divided by 4 and input to this prescaler. This selection is made by prescaler clock selection register SYSCR0<PRCK1:0>.

Resetting sets <PRCK1:0> to 00, selecting the fFPH clock input divided by 4.

The 16-bit timers 4 and 5 select among 3 clock inputs:  $\phi$ T1,  $\phi$ T4, and  $\phi$ T16 among the prescaler outputs.

This prescaler can be run or stopped by the timer operation control register TRUN<PRRUN>. Counting starts when <PRRUN> is set to "1". The prescaler is cleared to zero and stops operation when <PRRUN> is set to "0".

Resetting clears <PRRUN> to "0" and stops the prescaler.

When the IDLE1 mode (In which only the oscillator operates) is used, set TRUN<PRRUN> to "0" to reduce the power consumption of the prescaler before the "HALT" instruction is executed.

#### 2. Up counter

The up counter is a 16-bit binary counter which counts up according to the input clock specified by T4MOD<T4CLK1:0> register.

The alternatives for selecting the input clock include any one of the internal clocks  $\phi$ T1,  $\phi$ T4, and  $\phi$ T16 from the 9-bit prescaler (which is also used as an 8-bit timer), as well as the external clock from the TI4 pin (which itself can also be used as the P80 or INT4 pin). When reset, <T4CLK1:0> will be initialized to 00; this selects TI4 input mode. Counting or stop and clear of the counter are controlled by timer operation control register TRUN<T4RUN>.

When clearing is enabled, up counter UC4 will be cleared each time it matches the timer register TREG5. The "clear enable/disable" setting is made by T4MOD<CLE>.

If clearing is disabled, the counter operates as a free-running counter.

### 3. Timer registers (TREG4 to TREG7)

These two 16-bit registers are used to set the interval time. When the value of up counter UC4 matches the value set in this timer register, the comparator match detect signal will be activated.

Setting data in both lower and upper registers are always needed. For example, either by using a 2-byte data transfer instruction, or by using 1-byte data transfer instructions twice: once for the lower 8 bits and once for the upper 8 bits in that order.



The TREG4 timer register is a double buffer structure, which is paired with a register buffer. The timer control register T45CR<DB4EN> controls whether the double buffer structure should be enabled or disabled. It is disabled when  $\langle DB4EN \rangle = 0$ , and enabled when  $\langle DB4EN \rangle = 1$ .

When the double buffer is enabled, the timing of data transfer from the register buffer to the timer register is at the match between the up counter (UC4) and timer register TREG5.

When reset, <DB4EN> will be initialized to "0"; this disables the double buffer. To use the double buffer, write data in the timer register, set <DB4EN> = 1, and then write the data which follows to the register buffer.

TREG4 and the register buffer are allocated to the same memory addresses 000030H/000031H. When  $\langle DB4EN \rangle = 0$ , the same value will be written in both the timer register and in the register buffer. When  $\langle DB4EN \rangle = 1$ , the value is written only into the register buffer. Therefore, to write the initial value into the timer register, the register buffer should be disabled.

# 4. Capture registers

These 16-bit registers are used to hold the values of the up counter.

Data in the capture registers should be read all 16 bits. For example, by a 2-byte data load instruction or by two 1-byte data load instructions, starting from the lower 8 bits followed by the upper 8 bits.



### 5. Capture input control

This circuit controls the timing of latching the value of up counter UC4 into CAP1 and CAP2. The latch timing of the capture register is controlled by register T4MOD<CAP12M1:0>. There are four possible settings:

• When T4MOD<CAP12M1:0> = 00

Capture function is disabled. Disable is the default on resetting.

• When T4MOD < CAP12M1:0 > = 01

Data are loaded to CAP1 at the rising edge of the TI4 pin (which is also used as P80 or INT4) input, while data are loaded to CAP2 at the rising edge of the TI5 pin (also used as P81 or INT5) input. (Time difference measurement.)

• When T4MOD<CAP12M1:0> = 10

Data are loaded to CAP1 at the rising edge of the TI4 pin input, and to CAP2 at the falling edge. Only in this setting, interrupt INT4 occurs at the falling edge. This results in pulse width measurement.

• When T4MOD < CAP12M1:0 > = 11

Data are loaded to CAP1 at the rising edge of timer flip-flop TFF1, and to CAP2 at the falling edge.

Besides, the value of the up counter can be loaded to capture registers by software. Whenever "0" is written in T4MOD<CAP1IN>, the current value of the up counter will be loaded to capture register CAP1. It is necessary to keep the prescaler in RUN mode (TRUN<PRRUN> has to be 1).

### 6. Comparator

There are 16-bit comparators which compare the up counter UC4 value with the values set in TREG4 and TREG5 to detect matches. When a match is detected, these comparators generate interrupts INTTR4 or INTTR5 respectively. The up counter UC4 is cleared only when UC4 matches TREG5. The clearing of up counter UC4 can be disabled by setting T4MOD<CLE> = 0.

## 7. Timer flip-flop (TFF4)

This flip-flop is inverted by the match detect signal from the comparators or the latch signals to the capture registers. Disable or enable of inversion can be set for each element by T4FFCR<CAP2T4, CAP1T4, EQ5T4 and EQ4T4>. TFF4 will be inverted when "00" is written in T4FFCR<TFF4C1:0>. Also it is set to "1" when "01" is written, and cleared when "10"S is written. The value of TFF4 can be output to the timer output pin TO4 (which is also used as P82). TFF4 is undefined on resetting.

#### 8. Timer flip-flop (TFF5)

This flip-flop is inverted when the comparator detects that the up counter signal (UC4) and the contents of the timer register TREG5 match, or when the contents of the up counter are latched to the capture register CAP2. Disable or enable of inversion can be set for each element by T4MOD<CAP2T5 and EQ575>. TFF5 will be inverted when "00" is written in T4FFCR<TFF5C1:0>. Also it is set to "1" when "01" is written, and cleared when "10" is written. The value of TFF5 can be output to the timer output pin TO5 (also used as P83). TFF5 is undefined on resetting.

Note: This flip-flop (TFF5) is contained only in the 16-bit timer 4.

### (1) 16-bit timer mode

Generating interrupts at fixed intervals:

In this example, the interval time is set in the timer register TREG5 to generate the interrupt INTTR5.

```
TRUN
                                                     Stop timer 4.
INTET54
                             0
                                    0
                                                     Enable INTTR5 and set interrupt level 4. Disable INTTR4.
T4FFCR
                             0
                                                     Disable trigger.
T4MOD
                                                     Select internal clock for input and
                                                     disable the capture function.
TREG5
                                                     Set the interval time (16 bits).
TRUN
                                                     Start timer 4.
```

X: Don't care, -: No change

### (2) 16-bit event counter mode

In 16-bit timer mode as described in (1) above, the timer can be used as an event counter by selecting the external clock (TI4 pin input) as the input clock. To read the value of the counter, first perform "software capture" once and read the captured value.

The counter counts at the rising edge of the TI4 pin input.

The TI4 pin can also be used as P80 or INT4.

```
5 4 3 2
TRUN
                                                  Stop timer 4.
P8CR
                                                  Set P80 to input mode.
INTET54
                       0 0 1 0
                                                  Enable INTTR5 and sets interrupt level 4, while disables
                                                  INTTR4.
T4FFCR
                       0
                           0
                                  0
                                                  Disable trigger.
T4MOD
                   n
                           n
                                                  Select TI4 as the input clock.
TREG5
                                                  Set the number of counts (16 bits).
TRUN
                   Χ
                                                  Start timer 4.
```

Note: When using this set up as an event counter, set the prescaler in RUN mode.

### (3) 16-bit programmable pulse generation (PPG) output mode

The PPG mode is obtained by inversion of the timer flip-flop TFF4 that is enabled by the match of the up counter UC4 with either of the timer registers TREG4 or TREG5. TFF4 is also output to TO4 (which can be alternatively used as P82). In this mode, the following conditions must be satisfied:

(Set value of TREG4) < (Set value of TREG5)



### X: Don't care, -: No change



Figure 3.9.12 Programmable Pulse Generation (PPG) Output Waveforms

When the double buffer of TREG4 is enabled in this mode, the value of register buffer 4 will be shifted into TREG4 on finding a match with TREG5. This feature makes the handling of low duty waves easy.



Figure 3.9.13 Operation of Register Buffer

TRUN<T4RUN> TO4 (PPG output) TO5 16-bit up counter Flip-flop Flip-flop Selector Clear UC4 (TFF4) (TFF5) Match Match 16-bit comparator 16-bit comparator TREG4 Selector TREG4-WR Register buffer 4 TREG5 T45CR<DB4EN> Internal data bus

Figure 3.9.14 shows the block diagram of this mode.

Figure 3.9.14 Block Diagram of 16-Bit PPG Mode

# (4) Application examples of the capture function

It is possible to enable or disable the loading of up counter (UC4) values into the capture registers CAP1 and CAP2, the timer flip-flop TFF4 inversion due to match detection by comparators CP4 and CP5, and the output of the TFF4 status to the TO4 pin. Combined with the interrupt function, these options can be applied in many ways, for example:

- 1. One-shot pulse output from external trigger pulse
- 2. Frequency measurement
- 3. Pulse width measurement
- 4. Time difference measurement

These four application examples are described in detail below.

### 1. One-shot pulse output from external trigger pulse

To program this application, set the up counter UC4 in free-running mode with the internal input clock, input the external trigger pulse from the TI4 pin, and load the value of the up counter into capture register CAP1 at the rising edge of the TI4 pin. Then set T4MOD < CAP12M1:0 > 01.

When the interrupt INT4 is generated at the rising edge of the TI4 input, set the CAP1 value (c) plus a delay time (d) to TREG4 (= c + d), and set the above set value (c + d) plus a one-shot pulse width (p) to TREG5 (= c + d + p). When the interrupt INT4 occurs, the T4FFCR<EQ5T4 and EQ4T4>register should be set so that the TFF4 inversion is enabled only when the up counter value matches TREG4 or TREG5. When interrupt INTTR5 occurs, this inversion will be disabled.



Figure 3.9.15 One-shot Pulse Output (with delay)

Setting example: To output a 2 ms one-shot pulse to the external trigger pulse to TI4 pin, with 3 ms delay

## Clock condition

System clock: High frequency (fc)

Clock gear: 1 (fc) Prescaler clock: f<sub>FPH</sub>



# Setting of INT4

```
TREG4 \leftarrow CAP1 + 3 ms/\phiT1
TREG5 \leftarrow TREG4 + 2 ms/\phiT1
T4FFCR \leftarrow - - - - 1 1 - -

Enable TFF4 inversion when the up counter value matches TREG4 or TREG5.

INTET54 \leftarrow 1 1 0 0 - - - - Enable INTTR5.
```

## Setting of INTTR5



X: Don't care, -: No change

When a delay time is unnecessary, invert the timer flip-flop TFF4 by loading the up counter value into capture register 1 (CAP1). Then set TREG5 to the CAP1 value (c) plus the one-shot pulse width (p) when an INT4 interrupt occurs. The TFF4 inversion should be enabled when the up counter (UC4) value matches TREG5, and disabled when generating the interrupt INTTR5.



Figure 3.9.16 One-shot Pulse Output (without delay)

# 2. Frequency measurement

The frequency of the external clock can be measured in this mode. The clock signal is input through the TI4 pin, and its frequency is measured by the 8-bit timers (Timer 0 and timer 1) and the 16-bit timer/event counter (Timer 4).

The TI4 pin input should be selected for the clock input of timer 4. The value of the up counter is loaded into the capture register CAP1 at the rising edge of the timer flip-flop TFF1 of the 8-bit timers (Timer 0 and timer 1). Similarly, the up counter value is loaded into CAP2 at the falling edge of the TFF1 flip-flop.

The frequency is calculated by the difference between the values loaded in CAP1 and CAP2, at the moment when an interrupt (INTT0 or INTT1) is generated by either 8-bit timer.



Figure 3.9.17 Frequency Measurement

For example, if the value for the level "1" width of TFF1 of the 8-bit timer is set to 0.5~s and the difference between CAP1 and CAP2 is 100, the frequency will be  $100 \div 0.5~s = 200~Hz$ .

### 3. Pulse width measurement

This mode allows measurement of the H level width of an external pulse. While keeping the 16-bit timer/event counter counting (Free running) with the internal clock input, the external pulse is input via the TI4 pin. Then the capture function is used to load the UC4 values into CAP1 and CAP2 on the rising edge and falling edge of the external trigger pulse respectively. The interrupt INT4 occurs at the falling edge of TI4.

The pulse width is obtained from the difference between the values of CAP1 and CAP2 and the internal clock cycle.

For example, if the internal clock is  $0.8 \,\mu s$  and the difference between CAP1 and CAP2 is 100, the pulse width will be  $100 \times 0.8 \,\mu s = 80 \,\mu s$ .



Figure 3.9.18 Pulse Width Measurement

Note: External interrupt INT4 occurs at the falling edge of the TI4 pin input only in this pulse width measuring mode (T4MOD<CAP12M1:0> = 10). In other modes, it occurs at the rising edge.

The width of the L level can be measured from the difference between the first C2 and the second C1 at the second INT4 interrupt.

## 4. Time difference measurement

This mode is used to measure the difference in time between the rising edges of external pulses input via TI4 and TI5.

While keeping the 16-bit timer/event counter (Timer 4) counting (Free running) with the internal clock, the UC4 value is loaded into CAP1 on the rising edge of the input pulse to TI4. Then the interrupt INT4 is generated.

Similarly, the UC4 value is loaded into CAP2 on the rising edge of the input pulse to TI5, generating the interrupt INT5.

The time difference between these pulses can be obtained from the difference between the time counts at which loading the up counter value into CAP1 and CAP2 was performed.



Figure 3.9.19 Time Difference Measurement

# (5) Different phased pulses output mode (This mode can be used only with timer 4.)

In this mode, signals with any phase can be output by the free-running up counter UC4. When the value in up counter UC4 and the value in TREG4 (TREG5) match, the value in TFF4 (TFF5) is inverted and output to TO4 (TO5).



Figure 3.9.20 Phase Output

The periods of the output waveforms above (Expressed as counter overflow time) are listed in Table 3.9.2.

Table 3.9.2 Timer Output Periods in Different Phased Pulse Output Mode (Expressed as counter overflow time)

at fc = 20 MHz, fs = 32.768 kHz

| System Clock                | Prescaler Clock                 | Gear Value          | Counter Overflow Time |           |           |  |
|-----------------------------|---------------------------------|---------------------|-----------------------|-----------|-----------|--|
| Selected<br><sysck></sysck> | Selected<br><prck1:0></prck1:0> | <gear2:0></gear2:0> | φΤ1                   | φΤ4       | φT16      |  |
| 1 (fs)                      |                                 | XXX                 | 16.0s                 | 64.0 s    | 256.0 s   |  |
|                             |                                 | 000 (fc)            | 26.21 ms              | 104.86 ms | 419.43 ms |  |
|                             | 00                              | 001 (fc/2)          | 52.43 ms              | 209.72 ms | 838.86 ms |  |
| 0 (fc)                      | (f <sub>FPH</sub> )             | 010 (fc/4)          | 104.86 ms             | 419.43 ms | 1.68 s    |  |
|                             |                                 | 011 (fc/8)          | 209.72 ms             | 838.86 ms | 3.36 s    |  |
|                             |                                 | 100 (fc/16)         | 419.43 ms             | 1.68 s    | 6.71 s    |  |
| XXX                         | 01<br>(Low-frequency clock)     | XXX                 | 16.0 s                | 64.0 s    | 256.0 s   |  |
| XXX                         | 10<br>(fc/16 clock)             | xxx                 | 419.43 ms             | 1.68 s    | 6.71 s    |  |

XXX: Don't care

# 3.10 Stepping Motor Control/Pattern Generation Port

The TMP93CS40/TMP93CS41 contains two 4-bit hardware stepping motor control/pattern generation channels, PG0 and PG1, (hereinafter called PG) which actuate in synchronization with the (8-bit/16-bit) timers. PG (PG0 and PG1) shares the 8-bit input/output port with P6.

The output on channel 0 (PG0) is updated in synchronization with the 8-bit timer 0, 8-bit timer 1, or 16-bit timer 4. The output on channel 1 (PG1) is updated in synchronization with the 8-bit timer 0, the 8-bit timer 1, or the 16-bit timer 5.

The PG ports are controlled by the control register (PG01CR) and can select either stepping motor control mode or pattern generation mode. Each bit of P6 can be used for a PG port.

PG0 and PG1 can be used independently.

Since the two PG channels operate in the same manner, except for the following points, only the operation of PG0 will be explained below.





Figure 3.10.1 PG Block Diagram



Figure 3.10.2 Pattern Generation Control Register (PG01CR) (1/2)



Figure 3.10.3 Pattern Generation Control Register (PG01CR) (2/2)

|                  |             | 7           | 6              | 5             | 4            | 3                                      | 2    | 1    | 0    |  |
|------------------|-------------|-------------|----------------|---------------|--------------|----------------------------------------|------|------|------|--|
| PG0REG           | Bit symbol  | PG03        | PG02           | PG01          | PG00         | SA03                                   | SA02 | SA01 | SA00 |  |
| (004CH)          | Read/Write  |             | V              | V             |              | R/W                                    |      |      |      |  |
|                  | After reset | 0           | 0              | 0             | 0            | Undefined                              |      |      |      |  |
| Prohibit         | Function    | Pattern ger | neration 0 (Po | G0) output la | tch register | Shift alternate register 0             |      |      |      |  |
| read-            |             | ( PG        | 0 can be rea   | d by reading  | the \        | for the PG mode (4-bit write) register |      |      |      |  |
| modify-<br>write |             | port        | (P6) that is   | assigned to F | PG ∫         |                                        |      |      |      |  |

Figure 3.10.4 Pattern generation 0 register (PG0REG)

|                                                                                                                                 |                    | 7     | 6            | 5             | 4    | 3         | 2    | 1    | 0    |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------|--------------------|-------|--------------|---------------|------|-----------|------|------|------|--|--|--|
| PG1REG                                                                                                                          | Bit symbol         | PG13  | PG12         | PG11          | PG10 | SA13      | SA12 | SA11 | SA10 |  |  |  |
| (004DH)                                                                                                                         | O4DH) Read/Write W |       |              |               |      |           |      | R/W  |      |  |  |  |
|                                                                                                                                 | After reset        | 0     | 0            | 0             | 0    | Undefined |      |      |      |  |  |  |
| Prohibit read-modify-  Pattern generation 1 (PG1) output latch register Shift alternate register 1 for the PG mode (4-bit write |                    |       |              |               |      |           |      |      | r    |  |  |  |
| write                                                                                                                           |                    | √port | (P6) that is | assigned to I | PG / |           |      |      |      |  |  |  |

Figure 3.10.5 Pattern Generation 1 Register (PG1REG)



Note 1: When the 7-stage binary counter is not used as a warm-up timer, a stable clock must be input from an external circuit.

Note 2: T45CR<bit6:4> are always 1.

Figure 3.10.6 16-Bit Timer Trigger Control Register (T45CR)



Figure 3.10.7 Connection between Timer and Pattern Generator

# (1) Pattern generation mode

When PG01CR<PAT0> = "1", PG functions as a pattern generator. In this mode data is written from the CPU to the shift alternate register only. The pattern data is then written from the shift alternate register to the pattern generator register synchronized to the shift trigger interrupt from the timer.

In this mode, PG01CR<PG0M> should be set to "1", PG01CR<CCW0> to "0", and PG01CR<PG0TE> to "1".

The output from the pattern generator goes to port 6; since port or functions can be switched by the bit settings in the port function control register, P6FC, any port pin can be assigned to pattern generator output.

Figure 3.10.8 shows the block diagram for this mode.



**Example of Pattern Generation Mode** 



Figure 3.10.8 Pattern Generation Mode Block Diagram (PG0)

In pattern generation mode, only writing to the output latch can be disabled by hardware. All other functions behave in the same way as 1 to 2 step excitation in stepping motor control port mode. Hence, data shifted on the trigger signal from a timer must be written before the next trigger signal is output.

# (2) Stepping motor control mode

# 1. 4-phase 1-step/2-step excitation

Figure 3.10.9 and Figure 3.10.10 show the output waveforms for 4-phase 1 excitation and 4-phase 2 excitation respectively when channel 0 (PG0) is selected.

#### a. Normal rotation



Note: bn indicates the initial value of PG0REG  $\leftarrow$  b7 b6 b5 b4××××

#### b. Reverse rotation



Figure 3.10.9 Output Waveforms for 4-Phase 1-Step Excitation (Normal rotation and reverse rotation)



Figure 3.10.10 Output Waveforms for 4-phase 2-step Excitation (Normal rotation)

The output from PG0 (P6) is latched on the rising edge of the trigger signal from the timer.

The direction of shift is specified by the setting of PG01CR<CCW0>: Normal rotation (PG00→PG01→PG02→PG03) is selected when <CCW0> is set to "0"; reverse rotation (PG00←PG01←PG02←PG03) is selected when <CCW0> is set to "1". 4-phase 1-step excitation will be selected when only one bit is set to "1" during the initialization of PG, while 4-phase 2-step excitation will be selected when two consecutive bits are set to "1".

The value in the shift alternate registers are ignored when 4-phase 1-step/2-step excitation mode is selected.

Figure 3.10.11 shows the block diagram.



Figure 3.10.11 Block Diagram for 4-phase 1-step Excitation/2-step Excitation (Normal rotation)

# 2. 4-phase 1 to 2 step excitation

Figure 3.10.12 shows the output waveforms for 4-phase 1-2 step excitation when channel 0 is selected.

## a. Normal rotation



Note: bn denotes the initial value PG0REG  $\leftarrow$  b7 b6 b5 b4 b3 b2 b1 b0

### b. Reverse rotation



Figure 3.10.12 Output Waveforms for 4-phase 1- to 2-step Excitation (Normal rotation and reverse rotation)

The initialization sequence for 4-phase 1-2 step excitation is as follows.

By rearranging the initial value b7 b6 b5 b4 b3 b2 b1 b0 to b7 b3 b6 b2 b5 b1 b4 b0, three consecutive bits are set to 1 and the other bits are set to 0 (Positive logic).

For example, if b7, b3, and b6 are set to 1, the initial value becomes 11001000, producing the output waveforms shown in Figure 3.10.12.

To generate a negative logic output waveform, the 1's and 0's in the initial value must be inverted. For example, to change the output waveform shown in Figure 3.10.12 negative logic, change the initial value to 00110111.

The operation will be explained below for channel 0.

The output from PG0 (P6) and from the shift alternate register (SA0) for pattern generation is latched on the rising edge of the trigger signal from the timer. The shift direction is set by PG01CR<CCW0>.

Figure 3.10.13 shows the block diagram.



Figure 3.10.13 Block Diagram for 4-phase 1- to 2-step Excitation (Normal rotation)

Setting example: To drive channel 0 (PG0) using 4-phase 1-2 step excitation (Normal rotation) when timer 0 is selected, set each register as follows.

|        | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                                                           |
|--------|-----|---|---|---|---|---|---|---|---------------------------------------------------------------------------|
| TRUN   | ← - | Χ | _ | _ | _ | _ | _ | 0 | Stop timer 0, and clear it to zero.                                       |
| TMOD   | ← 0 | 0 | Χ | Χ | - | - | 0 | 1 | Set 8-bit timer mode and select $\phi T1$ as the input clock for timer 0. |
| TFFCR  | ← X | Χ | Χ | 0 | 1 | 0 | 1 | 0 | Clear TFF1 to zero and enable the inversion trigger using timer 0.        |
| TREG0  | ← * | * | * | * | * | * | * | * | Set the cycle in the timer register.                                      |
| P6CR   | ← - | _ | _ | _ | 1 | 1 | 1 | 1 | Set bits P60 to P63 to output mode.                                       |
| P6FC   | ← - | - | _ | _ | 1 | 1 | 1 | 1 | Set bits P60 to P63 to PG output.                                         |
| PG01CR | ← - | - | - | - | 0 | 0 | 1 | 1 | Select PG0 4-phase 1 to 2 step excitation mode and normal rotation.       |
| PG0REG | ← 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | Set an initial value.                                                     |
| TRUN   | ← 1 | Χ | _ | _ | _ | - | _ | 1 | Start timer 0.                                                            |

X: Don't care, -: No change

# (3) Trigger signal from timer

The trigger signal from the timer used by PG is not the same as the trigger signal for the timer flip-flop (TFF1, TFF4, TFF5, and TFF6); they differ as shown in Table 3.10.1 depending on the operation mode of the timer.

Table 3.10.1 Trigger Signal Selection

|                   | TFF1 Inversion                                                                                                                  | PG Shift                                                                                                                        |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 8-bit timer mode  | Selected by TFFCR <tff1is> when the up counter value matches TREG0 or TREG1 value</tff1is>                                      | Selected by TFFCR <tff1is> when the up counter value matches TREG0 or TREG1 value</tff1is>                                      |
| 16-bit timer mode | When the up counter value matches both TREG0 and TREG1 values (the value of up counter = TREG1 $\times$ 2 <sup>8</sup> + TREG0) | When the up counter value matches both TREG0 and TREG1 values (the value of up counter = TREG1 $\times$ 2 <sup>8</sup> + TREG0) |
| PPG output mode   | When the up counter value matches both TREG0 and TREG1                                                                          | When the up counter value matches TREG1 value (PPG cycle)                                                                       |
| PWM output mode   | When the up counter value matches TREG0 value and PWM cycle                                                                     | Trigger signal for PG is not generated                                                                                          |

Note: To shift PG, TFFCR<TFF1IE> must be set to 1 to enable TFF1 inversion.

Channel 1 of PG can be synchronized with the 16-bit timer timer 4/timer 5. In this case, the PG shift trigger signal from the 16-bit timer is output only when the up counter UC4/UC5 value matches TREG5/TREG7.

When using a trigger signal from timer 4, set either T4FFCR<EQ5T4> or T4MOD<EQ5T5> to "1"; a trigger is generated when the value in UC4 and the value in TREG5 match. When using a trigger signal from timer 5, set T5FFCR<EQ7T6> to "1"; a trigger is generated when the value in UC5 and the value in TREG7 match.

# (4) Application of PG and timer output

As explained in the previous section trigger signal from timer, the timings for shifting PG and inverting TFF differ depending on the timer mode. An application which operates PG while operating an 8-bit timer in PPG mode is explained below.

To drive a stepping motor, a synchronizing signal is required for the excitation timing, in addition to the value of each phase (PG output). In this application, port 6 is used as a stepping motor control port to output a synchronizing signal to the TO1 pin (shared with P71).



Figure 3.10.14 Output Waveforms for 4-Phase 1-step Excitation

### Setting example:

|        | 7                      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                                       |
|--------|------------------------|---|---|---|---|---|---|---|-------------------------------------------------------|
| TRUN   | ← -                    | Χ | _ | _ | _ | _ | 0 | 0 | Stop timer 0, and clear it to zero.                   |
| TMOD   | ← 1                    | 0 | Χ | Χ | Χ | Χ | 0 | 1 | Set timer 0 and timer 1 to PPG output mode and select |
|        |                        |   |   |   |   |   |   |   | φT1 as the input clock.                               |
| TFFCR  | $\leftarrow X$         | Χ | Χ | 0 | 0 | 1 | 1 | Χ | Enable TFF1 inversion and set TFF1 to "1".            |
| TREG0  | $\leftarrow \ ^{\ast}$ | * | * | * | * | * | * | * | Set the duty of TO1 to TREG0.                         |
| TREG1  | ← *                    | * | * | * | * | * | * | * | Set the cycle of TO1 to TREG1.                        |
| P7CR   | $\leftarrow X$         | Χ | Χ | Χ | _ | _ | 1 | _ | l                                                     |
| P7FC   | $\leftarrow X$         | Χ | Χ | Χ | _ | _ | 1 | Χ | Assign P71 as TO1.                                    |
| P6CR   | ← -                    | _ | - | - | 1 | 1 | 1 | 1 | Assign P60 to P63 as PG0.                             |
| P6FC   | ← -                    | _ | _ | _ | 1 | 1 | 1 | 1 | J 71331911 1 00 10 1 00 03 1 00.                      |
| PG01CR | ← -                    | _ | _ | _ | 0 | 0 | 0 | 1 | Set PG0 to 4-phase 1-step excitation mode.            |
| PG0REG | $\leftarrow \ ^{\ast}$ | * | * | * | * | * | * | * | Set an initial value.                                 |
| TRUN   | ← 1                    | Χ | _ | _ | _ | _ | 1 | 1 | Start timer 0 and timer 1.                            |
|        |                        |   |   |   |   |   |   |   |                                                       |

X: Don't care, -: No change

# 3.11 Serial Channel

The TMP93CS40/TMP93CS41 includes two serial I/O channels. Channel 0 and channel 1 select UART mode (Asynchronous transmission) or I/O interface mode (Synchronous transmission).

The serial channel has the following operation modes:



In mode 1 and mode 2, a parity bit can be added. Mode 3 has a wake-up function for making the master controller start slave controllers in a serial link (multi-controller) system.

Figure 3.11.1 shows the data format for each mode.

Serial channels 0 and 1 can be used independently.

All channels operate in the same manner except for the following points. Hence only the operation of channel 0 is explained below.

### Differences between channel 0 and 1

|                    | Channel 0                                   | Channel 1                             |
|--------------------|---------------------------------------------|---------------------------------------|
| Pin name           | TXD0 (P90), RXD0 (P91)<br>CTS0 /SCLK0 (P92) | TXD1 (P93), RXD1 (P94)<br>SCLK1 (P95) |
| Handshake function | Yes                                         | No<br>(No CTS pin)                    |

Note: Using the handshake function allows transmission in the units of one data format. Thus overrun error is prevented. See the section entitled handshake function for details.



Figure 3.11.1 Data Formats

The serial channel has buffer registers for temporarily storing transmitted or received data during transmitting and receiving operations. This is so that transmitting and receiving operations can be performed independently (Full duplex).

However, in I/O interface mode, the SCLK (Serial clock) pin is used for both transmitting and receiving and the channel becomes half duplex.

The receiving data register is a double buffer structure that prevents the occurrence of overrun errors and provides a margin of one frame before the CPU reads the received data. The receiving data register stores the previously received data while the buffer register receives the next frame.

By using  $\overline{\text{CTS}}$  and  $\overline{\text{RTS}}$  (There is no  $\overline{\text{RTS}}$  pin, so any single port must be controlled by software), it is possible to halt data transmission until the CPU finishes reading received data wherever a frame is received (The handshake function).

In UART mode, an additional check function ensures that erroneous state bits caused by noise do not cause receiving operations to start. The channel starts receiving data only when the start bit is detected properly at least twice out of three samplings of the start bit.

When the transmission buffer becomes empty and requests the CPU to send the next transmission data, or when data is stored in the receiving data register and the CPU is requested to read the data, an INTTX (Transmit interrupt) or INTRX (Receive interrupt) interrupt occurs. If an overrun error, parity error or framing error occurs during a receiving operation, the flag SCOCR<OERR, PERR, FERR> is set.

The serial channel 0/1 has a special baud rate generator, which can set any baud rate by dividing the frequency of the four clocks ( $\phi$ T0,  $\phi$ T2,  $\phi$ T8, and  $\phi$ T32) from the 9-bit prescaler (shared by the 8-bit/16-bit timers) by a value from 2 to 16.

In I/O interface mode, it is possible to input synchronous signals, as well as transmit or receive data using an external clock.

# 3.11.1 Control Registers

The serial channels are controlled by three control registers: SCOCR, SCOMOD and BROCR. Transmitted and received data are stored in the register SCOBUF.



Note: SC1MOD (56H) is on channel 1.

Figure 3.11.2 Serial Mode Control Register (Channel 0, SC0MOD)



Note 1: Serial control register for channel 1 is SC1CR (55H).

Note 2: As all error flags are cleared after reading, do not test a single bit only with a bit-testing instruction.

Figure 3.11.3 Serial Control Register (Channel 0, SC0CR)



Note 1: Serial control register for channel 1 is BR1CR (57H).

Note 2: Set TRUN<PRRUN> to 1 when the baud rate generator is used.

Note 3: BR0CR<bit6> is always 1.

Note 4: Don't read from or write to BR0CR register during sending or receiving.

Figure 3.11.4 Serial Channel Control (Channel 0, BR0CR)



Note: Read-modify-write is prohibited for SC0BUF.

Figure 3.11.5 Serial Transmission/Receiving Buffer Registers (Channel 0, SC0BUF)



Figure 3.11.6 Serial Mode Control Register (Channel 1, SC1MOD)



Note: As all error flags are cleared after reading, do not test a single bit only with a bit-testing instruction.

Figure 3.11.7 Serial Control Register (Channel 1, SC1CR)



Note 1: To use baud rate generator, set TRUN<PRRUN> to "1", putting the prescaler in RUN.

Note 2: BR1CR<bit6> is always "1".

Note 3: Don't read from or write to BR1CR register during sending or receiving.

Figure 3.11.8 Baud Rate Generator Control Register (Channel 1, BR1CR)



Note: Read-modify-write is prohibited for SC1BUF.

Figure 3.11.9 Serial Transmission/Receiving Buffer Registers (Channel 1, SC1BUF)



Figure 3.11.10 Port 9 Function Register (P9FC)



Note: ODE<br/>bit7:2> is always "1".

Figure 3.11.11 Port 9 Open-drain Enable Register (ODE)

# 3.11.2 Configuration

Figure 3.11.12 shows the block diagram for serial channel 0.



Note: SLCK0 pin can only be used for I/O in I/O interface mode.

Figure 3.11.12 Block Diagram of Serial Channel 0

Serial clock generation circuit BR1CR<BR1CK1:0> TO0TRG (Timer 0 comparator output) **UART** Selector φΤ0 SIOCLK Selector φΤ2 Prescaler φΤ8 φT32 Baud rate SC1MOD generator System <SC1:0> SC1MOD clock/f<sub>SYS</sub> (\phi1) <SM1:0> Selector I/O interface SCLK1 mode input (Shared by P95) SC1CR <IOC> SCLK1 output INTRX1 INTTX1 (Shared Serial channel Transmission by P95) SC1MOD Receive counter interrupt counter <WU> (UART only ÷ 16) (UART only ÷ 16) control RXDCLK TXDCLK \ SC1MOD Transmission Receive <RXE> control control SC1CR <EV,EN> Parity control RXD1 □ Receive buffer 1 (Shift register) (Shared by P94) Transmission buffer → TXD1 RB8 Receive buffer 2 (SC1BUF) Error flag TB8 (SC1BUF) (Shared by P93) SC1CR <OERR> <PERR> <FERR> Internal data bus

Figure 3.11.13 shows the block diagram for serial channel 1.

Note: SLCK1 pin can only be used for I/O in I/O interface mode.

Figure 3.11.13 Block Diagram for Serial Channel 1

### 1. Prescaler

9-bit prescaler and prescaler clock selection registers generate input clocks for 8-bit timer 0, 1, 16-bit timer 4, 5, and serial interface 0, 1.

Figure 3.11.15 shows the block diagram. Table 3.11.1 shows how the prescaler clock is resolved into the baud rate generator.



Figure 3.11.14 Block Diagram of Prescaler

Select System Prescaler Output Clock Resolution Select Prescaler Clock Gear Value Clock <PRCK1:0> <GEAR2:0> <SYSCK> φΤ0 φT2 φΤ8 φT32 1 (fs) XXX $fs/2^2$ fs/24 fs/26 fs/28 fc/2<sup>2</sup> fc/24 fc/2<sup>6</sup> fc/2<sup>8</sup> 000 (fc) 00 fc/2<sup>5</sup> fc/27 fc/29 001 (fc/2) fc/23 0 (fc) fc/2<sup>10</sup> (f<sub>FPH</sub>) fc/28 010 (fc/4) fc/24 fc/26 fc/2<sup>11</sup> 011 (fc/8) fc/2<sup>5</sup> fc/27 fc/29 fc/2<sup>10</sup> fc/212

100 (fc/16)

XXX

XXX

fc/26

fc/28

fs/24

 $fc/2^8$ 

fs/2<sup>6</sup>

fc/2<sup>10</sup>

fs/28

fc/212

Table 3.11.1 Prescaler Clock Resolution for Baud Rate Generator

XXX: Don't care, -: Invalid

XXX

XXX

01

(Low-frequency clock) 10

(fc/16 clock)

Note: The fc/16 clock cannot be used as a prescaler clock when the fs clock is used as a system clock.

The selected clock (f<sub>FPH</sub> clock, fc/16 clock or fs clock) is divided by 4 and input to the prescaler. This selection is made by the prescaler clock selection register SYSCR0<PRCK1:0>.

Resetting sets <PRCK1:0> to "00" and selects the fFPH clock input divided by 4.

The baud rate generator selects between 4 clock inputs: The prescaler outputs  $\phi T0$ ,  $\phi T2$ ,  $\phi T8$ , and  $\phi T32$ .

The prescaler can be run or stopped by the timer operation control register TRUN<PRRUN>. Counting starts when <PRRUN> is set to "1". The prescaler is cleared to zero and stops operation when <PRRUN> is set to "0".

Resetting clears <PRRUN> to "0", clearing the prescaler and stopping operation.

When IDLE1 mode (in which only the oscillator operates) is used, set TRUN<PRRUN> to "0" to stop the prescaler before a HALT instruction is executed.

### 2. Baud rate generator

The baud rate generator is a circuit that generates transmission and receiving clocks to determine the transfer rate of the serial channel.

The input clock to the baud rate generator,  $\phi T0$ ,  $\phi T2$ ,  $\phi T8$ , or  $\phi T32$ , is generated by the 9-bit prescaler which is shared by the timers. One of these input clocks is selected by the baud rate generator control register BR0CR<BR0CK1:0>.

The baud rate generator includes a 4-bit frequency divider, which divides frequency by from 2 to 16 to determine the transfer rate.

The method for calculating a transfer rate when the baud rate generator is used is explained below.

#### UART mode

• I/O interface mode

For example, when the source clock (fc) is 12.288 MHz, the input clock is  $\phi$ T2 (fc/16), and the frequency divisor is 5, the transfer rate in UART mode is as follows:

System clock: High frequency (fc) Clock gear: 1 (fc)

Prescaler clock: f<sub>FPH</sub>

Baud rate = 
$$\frac{\text{fc/16}}{5}$$
 ÷16  
=  $12.288 \times 10^6 \div 16 \div 5 \div 16 = 9600 \text{ (bps)}$ 

Table 3.11.2 shows an example of the transfer rate in UART mode.

Also, using the 8-bit timer 0, the serial channel can generate a transfer rate. Table 3.11.3 shows examples of baud rate settings using timer 0.

|           |                   |        |        |       | Unit (kbps) |
|-----------|-------------------|--------|--------|-------|-------------|
| fc [MHz]  | Input clock       | фТ0    | фТ2    | фТ8   | фТ32        |
|           | Frequency divisor |        |        |       |             |
|           | 2                 | 76.800 | 19.200 | 4.800 | 1.200       |
| 0.920400  | 4                 | 38.400 | 9.600  | 2.400 | 0.600       |
| 9.830400  | 8                 | 19.200 | 4.800  | 1.200 | 0.300       |
|           | 0                 | 9.600  | 2.400  | 0.600 | 0.150       |
| 42 200000 | 5                 | 38.400 | 9.600  | 2.400 | 0.600       |
| 12.288000 | A                 | 19.200 | 4.800  | 1.200 | 0.300       |
|           | 3                 | 76.800 | 19.200 | 4.800 | 1.200       |
| 14.745600 | 6                 | 38.400 | 9.600  | 2.400 | 0.600       |
|           | С                 | 19.200 | 4.800  | 1.200 | 0.300       |

Table 3.11.2 Selection of Transfer Rate (1) (when baud rate generator is used)

Note 1: Transfer rates in I/O interface mode are 8 times faster than the values given in the above table.

Note 2: This table is calculated for when fc is selected as the system clock, the clock gear is set to fc, and the system clock is selected as the prescaler clock input.

Table 3.11.3 Selection of Transfer Rate (2) (when timer 0 (Input clock φT1) is used)

Unit (kbps) fc 12.288 MHz 12 MHz 9.8304 MHz 8 MHz 6.144 MHz TREG0 96 76.8 62.5 48 48 38.4 31.25 24 2H 31.25 3Н 32 16 4H 24 19.2 12 5H 19.2 9.6 8H 12 9.6 ΑH 9.6 4.8 4.8 10H 14H 4.8 2.4

How to calculate the transfer rate (when timer 0 is used):

Transfer rate = 
$$\frac{\text{Clock frequency selected by SYSCR0}}{\text{TREG0} \times 8 \times 16}$$
 (when timer 0 (Input clock  $\phi$ T1) is used)

Note 1: Timer 0 match detect signal cannot be used as the transfer clock in I/O interface mode.

Note 2: This table is calculated for when fc is selected as the system clock, the clock gear is set to fc, and f<sub>FPH</sub> is selected as the prescaler clock input.

#### 3. Serial clock generation circuit

This circuit generates the basic clock for transmitting and receiving data.

#### • I/O interface mode

In SCLK output mode with a setting of SCOCR<IOC> = "0", the basic clock is generated by dividing the output of the baud rate generator by 2, as described previously. In SCLK Input mode with setting of SCOCR<IOC> = "1", the rising edge or falling edge is detected, according to the setting of the SCOCR<SCLKS> register, and used to generate the basic clock.

#### • UART mode

The setting of SC0MOD<SC1:0> selects the baud rate generator clock, internal clock  $\phi 1$  (Max 625 kbps at fc = 20 MHz) or the match detect signal from timer 0 as the signal from which to generate the basic clock SIOCLK.

### 4. Receiving counter

The receiving counter is a 4-bit binary counter used in asynchronous communication (UART) mode and counts up with the SIOCLK clock. A duration of 16 pulses of SIOCLK are used for receiving 1 bit of data, and the data bit is sampled three times, at the 7th, 8th, and 9th clock ticks.

Using these three samples, the received data is evaluated using the majority rule.

For example, if the sampled data bits are respectively "1", "0" and "1" at the 7th, 8th, and 9th clock ticks, the received data is evaluated as "1". Sampled data "0", "0" and 1 is evaluated to be "0".

### 5. Receiving control

#### I/O interface mode

In SCLK0 output mode with a setting of SC0CR<IOC> = "0", the RXD0 signal will be sampled at the rising edge of the shift clock which is output to the SCLK0 pin.

In SCLK0 input mode with a setting of SC0CR<IOC> = "1", the RXD0 signal will be sampled at the rising edge or falling edge of the SCLK0 input, according to the setting of the SC0CR<SCLKS> register.

#### • Asynchronous communication (UART) mode

The receiving control block has a circuit for detecting the start bit using the majority rule. When two or more 0's are detected out of 3 samples, it is recognized as a start bit and the receiving operation is started.

The data being received is also evaluated using the majority rule.

### 6. Receiving buffer

To prevent overrun errors, the receiving buffer has a double buffer structure.

Received data is stored bit by bit in receiving buffer 1 (Shift register type). When 7 bits or 8 bits of data are stored in receiving buffer 1, the stored data is transferred to receiving buffer 2 (SC0BUF), generating an interrupt INTRX0. The CPU reads only receiving buffer 2 (SC0BUF). Even before the CPU has read receiving buffer 2 (SC0BUF), more received data can be stored in receiving buffer 1. However, unless receiving buffer 2 (SC0BUF) is read before all the bits of the next data are received by receiving buffer 1, an overrun error occurs. If an overrun error occurs, the contents of receiving buffer 1 will be lost, although the contents of receiving buffer 2 and SC0CR<RB8> are still preserved.

The parity bit added in 8-bit UART mode and the most significant bit (MSB) in 9-bit UART mode are stored in SCOCR<RB8>.

In 9-bit UART mode, the wakeup function for the slave controller is enabled by setting SC0MOD<WU> to "1"; and interrupt INTRX0 occurs only when SC0CR<RB8> is set to 1.

### 7. Transmission counter

The transmission counter is a 4-bit binary counter which is used in Asynchronous communication (UART) mode and, like a receiving counter, counts using the SIOCLK clock. This generates a TXDCLK pulse every 16 clock pulses.



Figure 3.11.15 Generation of Transmission Clock

### 8. Transmission controller

# • I/O interface mode

In SCLKO output mode with a setting of SCOCR<IOC>=0, the data in the transmission buffer is output bit by bit to the TXDO pin at the rising edge of the shift clock which is output from the SCLKO pin.

In SCLK0 Input mode with a setting of SC0CR<IOC>= 1, the data in the transmission buffer is output bit by bit to the TXD0 pin at the rising edge or falling edge of the SCLK0 input, according to the setting of the SC0CR<SCLKS> register.

### • Asynchronous communication (UART) mode

When transmission data is written to the transmission buffer from the CPU, transmission starts at the rising edge of the next TXDCLK pulse.

### Handshake function

Serial channel 0 has a  $\overline{\text{CTS0}}$  pin. Using this pin, data can be sent in units of one frame; thus, overrun errors can be avoided. The handshake function is enabled/disabled by SC0MOD<CTSE>.

When the  $\overline{\text{CTS0}}$  pin goes high, after completion of the current data transmission, data transmission is halted until the  $\overline{\text{CTS0}}$  pin goes low again. When the INTTX0 interrupt is generated, it requests the next data transmission to the CPU.

Although there is no  $\overline{RTS}$  pin, a handshake function can easily be configured by assigning any port to the  $\overline{RTS}$  function. The  $\overline{RTS}$  output should be high to request a halt to data transmission after data receive is completed by software in the RXD interrupt routine.



Figure 3.11.16 Handshake Function



Note 1: If the  $\overline{\text{CTS}}$  signal rises during transmission, the next datum is not sent after completion of the current transmission.

Note 2: Transmission starts at the first falling edge of the TXDCLK clock after the  $\overline{\text{CTS}}$  signal falls.

Figure 3.11.17 Timing of CTS (Clear to send)

### 9. Transmission buffer

The transmission buffer (SC0BUF) shifts out and sends the transmission data written from the CPU in order starting with the least significant bit (LSB). When all bits have been shifted out, the transmission buffer becomes empty and generates an INTTX0 interrupt.

### 10. Parity control circuit

When the serial channel control register SCOCR<PE> is set to 1, it is possible to transmit and receive data with parity. However, parity can be added only in 7-bit UART or 8-bit UART modes. The SCOCR<EVEN> register can select even or odd parity.

During transmission, parity is automatically generated according to the data written to the transmission buffer SC0BUF. The data are transmitted after the parity bit is stored in SC0BUF<TB7> in 7-bit UART mode, or in SC0MOD<TB8> in 8-bit UART mode. <PE> and <EVEN> must be set before the transmission data is written to the transmission buffer.

During receiving, data are shifted to the receiving buffer 1 and the parity is automatically set after the data are transferred to the receiving buffer 2 (SC0BUF). The parity bit is then compared with SC0BUF<RB7> in 7-bit UART mode, or with SC0MOD<RB8> in 8-bit UART mode. If the bits do not match, a parity error occurs and the SC0CR<PERR> flag is set.

### 11. Error flag

Three error flags are provided to increase the reliability of data reception.

#### 1) Overrun error <OERR>

If all bits of the next datum are received in receiving buffer 1 while valid data is stored in receiving buffer 2 (SC0BUF), an overrun error occurs.

### 2) Parity error <PERR>

The parity generated for the data shifted into receiving buffer 2 (SC0BUF) is compared with the parity bit received from the RXD pin. If they are not equal, a parity error occurs.

#### 3) Framing error <FERR>

The stop bit of the received data is sampled three times in the center of the pulse. If the majority of the sampled values are "0", a framing error occurs.

# 12. Signal generating timing

# 1) In UART mode

#### Receive

| Mode                               | 9 Bits                    | 8 Bits + Parity             | 8 Bits, 7 Bits + Parity, 7 Bits |
|------------------------------------|---------------------------|-----------------------------|---------------------------------|
| Timing for interrupt generation    | Around center of bit8     | Around center of parity bit | Around center of stop bit       |
| Timing for framing generation      | Around center of stop bit | Around center of stop bit   | Around center of stop bit       |
| Timing for parity error generation | -                         | Around center of parity bit | <b>←</b>                        |
| Timing for overrun error timing    | Around center of bit8     | Around center of parity bit | Around center of stop bit       |

Note: In 9-Bit and 8-Bit + Parity mode, interrupts coincide with the ninth bit pulse. Thus, when servicing the interrupt, it is necessary to wait for a 1-bit period (to allow the stop bit to be transferred) to allow checking for a framing error.

# Send

| Mode                            | 9 Bits                           | 8 Bits + Parity | 8 Bits, 7 Bits + Parity, 7 Bits |
|---------------------------------|----------------------------------|-----------------|---------------------------------|
| Timing for interrupt generation | Immediately before stop bit sent | <b>+</b>        | <b>←</b>                        |

# 2) In I/O interface mode

| Timing for send interrupt generation    | SCLK0 output mode | mmediately after rise of last SCLK0 signal (See Figure 3.9.20)                                                      |  |  |  |  |  |
|-----------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                         | SCLK0 input mode  | Immediately after rise (Rising mode) or fall (Falling mode) of last SCLK0 signal (See Figure 3.9.21)                |  |  |  |  |  |
| Timing for receive interrupt generation | SCLK0 output mode | Immediately after final SCLK0 (when received data are transferred to receive buffer 2 (SC0BUF)) (See Figure 3.9.22) |  |  |  |  |  |
|                                         | SCLK0 input mode  | Immediately after final SCLK0 (when received data are transferred to receive buffer 2 (SC0BUF)) (See Figure 3.9.2   |  |  |  |  |  |

# 3.11.3 Operational Description

### (1) Mode 0 (I/O interface mode)

This mode is used to increase the number of I/O pins available for transmitting data to or receiving data from an external shift register.

This mode encompasses the SCLK output mode for outputting a synchronous clock SCLK and the SCLK input mode for inputting an external synchronous clock SCLK.



Figure 3.11.18 Example of SCLK Output Mode Connection



Figure 3.11.19 Example of SCLK Input Mode Connection

#### 1. Transmission

In SCLK output mode, 8-bit data and the synchronous clock are output from the TXD0 pin and SCLK0 pin respectively, each time the CPU writes data to the transmission buffer. When all data has been output, INTESO<ITX0C> will be set, generating the INTTX0 interrupt.



Figure 3.11.20 Transmitting Operation in I/O Interface Mode (SCLK output mode) (Channel 0)

In SCLK input mode, 8-bit data are output from the TXD0 pin when SCLK0 input becomes active after data are written to the transmission buffer by the CPU.

When all data have been output, INTESO<ITX0C> will be set, generating the INTTX0 interrupt.



Figure 3.11.21 Transmitting Operation in I/O Interface Mode (SCLK input mode) (Channel 0)

### 2. Receiving

In SCLK output mode, the synchronous clock is output from the SCLK0 pin and data are shifted into the receiving buffer 1 whenever the receive interrupt flag INTES0<IRX0C> is cleared by a read of the received data. When 8-bit data is received, the data will be transferred to receiving buffer 2 (SC0BUF) according to the timing shown below and INTES0<IRX0C> will be set again, generating an INTRX0 interrupt.



Figure 3.11.22 Receiving Operation in I/O Interface Mode (SCLK0 output mode) (Channel 0)

In SCLK input mode, the data are shifted to receiving buffer 1 when the SCLK input becomes active after the receive interrupt flag INTESO<IRX0C> is cleared by a read of the received data. When 8-bit data are received, the data will be shifted to receiving buffer 2 (SC0BUF) according to the timing shown below and INTESO<IRX0C> will be set again, generating the INTRX0 interrupt.



Figure 3.11.23 Receiving Operation in I/O Interface Mode (SCLK input mode) (Channel 0)

Note: When receiving data, the system must be put in receive enable state (SCOMOD < RXE > = 1).

#### (2) Mode 1 (7-bit UART mode)

7-bit mode can be selected by setting the serial channel mode register SC0MOD<SM1:0> to 01.

In this mode, a parity bit can be added. The parity bit is enabled or disabled by serial channel control register SCOCR<PE>. Even parity or odd parity is selected using SCOCR<EVEN> when <PE> is set to 1 (Enable).

Setting example: When transmitting data with the following format, the control registers should be set as described below. Channel 0 is explained here.



INTES0  $\leftarrow$  1 1 0 0 - - - Enable INTTX0 interrupt and set interrupt level 4. SC0BUF  $\leftarrow$  \* \* \* \* \* \* \* \* \* Set data for transmission.

X: Don't care, -: No change

#### (3) Mode 2 (8-bit UART mode)

8-bit UART mode can be selected by setting SC0MOD<SM1:0> to 10. In this mode, a parity bit can be added. The parity bit is enabled or disabled by SC0CR<PE>. Even parity or odd parity is selected by using SC0CR<EVEN> when <PE> is set to 10 (Enable).

Setting example: When receiving data with the following format, the control registers should be set as described below.



Direction of transmission (Transmission rate: 9600 bps at fc = 12.288 MHz)

Clock configuration

System clock: High frequency (fc)

Clock gear: 1 (fc)

Prescaler clock: System clock

### Main setting

|        | 7              | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                                    |
|--------|----------------|---|---|---|---|---|---|---|----------------------------------------------------|
| P9CR   | $\leftarrow X$ | Χ | _ | _ | _ | _ | 0 | _ | Select P91 (RXD0) as the input pin.                |
| SC0MOD | ← -            | 0 | 1 | Χ | 1 | 0 | 0 | 1 | Enable receiving in 8-bit UART mode.               |
| SC0CR  | $\leftarrow X$ | 0 | 1 | Χ | Χ | Χ | 0 | 0 | Set odd parity.                                    |
| BR0CR  | ← 0            | Χ | 0 | 1 | 0 | 1 | 0 | 1 | Set transfer rate at 9600 bps.                     |
| TRUN   | ← 1            | Χ | _ | _ | _ | - | _ | _ | Start the prescaler for the baud rate generator.   |
| INTES0 | ← -            | _ | _ | _ | 1 | 1 | 0 | 0 | Enable INTTX0 interrupt and set interrupt level 4. |

# Interrupt processing

X: Don't care, -: No change

# (4) Mode 3 (9-bit UART mode)

9-bit UART mode can be selected by setting SC0MOD<SM1:0> to 11. In this mode, a parity bit cannot be set.

During transmission, the MSB (9th bit) is written to the serial channel mode register <TB8>. During receiving it is stored in the serial channel control register <RB8>. When the buffer is written or read, the MSB is read or written first, then the rest of the data is read from or written to SC0BUF.

# Wakeup function

In 9-bit UART mode, the wakeup function for slave controllers is enabled by setting SC0MOD<WU> to 1. The interrupt INTRX0 occurs only when<RB8> = 1.



Note: The TXD pins of the slave controllers must be in open-drain output mode.

Figure 3.11.24 Serial Link Using Wakeup Function

# Protocol

- 1. Select 9-bit UART mode for the master and slave controllers.
- 2. Set the SCOMOD<WU> bit of each slave controller to 1 to enable data receiving.
- 3. The master controller transmits one-frame data including the 8-bit select code for the slave controllers. The MSB (bit8)<TB8> is set to "1".



- 4. Each slave controller receives the above frame and clears its WU bit to "0" if the above select code matches its own select code.
- 5. The master controller transmits data to the specified slave controller (the one whose SC0MOD<WU> bit is cleared to "0"). The MSB (bit8)<TB8> is cleared to "0".



- 6. The other slave controllers (those with their <WU> bits remaining at 1) ignore the receiving data because their MSBs (bit8 or <RB8>) are set to "0" to disable the INTRX0 interrupt.
  - Slave controllers (with WU = 0) can transmit data to the master controller. In this way they can indicate the end of data reception to the master controller.

Setting example: To link two slave controllers serially with the master controller, and use the internal clock  $\phi 1$  as the transfer clock.



Since serial channels 0 and 1 operate in exactly the same way, channel 0 only is used for the purposes of this explanation.

• Setting the master controller

### Main

| P9CR   | , v        | V |   |   |   |   | 0 | 4 | ٦ |                                                            |
|--------|------------|---|---|---|---|---|---|---|---|------------------------------------------------------------|
| PSCK   | ← ∧        | ^ | _ | _ | _ | _ | U |   | Ļ | Select P90 as TXD0 pin and P91 as RXD0 pin.                |
| P9FC   | ← X<br>← X | Χ | _ | Χ | _ | Χ | Χ | 1 | J | Colcott 30 do 1700 pin dia 1 31 do 1700 pin.               |
| INTES0 | ← 1        | 1 | 0 | 0 | 1 | 1 | 0 | 1 |   | Enable INTTX0 and set interrupt level 4.                   |
|        |            |   |   |   |   |   |   |   |   | Enable INTRX0 and set interrupt level 5.                   |
| SC0MOD | ← 1        | 0 | 1 | 0 | 1 | 1 | 1 | 0 |   | Set $\phi 1$ as the transmission clock in 9-bit UART mode. |
| SC0BUF | ← 0        | 0 | 0 | 0 | 0 | 0 | 0 | 1 |   | Set the select code for slave controller 1.                |

# INTTX0 interrupt

| SC0MOD | ← 0 | _ | _ | _ | _ | _ | _ | _ | Sets TB8 to 0.             |
|--------|-----|---|---|---|---|---|---|---|----------------------------|
| SC0BUF | ← * | * | * | * | * | * | * | * | Set data for transmission. |

• Setting the slave controller

### Main

# INTRX0 interrupt

# 3.12 Analog/Digital Converter

The TMP93CS40/S41 contains an analog/digital converter (AD converter) with 8-channel analog input that features 10-bit successive approximation.

Figure 3.12.1 shows the block diagram for the AD converter. 8-channel analog input pins (AN7 to AN0) are shared by the input only port P5 which can also be used as a general-purpose input port.



Figure 3.12.1 Block Diagram for AD Converter

- Note 1: This AD converter does not have a built-in sample and hold circuit.
- Note 2: When the power supply current is reduced in IDLE2, IDLE1 or STOP mode, stop operation of the AD converter before the HALT instruction is executed. And set ADMOD2<SPEED1:0> = "00".
- Note 3: The operation of the AD converter is guaranteed only when fc (The high-frequency oscillator) is used (It is not guaranteed when fs is used). It is guaranteed when  $f_{FPH} \ge 4$  MHz.



Figure 3.12.2 AD Control Register (1/2)



Note: Set the <VREFON> register to "1" before starting conversion (setting <ADS> to "1").

Figure 3.12.3 AD Control Register (2/2)

7 6 5 4 3 2 0 1 ADREG04L ADR01 ADR00 Bit symbol (0060H)Read/Write R After reset Undefined **Function** Lower 2 bits of AD result for AN0 or AN4 are stored 7 6 5 4 3 2 1 0 ADREG04H Bit symbol ADR09 ADR08 ADR07 ADR06 ADR05 ADR04 ADR03 ADR02 (0061H)Read/Write R After reset Undefined **Function** Upper 8 bits of AD result for AN0 or AN4 are stored. 7 2 6 5 4 3 1 0 ADR11 ADR10 ADREG15L Bit symbol (0062H) Read/Write R After reset Undefined Lower 2 bits of AD result for AN1 or AN5 are stored. **Function** 7 5 2 6 4 3 1 0 ADREG15H ADR19 ADR18 ADR17 ADR16 ADR15 ADR14 ADR13 ADR12 Bit symbol (0063H)Read/Write After reset Undefined Function Upper 8 bits of AD result for AN1 or AN5 are stored.

Note: The result registers are used both as AN0 and AN4, AN1 and AN5, AN2 and AN6, and AN3 and AN7. They are stored in ADREG04, 15, 26, and 37.



Figure 3.12.4 AD Conversion Result Register (ADREG04, ADREG15) (1/2)

7 6 5 4 3 2 0 1 ADREG26L ADR21 ADR20 Bit symbol (0064H)Read/Write R Afte<u>r reset</u> Undefined Lower 2 bits of AD result for AN2 or AN6 are stored **Function** 7 6 5 4 3 2 1 0 ADREG26H Bit symbol ADR29 ADR28 ADR27 ADR26 ADR25 ADR24 ADR23 ADR22 (0065H)Read/Write R After reset Undefined **Function** Upper 8 bits of AD result for AN2 or AN6 are stored. 7 3 2 6 5 4 1 0 ADREG37L ADR31 ADR30 Bit symbol (0066H) Read/Write R After reset Undefined Function Lower 2 bits of AD result for AN3 or AN7 are stored. 7 5 2 0 6 4 3 1 ADREG37H ADR38 ADR37 ADR39 ADR36 ADR35 ADR34 ADR33 ADR32 Bit symbol (0067H)Read/Write After reset Undefined Function Upper 8 bits of AD result for AN3 or AN7 are stored.



Figure 3.12.5 AD Conversion Result Register (ADREG26, ADREG37) (2/2)

### 3.12.1 Operation

#### (1) Analog reference voltage

The high analog reference voltage is applied to the VREFH pin, and the low analog reference voltage is applied to the VREFL pin.

The reference voltage between VREFH and VREFL is divided by 1024 (using string resistance) and compared with the analog input voltage for AD conversion.

The switch between VREFH and VREFL can be turned off by writing "0" to ADMOD2<VREFON>.

When  $\langle VRFFON \rangle =$  "0", before the conversion can start, must be written to  $\langle VREFON \rangle$  and a 3 µs period must be allowed so that the internal reference voltage can stabilize (regardless of fc) before "1" is written to ADMOD1 $\langle ADS \rangle$ .

### (2) Analog input channels

The analog input channel is selected by ADMOD2<ADCH2:0>. However, the channel which should be selected depends on the operation mode of the AD converter.

In fixed analog input mode, one channel is selected out of eight pins, AN0 to AN7, by <ADCH2:0>.

In analog input channel scan mode, the number of channels to be scanned is specified by ADMOD2<ADCH2:0>. For example, AN0 only, AN0  $\rightarrow$  AN1, AN0  $\rightarrow$  AN1  $\rightarrow$  AN2, AN0  $\rightarrow$  AN1  $\rightarrow$  AN2  $\rightarrow$  AN3, AN4 only, AN4  $\rightarrow$  AN5, AN4  $\rightarrow$  AN5  $\rightarrow$  AN6, or AN4  $\rightarrow$  AN5  $\rightarrow$  AN6  $\rightarrow$  AN7.

When reset the AD conversion channel register will be initialized to ADMOD2<ADCH2:0> = "000", so that the AN0 pin is selected.

The pins which are not used as analog input channels can be used as ordinary input port pins for port P5.

#### (3) Starting AD conversion

AD conversion starts when "1" is written to the AD conversion register ADMOD1<ADS>. When conversion starts, the conversion busy flag ADMOD1<ADBF>, which indicates that conversion is in progress, is set to "1".

### (4) AD conversion mode

Both fixed AD conversion channel mode and conversion channel scan mode include two conversion modes; single and repeat conversion mode.

In fixed channel repeat mode, conversion of the specified single channel is executed repeatedly.

In scan repeat mode, scanning is executed repeatedly.

The AD conversion mode is selected by ADMOD1<REPET, SCAN>.

### (5) AD conversion speed selection

There are four AD conversion speed modes. The selection is made by the ADMOD2<SPEED1:0> register.

When reset, <SPEED1:0> is initialized to "00", selecting 160-state conversion mode (16 µs at 20 MHz).

## (6) AD conversion end and interrupt

### • AD conversion single mode

When AD conversion of the specified channel has finished (in fixed channel conversion mode) or when AD conversion of the last channel has finished (in channel scan mode), ADMOD<EOCF> is set to "1", the ADMOD<ADBF> flag is reset to "0", and the INTAD interrupt is generated.

### AD conversion repeat mode

For both fixed conversion channel mode and conversion channel scan mode, INTAD should be disabled in repeat mode. Always set INTE0AD to "000", to disable the interrupt request.

Write 0 to ADMOD2<REPET> to terminate repeat mode. Repeat mode will be exited as soon as the conversion in progress is completed.

## (7) Storing the AD conversion result

The results of AD conversion are stored in the registers ADREG04, ADREG15, ADREG26, ADREG37 for each channel. The result registers are used as AN0 and AN4, AN1 and AN5, AN2 and AN6, and AN3 and AN7.

However, the contents of the registers do not indicate which channel's data has been converted.

In repeat mode, the registers are updated as soon as conversion ends.

ADREG04 to ADREG37 are read only registers.

### (8) Reading the AD conversion result

The results of AD conversion are stored in the registers ADREG04 to ADREG37.

When the lowest two bits of one of the registers ADREG04L, ADREG15L, ADREG26L, or ADREG37L are read, ADMOD1<EOCF> is cleared to "0".

<EOCF> is not cleared to "0" when the upper eight bits of one of the registers ADREG04H, ADREG15H, ADREG26H, or ADREG37H are read.

Setting example:

1. When the analog input voltage on the AN3 pin is AD converted at 160-state speed and the result is transferred to the memory address 0100H by the AD interrupt INTAD routine.

# Main setting

```
      INTE0AD
      ← 1
      1
      0
      0
      -
      -
      -
      Enable INTAD and set interrupt level 4.

      ADMOD2
      ← 1
      X
      0
      0
      X
      0
      1
      1
      Specify AN3 pin as an analog input channel and start AD conversion in 160-state speed mode.
```

### **INTAD** routine

```
WA ← ADREG37 Read ADREG37L and ADREG37H values and write to WA (16 bits).

WA → 6 Right-shift WA six times and write "0" in upper bits.

(000100H) ← WA Write contents of WA in memory at 0100H.
```

2. When the analog input voltage of the four pins AN4 to AN7 are AD converted at 320-state speed and the channel is set to scan and repeat mode.

# Main setting

X: Don't care, -: No change

# 3.13 Watchdog Timer (Runaway Detection Timer) and Warm-up Timer

The TMP93CS40/S41 contains a watchdog timer for runaway detection.

The watchdog timer (WDT) is used to return the CPU to a normal state when it detects that the CPU has started to malfunction (runaway) due to causes such as noise. When the watchdog timer detects a malfunction, it generates a non-maskable interrupt to notify the CPU of the malfunction, and outputs "0" from the watchdog timer out pin  $\overline{\text{WDTOUT}}$  to notify peripheral devices of the malfunction.

Connecting the watchdog timer output to the reset pin internally forces a reset.

The watchdog timer consists of 7-stage and 15-stage binary counters.

These binary counters are also used as a warm-up timer for internal oscillator stabilization. This is used for releasing stop and also before changing the system clock.

# 3.13.1 Configuration

Figure 3.13.1 shows the block diagram for the watchdog timer (WDT).



Figure 3.13.1 Block Diagram for Watchdog Timer/Warm-up Timer

The watchdog timer consists of 7-stage and 15-stage binary counters which use the system clock (fsys) as the input clock. The 15-stage binary counter has fsys/2<sup>15</sup>, fsys/2<sup>17</sup>, fsys/2<sup>19</sup> and fsys/2<sup>21</sup> outputs. Selecting one of the outputs with the WDMOD<WDTP1:0> register generates a watchdog interrupt and outputs watchdog timer out when an overflow occurs.

For the warm-up counter, either a  $2^7$  or a  $2^9$  output from the 15-stage binary counter can be selected using the WDMOD<WARM> register. When a stable-external oscillator is used, a shorter warm-up time is available using the T45CR<QCU> register. When <QCU> = "1", a counting value  $2^7$  is selected.

When the watchdog timer is in operation, this shorter warm-up time function cannot be selected. The warm-up counter function can be made available by setting QCU = 0.

Since the watchdog timer out pin (WDTOUT) outputs "0" when there is a watchdog timer overflow, the peripheral devices can be reset. The watchdog timer out pin is set to "1" after WDT has been disabled and the watchdog timer cleared (by a clear code 4EH being written into the WDCR register).

### Example:

LDW (WDMOD), B100H ; Disable

LD (WDCR), 4EH ; Write clear code SET 7, (WDMOD) ; Enable again

In other words, WDTOUT keeps outputting "0" until the clear code is written.

The watchdog timer out pin can also be connected to the reset pin internally. In this case, the watchdog timer out pin ( $\overline{WDTOUT}$ ) outputs "0" for 8 to 20 states (12.8 to 32  $\mu s$  at fc = 20 MHz), and then resets itself.



Figure 3.13.2 Normal Mode



Figure 3.13.3 Reset Mode

# 3.13.2 Control Registers

The watchdog timer WDT is controlled by two control registers WDMOD and WDCR.

- (1) Watchdog timer mode register (WDMOD)
  - 1. Setting the detection time for the watchdog timer <WDTP>

This 2-bit register is used to set the watchdog timer interrupt time for detecting runaway. This register is initialized to WDMOD<WDTP1:0> = "00" when reset.

The detection time for WDT is shown in Figure 3.13.6.

2. Watchdog timer enable/disable control <WDTE>

When reset, WDMOD<WDTE> is initialized to "1" to enable the watchdog timer.

To disable the timer, it is necessary to clear this bit to "0" and write the disable code (B1H) into the watchdog timer control register WDCR. This makes it difficult for the watchdog timer to be disabled by runaway.

However, it is possible to return from the disabled state to the enabled state simply by setting <WDTE> to "1".

3. Watchdog timer out reset connection<RESCR>

This bit is used to connect the output of the watchdog timer with  $\overline{\text{RESET}}$  internally. Since WDMOD<RESCR> is initialized to "0" at reset, a watchdog timer reset is not performed.

(2) Watchdog timer control register (WDCR)

This register is used to disable and clear the watchdog timer's binary counter.

• Disable control

The watchdog timer can be disabled by writing the disable code (B1H) to the WDCR register after clearing WDMOD<WDTE> to "0".

```
WDMOD ← 0 − − − − X X Clear WDMOD<WDTE> to "0".

WDCR ← 1 0 1 1 0 0 0 1 Write the disable code (B1H).
```

• Enable control

This sets WDMOD<WDTE> to "1".

• Watchdog timer clear control

The binary counter can be cleared and made to resume counting by writing the clear code (4EH) into the WDCR register.

WDCR  $\leftarrow$  0 1 0 0 1 1 1 0 Write the clear code (4EH).

7 6 5 4 3 2 1 0 WDMOD Bit symbol WDTE WDTP1 WDTP0 WARM HALTM1 HALTM0 RESCR DRVE (005CH) Read/Write R/W After reset 0 WDT Select detection time Standby mode 1: Internally Warm-up 1: Drives Function 00: 2<sup>15</sup>/f<sub>SYS</sub> control time 00: RUN mode connects the pin 01: 217/fSYS 1: Enable 01: STOP mode WDT out even in 10: 2<sup>19</sup>/f<sub>SYS</sub> 10: IDLE1 mode STOP to the 11: IDLE2 mode 11: 2<sup>21</sup>/f<sub>SYS</sub> reset pin mode See Figure 3.13.6 DRVE (Explanation in STOP mode section) ➤ Watchdog timer out control Connects WDT out to reset ➤ Select the standby mode HALT instruction RUN mode (only the CPU stops) STOP mode (All circuits stop) IDLE1 mode (only the oscillator operates) 10 11 IDLE2 mode (CPU and AD stop) at fc = 20 MHz, fs = 32.768 kHzSelection of warm-up time Warm-up Time System Clock Gear Value Selection T45CR < QCU > = 0T45CR<QCU> = 1 <GEAR2:0> <SYSCK>  $WARM = 0 \mid WARM = 1$ WARM = XXXX  $0.50\,\mathrm{s}$ 2.00 s 1 (fs)  $3.9 \, \mathrm{ms}$ (Don't care) 3.28 ms 6.4 μs 000 (fc)  $0.82 \, \text{ms}$ 001 (fc/2) 1.64 ms 6.55 ms 12.8 μs 0 (fc) 25.6 μs 010 (fc/4) 3.28 ms 13.11 ms 011 (fc/8) 6.55 ms 26.21 ms 51.2 μs 102.4 μs 100 (fc/16) 13.11 ms 52.43 ms ➤ Watchdog timer enable/disable control Disable 0 Enable

Figure 3.13.4 Watchdog Timer Mode Register

7 6 5 4 3 2 1 0 WDCR Bit symbol (005DH) Read/Write W After reset Function B1H: WDT disable code 4EH: WDT clear code → Disable/clear WDT в1Н Disable code 4EH Clear code

Figure 3.13.5 Watchdog Timer Control Register

at fc = 20 MHz, fs = 32.768 kHz

Don't set

Others

| System Clock    | 0 1/-1                            | Watchdog Timer Detecting Time |                           |           |           |  |  |  |  |  |
|-----------------|-----------------------------------|-------------------------------|---------------------------|-----------|-----------|--|--|--|--|--|
| Selection       | Gear Value<br><gear2:0></gear2:0> |                               | WDMOD <wdtp1:0></wdtp1:0> |           |           |  |  |  |  |  |
| <sysck></sysck> | 102/11/2.02                       | 00                            | 01                        | 10        | 11        |  |  |  |  |  |
| 1 (fs)          | XXX<br>(Don't care)               | 2.00 s                        | 8.00 s                    | 32.00 s   | 128.0 s   |  |  |  |  |  |
|                 | 000 (fc)                          | 3.28 ms                       | 13.11 ms                  | 52.43 ms  | 209.72 ms |  |  |  |  |  |
|                 | 001 (fc/2)                        | 6.55 ms                       | 26.24 ms                  | 104.86 ms | 419.43 ms |  |  |  |  |  |
| 0 (fc)          | 010 (fc/4)                        | 13.11 ms                      | 52.43 ms                  | 209.72 ms | 838.86 ms |  |  |  |  |  |
|                 | 011 (fc/8)                        | 26.21 ms                      | 104.86 ms                 | 419.43 ms | 1.68 s    |  |  |  |  |  |
|                 | 100 (fc/16)                       | 52.43 ms                      | 209.72 ms                 | 838.86 ms | 3.36 s    |  |  |  |  |  |

Note: When using the register as the watchdog timer, write 0 to the T45CR<QCU> bit.

Figure 3.13.6 Watchdog Timer Detection Time

# 3.13.3 Operation

The watchdog timer generates interrupt INTWD after the detection time set in the WDMOD<WDTP1:0> and T45CR<QCU> registers has elapsed, and outputs a low level signal. The watchdog timer must be cleared to zero by software before an INTWD interrupt is generated. If the CPU malfunctions (Undergoes runaway) due to causes such as noise, but does not execute the instruction used to clear the binary counter, the binary counter overflows and an INTWD interrupt is generated. The CPU detects malfunction (Runaway) from the INTWD interrupt and it is possible to return to normal operation using a recovery program. If the watchdog timer out pin is connected to the reset pins of peripheral devices, a CPU malfunction can also be acknowledged by these other devices.

### The watchdog timer restarts operation immediately after reset is released.

The watchdog timer does not operate in IDLE1 or STOP mode. In RUN mode, the watchdog timer is operational. When the bus is released ( $\overline{BUSAK} = L$ ), WDT continues counting.

However, the function can be disabled when entering RUN or IDLE2 mode. The watchdog timer is enabled in IDLE2 mode, but the overflow interrupt is disabled. Disable the watchdog timer before entering IDLE2 mode.

Example: 1. Clear the binary counter.

```
WDCR \leftarrow 0 1 0 0 1 1 1 1 0 Write the clear code (4EH).

2. Set the watchdog timer detecting time to 2^{18}/f_{SYS}.

WDMOD \leftarrow 1 0 1 - - - X X

3. Disable the watchdog timer.

WDMOD \leftarrow 0 - - - - - X X Clear WDTE to "0".

WDCR \leftarrow 1 0 1 1 0 0 0 1 Write disable code (B1H).
```

4. Set IDLE1 mode.

```
WDMOD \leftarrow 0 - - - 1 0 X X Disable WDT and set IDLE1 mode. WDCR \leftarrow 1 0 1 1 0 0 0 1 Executes halt command Set standby mode.
```

5. Set the STOP mode (Warm-up time: 216/fsys)

# 4. Electrical Characteristics

# 4.1 Maximum Ratings

TMP93CS40F, TMP93CS41F TMP93CS40DF, TMP93CS41DF "X" used in an expression shows a frequency for the clock fFPH selected by SYSCR1<SYSCK>. The value of X changes according to whether a clock gear or a low speed oscillator is selected. An example value is calculated for fc, with gear = 1/fc (SYSCR1<SYSCK, GEAR2:0> = 0000).

| Parameter                     | Symbol              | Rating                   | Unit |
|-------------------------------|---------------------|--------------------------|------|
| Power supply voltage          | V <sub>CC</sub>     | -0.5 to 6.5              | V    |
| Input voltage                 | V <sub>IN</sub>     | $-0.5$ to $V_{CC} + 0.5$ | V    |
| Output current (Total)        | $\Sigma I_{OL}$     | 120                      | mA   |
| Output current (Total)        | Σl <sub>OH</sub>    | -80                      | mA   |
| Power dissipation (Ta = 85°C) | $P_{D}$             | 600                      | mW   |
| Soldering temperature (10 s)  | T <sub>SOLDER</sub> | 260                      | °C   |
| Storage temperature           | T <sub>STG</sub>    | -65 to 150               | °C   |
| Operating temperature         | T <sub>OPR</sub>    | -40 to 85                | °C   |

Note: The maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no maximum rating value will ever be exceeded.

# 4.2 DC Characteristics (1/2)

 $Ta = -40 \text{ to } 85^{\circ}C$ 

|                       | Parameter                                  | Symbol           | Condition                                             | 1         | Min                   | Typ. (Note) | Max                  | Unit |
|-----------------------|--------------------------------------------|------------------|-------------------------------------------------------|-----------|-----------------------|-------------|----------------------|------|
| (A)                   | supply voltage                             | V <sub>CC</sub>  | fc = 4 to 20 MHz                                      | fs =      | 4.5                   |             | 5.5                  | V    |
| (A)                   | (AV <sub>CC</sub> = V <sub>SS</sub> = 0 V) |                  | fc = 4 to 12.5 MHz                                    | 34 kHz    | 2.7                   |             | 5.5                  | V    |
|                       | AD0 to AD15                                |                  | $V_{CC} \ge 4.5 \text{ V}$                            |           |                       |             | 0.8                  |      |
|                       | 7.20.07.270                                | V <sub>IL</sub>  | V <sub>CC</sub> < 4.5 V                               |           |                       |             | 0.6                  |      |
| Φ                     | Port 2 to port A (except P87)              | V <sub>IL1</sub> |                                                       |           | -0.3                  |             | $0.3V_{CC}$          |      |
| Input<br>Iow voltage  | RESET, NMI, INTO                           | $V_{IL2}$        | V <sub>CC</sub> = 2.7 to 5.5 V                        |           |                       |             | 0.25 V <sub>CC</sub> |      |
| # \                   | ₩ Note    EA , AM8/ AM16                   |                  | VCC = 2.7 to 5.5 v                                    |           |                       |             | 0.3                  |      |
| du No                 | X1                                         | $V_{IL4}$        |                                                       |           |                       |             | 0.2 V <sub>CC</sub>  | V    |
|                       | AD0 to AD15                                | V                | $V_{CC} \ge 4.5 \text{ V}$                            |           | 2.2                   |             |                      |      |
|                       | AD0 t0 AD15                                | V <sub>IH</sub>  | V <sub>CC</sub> < 4.5 V                               |           | 2.0                   |             |                      |      |
| <u>a</u>              | Port 2 to port A (except P87)              | V <sub>IH1</sub> |                                                       |           | 0.7 V <sub>CC</sub>   |             | V <sub>CC</sub> +    |      |
| oltaç                 | RESET, NMI, INTO                           | V <sub>IH2</sub> | V 074-55V                                             |           | 0.75 V <sub>CC</sub>  |             | 0.3                  |      |
| Input<br>high voltage | EA , AM8/ AM16                             | V <sub>IH3</sub> | $V_{CC} = 2.7 \text{ to } 5.5 \text{ V}$              |           | V <sub>CC</sub> - 0.3 |             |                      |      |
| Inp                   | X1                                         | V <sub>IH4</sub> |                                                       |           | 0.8 V <sub>CC</sub>   |             |                      |      |
| Outpu                 | t low voltage                              | V <sub>OL</sub>  | $I_{OL} = 1.6 \text{ mA}$ $(V_{CC} = 2.7 \text{ mA})$ | to 5.5 V) |                       |             | 0.45                 |      |
| Output                |                                            |                  | $I_{OH} = -400 \mu A$ $(V_{CC} = 3 V \pm 10\%)$       |           | 2.4                   |             |                      | V    |
| Outpu                 | t high voltage                             | V <sub>OH2</sub> | $I_{OH} = -400 \mu A$ $(V_{CC} = 5 \ V_{CC})$         | / ± 10%)  | 4.2                   |             |                      |      |

Note: Typical values are for Ta = 25°C and  $V_{CC} = 5$  V unless otherwise noted.

# 4.2 DC Characteristics (2/2)

| Parameter                                    | Symbol                       | Condition                                                                                                | Min      | Typ. (Note 1) | Max       | Unit |
|----------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------|----------|---------------|-----------|------|
| Darlington drive current (8 output pins max) | I <sub>DAR</sub><br>(Note 2) | $V_{EXT} = 1.5 \text{ V}$ $R_{EXT} = 1.1 \text{ k}\Omega$ $(\text{when } V_{CC} = 5 \text{ V} \pm 10\%)$ | -1.0     |               | -3.5      | mA   |
| Input leakage current                        | I <sub>LI</sub>              | $0.0 \le V_{IN} \le V_{CC}$                                                                              |          | 0.02          | ±5        |      |
| Output leakage current                       | I <sub>LO</sub>              | $0.2 \leq V_{IN} \leq V_{CC} - 0.2$                                                                      |          | 0.05          | ±10       | μА   |
| Powerdown voltage (at stop, RAM backup)      | V <sub>STOP</sub>            | $V_{IL2} = 0.2 V_{CC},$<br>$V_{IH2} = 0.8 V_{CC}$                                                        | 2.0      |               | 6.0       | V    |
| RESET pull-up resistor                       | В                            | $V_{CC} = 5 \text{ V} \pm 10\%$                                                                          | 50       |               | 150       | li O |
| RESET pull-up resistor                       | R <sub>RST</sub>             | $V_{CC} = 3 \text{ V} \pm 10\%$                                                                          | 80       |               | 200       | kΩ   |
| Pin capacitance                              | C <sub>IO</sub>              | fc = 1 MHz                                                                                               |          |               | 10        | pF   |
| Schmitt width RESET, NMI, INTO               | V <sub>TH</sub>              |                                                                                                          | 0.4      | 1.0           |           | ٧    |
| Programmable pull-down resistor              | R <sub>KL</sub>              | $V_{CC} = 5 \text{ V} \pm 10\%$<br>$V_{CC} = 3 \text{ V} \pm 10\%$                                       | 10<br>30 |               | 80<br>150 |      |
| Programmable                                 |                              | V <sub>CC</sub> = 5 V ± 10%                                                                              | 50       |               | 150       | kΩ   |
| pull-up resistor                             | R <sub>KH</sub>              | V <sub>CC</sub> = 3 V ± 10%                                                                              | 100      |               | 300       |      |
| NORMAL (Note 3)                              | Icc                          | V <sub>CC</sub> = 5 V ± 10%                                                                              |          | 19            | 25        |      |
| NORMAL2 (Note 4)                             |                              | fc = 20 MHz                                                                                              |          | 24            | 30        |      |
| RUN                                          |                              |                                                                                                          |          | 17            | 25        | mA   |
| IDLE2                                        |                              |                                                                                                          |          | 10            | 15        |      |
| IDLE1                                        |                              |                                                                                                          |          | 3.5           | 5         |      |
| NORMAL (Note 3)                              |                              | $V_{CC} = 3 V \pm 10\%$                                                                                  |          | 6.5           | 10        |      |
| NORMAL2 (Note 4)                             |                              | fc = 12.5 MHz                                                                                            |          | 9.5           | 13        |      |
| RUN                                          |                              | (Typ: $V_{CC} = 3.0 \text{ V}$ )                                                                         |          | 5.0           | 9         | mA   |
| IDLE2                                        |                              |                                                                                                          |          | 3.0           | 5         |      |
| IDLE1                                        |                              |                                                                                                          |          | 0.8           | 1.5       |      |
| SLOW (Note 3)                                |                              | $V_{CC} = 3 \text{ V} \pm 10\%$                                                                          |          | 20            | 35        |      |
| RUN                                          |                              | fs = 32.768 kHz                                                                                          |          | 16            | 30        | μА   |
| IDLE2                                        |                              | (Typ: Vcc = 3.0 V)                                                                                       |          | 10            | 20        |      |
| IDLE1                                        |                              |                                                                                                          |          | 5             | 15        | _    |
| STOP                                         |                              | $V_{CC} = 2.7 \text{ to } 5.5 \text{ V}$                                                                 |          | 0.2           | 10        | μΑ   |

- Note 1: Typical values are for  $Ta = 25^{\circ}C$  and  $V_{CC} = 5$  V unless otherwise noted.
- Note 2:  $I_{\mbox{DAR}}$  is guaranteed for up to eight ports.
- Note 3: I<sub>CC</sub> measurement conditions (NORMAL, SLOW):
  Only CPU is operational; output pins are open and input pins are fixed.
- Note 4: I<sub>CC</sub> measurement conditions (NORMAL2):

  All functions are operational; output pins are open and input pins are fixed.

# 4.3 AC Characteristics

(1)  $V_{CC} = 5 V \pm 10\%$ 

| No.  | Parameter                                                                                                                                | Symbol            | Vari      | able       | 16 N | ИHz | 20 N | ИНz | Unit  |
|------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------|------------|------|-----|------|-----|-------|
| 140. | i arameter                                                                                                                               | Cyrribor          | Min       | Max        | Min  | Max | Min  | Max | Offic |
| 1    | Osc. period (= X)                                                                                                                        | tosc              | 50        | 31250      | 62.5 |     | 50   |     | ns    |
| 2    | CLK pulse width                                                                                                                          | t <sub>CLK</sub>  | 2x - 40   |            | 85   |     | 60   |     | ns    |
| 3    | A0 to A23 valid → CLK hold                                                                                                               | t <sub>AK</sub>   | 0.5x - 20 |            | 11   |     | 5    |     | ns    |
| 4    | CLK valid → A0 to A23 hold                                                                                                               | t <sub>KA</sub>   | 1.5x - 70 |            | 24   |     | 5    |     | ns    |
| 5    | A0 to A15 valid → ALE fall                                                                                                               | t <sub>AL</sub>   | 0.5x – 15 |            | 16   |     | 10   |     | ns    |
| 6    | ALE fall → A0 to A15 hold                                                                                                                | $t_{LA}$          | 0.5x - 20 |            | 11   |     | 5    |     | ns    |
| 7    | ALE high pulse width                                                                                                                     | t <sub>LL</sub>   | x – 40    |            | 23   |     | 10   |     | ns    |
| 8    | ALE fall → RD / WR fall                                                                                                                  | t <sub>LC</sub>   | 0.5x - 25 |            | 6    |     | 0    |     | ns    |
| 9    | $\overline{RD}/\overline{WR}rise \to ALErise$                                                                                            | t <sub>CL</sub>   | 0.5x - 20 |            | 11   |     | 5    |     | ns    |
| 10   | A0 to A15 valid → RD / WR fall                                                                                                           | t <sub>ACL</sub>  | x – 25    |            | 38   |     | 25   |     | ns    |
| 11   | A0 to A23 valid → RD / WR fall                                                                                                           | tACH              | 1.5x - 50 |            | 44   |     | 25   |     | ns    |
| 12   | $\overline{\text{RD}} / \overline{\text{WR}} \text{ rise} \rightarrow \text{A0 to A23 hold}$                                             | t <sub>CA</sub>   | 0.5x - 25 |            | 6    |     | 0    |     | ns    |
| 13   | A0 to A15 valid → D0 to D15 input                                                                                                        | t <sub>ADL</sub>  |           | 3.0x - 55  |      | 133 |      | 95  | ns    |
| 14   | A0 to A23 valid → D0 to D15 input                                                                                                        | t <sub>ADH</sub>  |           | 3.5x - 65  |      | 154 |      | 110 | ns    |
| 15   | $\overline{RD}$ fall $\rightarrow$ D0 to D15 input                                                                                       | t <sub>RD</sub>   |           | 2.0x - 60  |      | 65  |      | 40  | ns    |
| 16   | RD low pulse width                                                                                                                       | t <sub>RR</sub>   | 2.0x - 40 |            | 85   |     | 60   |     | ns    |
| 17   | RD rise → D0 to D15 hold                                                                                                                 | t <sub>HR</sub>   | 0         |            | 0    |     | 0    |     | ns    |
| 18   | $\overline{RD}$ rise $\rightarrow$ A0 to A15 output                                                                                      | t <sub>RAE</sub>  | x – 15    |            | 48   |     | 35   |     | ns    |
| 19   | WR low pulse width                                                                                                                       | t <sub>WW</sub>   | 2.0x - 40 |            | 85   |     | 60   |     | ns    |
| 20   | D0 to D15 valid→ WR rise                                                                                                                 | t <sub>DW</sub>   | 2.0x - 55 |            | 70   |     | 45   |     | ns    |
| 21   | $\overline{\text{WR}}$ rise $\rightarrow$ D0 to D15 hold                                                                                 | t <sub>WD</sub>   | 0.5x – 15 |            | 16   |     | 10   |     | ns    |
| 22   | A0 to A23 valid $\rightarrow \overline{\text{WAIT}}$ input $\begin{pmatrix} (1+N) \text{ WAIT} \\ \text{mode} \end{pmatrix}$             | tawh              |           | 3.5x - 90  |      | 129 |      | 85  | ns    |
| 23   | A0 to A15 valid $\rightarrow \overline{\text{WAIT}}$ input $\begin{pmatrix} (1+N) \text{ WAIT} \\ \text{mode} \end{pmatrix}$             | t <sub>AWL</sub>  |           | 3.0x - 80  |      | 108 |      | 70  | ns    |
| 24   | $\overline{RD} / \overline{WR} \text{ fall } \rightarrow \overline{WAIT} \text{ hold } \begin{pmatrix} (1+N) WAIT \\ mode \end{pmatrix}$ | t <sub>CW</sub>   | 2.0x + 0  |            | 125  |     | 100  |     | ns    |
| 25   | A0 to A23 valid → Port input                                                                                                             | t <sub>APH</sub>  |           | 2.5x - 120 |      | 36  |      | 5   | ns    |
| 26   | A0 to A23 valid → Port hold                                                                                                              | t <sub>APH2</sub> | 2.5x + 50 |            | 206  |     | 175  |     | ns    |
| 27   | WR rise → Port valid                                                                                                                     | tCP               |           | 200        |      | 200 |      | 200 | ns    |
| 28   | A0 to A23 valid → RAS fall                                                                                                               | tasrh             | 1.0x - 40 |            | 23   |     | 10   |     | ns    |
| 29   | A0 to A15 valid → RAS fall                                                                                                               | tASRL             | 0.5x – 15 |            | 16   |     | 10   |     | ns    |
| 30   | RAS fall → D0 to D15 input                                                                                                               | t <sub>RAC</sub>  |           | 2.5x - 70  |      | 86  |      | 55  | ns    |
| 31   | RAS fall → A0 to A15 hold                                                                                                                | t <sub>RAH</sub>  | 0.5x - 15 |            | 16   |     | 10   |     | ns    |
| 32   | RAS low pulse width                                                                                                                      | t <sub>RAS</sub>  | 2.0x - 40 |            | 85   |     | 60   |     | ns    |
| 33   | RAS high pulse width                                                                                                                     | t <sub>RP</sub>   | 2.0x - 40 |            | 85   |     | 60   |     | ns    |
| 34   | CAS fall → RAS rise                                                                                                                      | t <sub>RSH</sub>  | 1.0x - 40 |            | 23   |     | 10   |     | ns    |
| 35   | RAS rise → CAS rise                                                                                                                      | t <sub>RSC</sub>  | 0.5x - 25 |            | 6    |     | 0    |     | ns    |
| 36   | RAS fall → CAS fall                                                                                                                      | t <sub>RCD</sub>  | 1.0x - 40 |            | 23   |     | 10   |     | ns    |
| 37   | CAS fall → D0 to D15 input                                                                                                               | t <sub>CAC</sub>  |           | 1.5x – 65  |      | 29  |      | 10  | ns    |
| 38   | CAS low pulse width                                                                                                                      | tCAS              | 1.5x - 30 |            | 64   |     | 40   |     | ns    |

# AC measuring conditions

- Output level: High 2.2 V/Low 0.8 V,  $C_L = 50 \text{ pF}$  (However,  $C_L = 100 \text{ pF}$  for AD0 to AD15, A0 to A23, ALE,  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ,  $\overline{\text{HWR}}$ ,  $\overline{\text{R/W}}$ ,  $\overline{\text{CLK}}$ ,  $\overline{\text{RAS}}$ ,  $\overline{\text{CASO}}$  to  $\overline{\text{CAS2}}$ )
- Input level: High 2.4 V/Low 0.45 V (AD0 to AD15) High 0.8 × Vcc/Low 0.2 × Vcc (except for AD0 to AD15)

# (2) $V_{CC} = 3 V \pm 10\%$

| No. | Parameter                                                                                                                                            | Symbol            | Variable   |            | 12.5 MHz |     | Unit  |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------|------------|----------|-----|-------|
|     |                                                                                                                                                      |                   | Min        | Max        | Min      | Max | Offic |
| 1   | Osc. period (= X)                                                                                                                                    | tosc              | 80         | 31250      | 80       |     | ns    |
| 2   | CLK pulse width                                                                                                                                      | t <sub>CLK</sub>  | 2x - 40    |            | 120      |     | ns    |
| 3   | A0 to A23 valid → CLK hold                                                                                                                           | t <sub>AK</sub>   | 0.5x - 30  |            | 10       |     | ns    |
| 4   | CLK valid → A0 to A23 hold                                                                                                                           | t <sub>KA</sub>   | 1.5x - 80  |            | 40       |     | ns    |
| 5   | A0 to A15 valid → ALE fall                                                                                                                           | t <sub>AL</sub>   | 0.5x - 35  |            | 5        |     | ns    |
| 6   | ALE fall → A0 to A15 hold                                                                                                                            | t <sub>LA</sub>   | 0.5x - 35  |            | 5        |     | ns    |
| 7   | ALE high pulse width                                                                                                                                 | t <sub>LL</sub>   | x - 60     |            | 20       |     | ns    |
| 8   | ALE fall → RD / WR fall                                                                                                                              | tLC               | 0.5x - 35  |            | 5        |     | ns    |
| 9   | RD / WR rise →ALE rise                                                                                                                               | t <sub>CL</sub>   | 0.5x - 40  |            | 0        |     | ns    |
| 10  | A0 to A15 valid $\rightarrow \overline{RD} / \overline{WR}$ fall                                                                                     | t <sub>ACL</sub>  | x – 50     |            | 30       |     | ns    |
| 11  | A0 to A23 valid $\rightarrow \overline{RD} / \overline{WR}$ fall                                                                                     | t <sub>ACH</sub>  | 1.5x – 50  |            | 70       |     | ns    |
| 12  | $\overline{RD}$ / $\overline{WR}$ rise $\rightarrow$ A0 to A23 hold                                                                                  | t <sub>CA</sub>   | 0.5x - 40  |            | 0        |     | ns    |
| 13  | A0 to A15 valid → D0 to D15 input                                                                                                                    | t <sub>ADL</sub>  |            | 3.0x - 110 |          | 130 | ns    |
| 14  | A0 to A23 valid → D0 to D15 input                                                                                                                    | t <sub>ADH</sub>  |            | 3.5x - 125 |          | 155 | ns    |
| 15  | $\overline{RD}$ fall $\rightarrow$ D0 to D15 input                                                                                                   | t <sub>RD</sub>   |            | 2.0x - 115 |          | 45  | ns    |
| 16  | RD low pulse width                                                                                                                                   | t <sub>RR</sub>   | 2.0x - 40  |            | 120      |     | ns    |
| 17  | $\overline{RD}$ rise $\rightarrow$ D0 to D15 hold                                                                                                    | t <sub>HR</sub>   | 0          |            | 0        |     | ns    |
| 18  | $\overline{RD}$ rise $\rightarrow$ A0 to A15 output                                                                                                  | t <sub>RAE</sub>  | x – 25     |            | 55       |     | ns    |
| 19  | WR low pulse width                                                                                                                                   | t <sub>WW</sub>   | 2.0x - 40  |            | 120      |     | ns    |
| 20  | D0 to D15 valid → WR rise                                                                                                                            | t <sub>DW</sub>   | 2.0x - 120 |            | 40       |     | ns    |
| 21  | $\overline{\text{WR}}$ rise $\rightarrow$ D0 to D15 hold                                                                                             | t <sub>WD</sub>   | 0.5x - 40  |            | 0        |     | ns    |
| 22  | A0 to A23 valid $\rightarrow \overline{\text{WAIT}}$ input $\begin{pmatrix} (1+N) \text{ WAIT} \\ \text{mode} \end{pmatrix}$                         | t <sub>AWH</sub>  |            | 3.5x - 130 |          | 150 | ns    |
| 23  | A0 to A15 valid $\rightarrow \overline{\text{WAIT}}$ input $\begin{pmatrix} (1+N) \text{ WAIT} \\ \text{mode} \end{pmatrix}$                         | t <sub>AWL</sub>  |            | 3.0x - 100 |          | 140 | ns    |
| 24  | $\overline{RD} / \overline{WR} \text{ fall} \rightarrow \overline{WAIT} \text{ hold} \qquad \begin{pmatrix} (1+N) WAIT \\ \text{mode} \end{pmatrix}$ | t <sub>CW</sub>   | 2.0x + 0   |            | 160      |     | ns    |
| 25  | A0 to A23 valid → Port input                                                                                                                         | t <sub>APH</sub>  |            | 2.5x - 195 |          | 5   | ns    |
| 26  | A0 to A23 valid → Port hold                                                                                                                          | t <sub>APH2</sub> | 2.5x + 50  |            | 250      |     | ns    |
| 27  | WR rise → Port valid                                                                                                                                 | t <sub>CP</sub>   |            | 200        |          | 200 | ns    |
| 28  | A0 to A23 valid → RAS fall                                                                                                                           | tasrh             | 1.0x - 60  |            | 20       |     | ns    |
| 29  | A0 to A15 valid → RAS fall                                                                                                                           | t <sub>ASRL</sub> | 0.5x - 40  |            | 0        |     | ns    |
| 30  | $\overline{RAS}$ fall $\rightarrow$ D0 to D15 input                                                                                                  | t <sub>RAC</sub>  |            | 2.5x - 90  |          | 110 | ns    |
| 31  | $\overline{RAS}$ fall $\rightarrow$ A0 to A15 hold                                                                                                   | t <sub>RAH</sub>  | 0.5x - 25  |            | 15       |     | ns    |
| 32  | RAS low pulse width                                                                                                                                  | t <sub>RAS</sub>  | 2.0x - 40  |            | 120      |     | ns    |
| 33  | RAS high pulse width                                                                                                                                 | t <sub>RP</sub>   | 2.0x - 40  |            | 120      |     | ns    |
| 34  | $\overline{\text{CAS}}$ fall $\rightarrow \overline{\text{RAS}}$ rise                                                                                | t <sub>RSH</sub>  | 1.0x – 55  |            | 25       |     | ns    |
| 35  | $\overline{RAS}$ rise $\rightarrow \overline{CAS}$ rise                                                                                              | t <sub>RSC</sub>  | 0.5x - 25  |            | 15       |     | ns    |
| 36  | $\overline{RAS} \ fall \to \overline{CAS} \ fall$                                                                                                    | t <sub>RCD</sub>  | 1.0x - 40  |            | 40       |     | ns    |
| 37  | CAS fall → D0 to D15 input                                                                                                                           | t <sub>CAC</sub>  |            | 1.5x – 120 |          | 0   | ns    |
| 38  | CAS low pulse width                                                                                                                                  | t <sub>CAS</sub>  | 1.5x – 40  |            | 80       |     | ns    |

# AC measuring conditions

- Input level: High  $0.9 \times V_{CC}/Low \ 0.1 \times V_{CC}$

# (1) Read cycle



Note: Since the CPU accesses the internal area to read data from a port, the control signals of external pins such as  $\overline{\text{RD}}$  and  $\overline{\text{CS}}$  are not enabled. Therefore, the above waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative.



Note: Since the CPU accesses the internal area to write data to a port, the control signals of external pins such as  $\overline{\text{WR}}$  and  $\overline{\text{CS}}$  are not enabled. Therefore, the above waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative.

### 4.4 AD Conversion Characteristics

 $\mathsf{AV}_{CC} = \mathsf{V}_{CC}, \ \mathsf{AV}_{SS} = \mathsf{V}_{SS}$ 

| Parameter                               | Symbol                                        | Power Supply                             | Min                     | Тур             | Max                     | Unit |
|-----------------------------------------|-----------------------------------------------|------------------------------------------|-------------------------|-----------------|-------------------------|------|
| Analog reference voltage (1)            | \/                                            | $V_{CC} = 5 V \pm 10\%$                  | V <sub>CC</sub> – 1.5 V | V <sub>CC</sub> | V <sub>CC</sub>         |      |
| Analog reference voltage (+)            | $V_{REFH}$                                    | $V_{CC} = 3 \text{ V} \pm 10\%$          | V <sub>CC</sub> – 0.2 V | Vcc             | V <sub>CC</sub>         |      |
| Analog reference voltage (-)            | \/                                            | $V_{CC} = 5 \text{ V} \pm 10\%$          | V <sub>SS</sub>         | $V_{SS}$        | V <sub>SS</sub> + 0.2 V | V    |
| Analog reference voltage (–)            | V <sub>REFL</sub>                             | $V_{CC} = 3 \text{ V} \pm 10\%$          | V <sub>SS</sub>         | V <sub>SS</sub> | V <sub>SS</sub> + 0.2 V |      |
| Analog input voltage range              | V <sub>AIN</sub>                              |                                          | V <sub>REFL</sub>       |                 | V <sub>REFH</sub>       |      |
| Analog current for analog reference     |                                               | $V_{CC} = 5 \text{ V} \pm 10\%$          |                         | 0.5             | 1.5                     |      |
| voltage<br><vrefon> = 1</vrefon>        | I <sub>REF</sub><br>(V <sub>REFL</sub> = 0 V) | $V_{CC} = 3 \text{ V} \pm 10\%$          |                         | 0.3             | 0.9                     | mA   |
| <vrefon> = 0</vrefon>                   | (TREFL - 0 )                                  | $V_{CC} = 2.7 \text{ to } 5.5 \text{ V}$ |                         | 0.02            | 5.0                     | μА   |
|                                         |                                               | $V_{CC} = 5 V \pm 10\%$                  |                         | ±1.0            | ±3.0                    | LCD  |
| Error (not including quantizing errors) |                                               | $V_{CC} = 3 \text{ V} \pm 10\%$          |                         | ±1.0            | ±3.0                    | LSB  |

Note 1:  $1LSB = (V_{REFH} - V_{REFL})/2^{10} [V]$ 

Note 2: The operation of this AD converter is guaranteed only using fc (The high-frequency oscillator). It is not guaranteed for fs.

The operation above is guaranteed for  $f_{FPH} \ge 4$  MHz.

Note 3: The value I<sub>CC</sub> includes the current which flows through the AVCC pin.

## 4.5 Serial Channel Timing

### (1) I/O interface mode

### 1. SCLK input mode

| Parameter                                                 | Cumbal | Varia                         | able                        | 32.768 M | Hz (Note) | 12.5 | MHz | 20 1 | ИНz | Unit  |
|-----------------------------------------------------------|--------|-------------------------------|-----------------------------|----------|-----------|------|-----|------|-----|-------|
| Parameter                                                 | Symbol | Min                           | Max                         | Min      | Max       | Min  | Max | Min  | Max | Offic |
| SCLK cycle                                                | tscy   | 16X                           |                             | 488      |           | 1.28 |     | 0.8  |     | μS    |
| Output data → Rising edge or falling edge* of SCLK        | toss   | t <sub>SCY</sub> /2 - 5X - 50 |                             | 91.5 μs  |           | 190  |     | 100  |     | ns    |
| SCLK rising edge or falling edge*  → Output data hold     | tons   | 5X – 100                      |                             | 152 μs   |           | 300  |     | 150  |     | ns    |
| SCLK rising edge or falling edge*  → Input data hold      | tHSR   | 0                             |                             | 0        |           | 0    |     | 0    |     | ns    |
| SCLK rising edge or falling edge*  → Effective data input | tSRD   |                               | t <sub>SCY</sub> - 5X - 100 |          | 336 μs    |      | 780 |      | 450 | ns    |

Note: System clock is fs, or input clock to prescaler is divisor clock of fs.

\* The rising edge is used in SCLK rising mode. The falling edge is used SCLK falling mode.

## 2. SCLK output mode

| Dorometer                               | Cumbal |                             | able                        | 32.768 MHz | z (Note) | 12.5 | MHz    | 20 N | ИHz   | Linit |
|-----------------------------------------|--------|-----------------------------|-----------------------------|------------|----------|------|--------|------|-------|-------|
| Parameter                               | Symbol | Min                         | Min Max Min Max             |            | Min      | Max  | Min    | Max  | Unit  |       |
| SCLK cycle (Programmable)               | tSCY   | 16X                         | 8192X                       | 488        | 250 ms   | 1.28 | 655.36 | 0.8  | 409.6 | μS    |
| Output data → SCLK rising edge          | toss   | t <sub>SCY</sub> – 2X – 150 |                             | 427 μs     |          | 970  |        | 550  |       | ns    |
| SCLK rising edge → Output data hold     | tons   | 2X - 80                     |                             | 60 μs      |          | 80   |        | 20   |       | ns    |
| SCLK rising edge → Input data hold      | tHSR   | 0                           |                             | 0          |          | 0    |        | 0    |       | ns    |
| SCLK rising edge → Effective data input | tSRD   |                             | t <sub>SCY</sub> – 2X – 150 |            | 428 μs   |      | 970    |      | 550   | ns    |

Note: System clock is fs, or input clock to prescaler is divisor clock of fs.



## 4.6 Timer/Counter Input Clock (TI0, TI4, TI5, TI6 and TI7)

| Parameter                    | Symbol            | Vari     | able | 12.5 | MHz | 20 N | ИHz | Unit  |
|------------------------------|-------------------|----------|------|------|-----|------|-----|-------|
|                              | Symbol            | Min      | Max  | Min  | Max | Min  | Max | Offic |
| Clock cycle                  | t <sub>VCK</sub>  | 8X + 100 |      | 740  |     | 500  |     | ns    |
| Low level clock pulse width  | t <sub>VCKL</sub> | 4X + 40  |      | 360  |     | 240  |     | ns    |
| High level clock pulse width | tvckh             | 4X + 40  |      | 360  |     | 240  |     | ns    |

## 4.7 Interrupt and Capture

## (1) $\overline{\text{NMI}}$ and INT0 interrupts

| Parameter                        | Svmbol   | Vari | able | 12.5 | MHz | 20 N | ИHz | Unit   |
|----------------------------------|----------|------|------|------|-----|------|-----|--------|
| Farameter                        | Syllibol | Min  | Max  | Min  | Max | Min  | Max | Offile |
| NMI, INTO low level pulse width  | tINTAL   | 4X   |      | 320  |     | 200  |     | ns     |
| NMI, INT0 high level pulse width | tINTAH   | 4X   |      | 320  |     | 200  |     | ns     |

## (2) INT4 to INT7 interrupts, capture

The INT4 to INT7 input pulse width depends on the CPU operation clock and timer (9-bit prescaler). The following shows the pulse width for each clock.

| 1 '                                          | Prescaler Clock        |            | TBL level pulse width) |            | TBH<br>n level pulse width) |      |
|----------------------------------------------|------------------------|------------|------------------------|------------|-----------------------------|------|
| Selected Selected SYSCK> <prck1:0></prck1:0> |                        | Variable   | 20 MHz                 | Variable   | 20 MHz                      | Unit |
| 10100K2                                      | CFRORT.02              | Min        | Min                    | Min        | Min                         |      |
|                                              | 00 (f <sub>FPH</sub> ) | 8X + 100   | 500                    | 8X + 100   | 500                         | ns   |
| 0 (fc)                                       | 01 (fs)                | 8XT + 0.1  | 244.3                  | 8XT + 0.1  | 244.3                       |      |
|                                              | 10 (fc/16)             | 128x + 0.1 | 6.5                    | 128X + 0.1 | 6.5                         |      |
| 1 (fs)                                       | 00 (f <sub>FPH</sub> ) | 8XT + 0.1  | 244.3                  | 8XT + 0.1  | 244.3                       | μS   |
| (Note 2)                                     | 01 (fs)                | 0A1 + 0.1  | 244.3                  | 0/1 + 0.1  | 244.3                       |      |

Note 1: XT represents the frequency of the low-frequency clock fs. Calculated at fs = 32.768 kHz.

Note 2: When using fs as the system clock, fc/16 cannot be selected as the prescaler clock.

## 4.8 SCOUT Pin AC Characteristics

| Parameter                                              | Symbol           | Vari      | able | 12.5 | MHz | 20 N | ИHz | Unit  |
|--------------------------------------------------------|------------------|-----------|------|------|-----|------|-----|-------|
| Farameter                                              | Symbol           | Min       | Max  | Min  | Max | Min  | Max | Offic |
| High-level pulse width $V_{CC} = 5 \text{ V} \pm 10\%$ |                  | 0.5X – 10 |      | 40   |     | 15   |     | 20    |
| High-level pulse width $V_{CC} = 3 \ V \pm 10\%$       | tsch             | 0.5X - 20 |      | 30   |     | _    | _   | ns    |
| Low-level pulse width $V_{CC} = 5 \ V \pm 10\%$        | 4                | 0.5X – 10 |      | 40   |     | 15   |     | 20    |
| Low-level pulse width $V_{CC} = 3 \ V \pm 10\%$        | t <sub>SCL</sub> | 0.5X - 20 |      | 30   |     | _    | _   | ns    |

## Measurement condition

• Output level: High 2.2 V/Low 0.8 V,  $C_L = 10 \text{ pF}$ 



# 4.9 Timing Chart for Bus Request (BUSRQ)/Bus Acknowledge (BUSAK)



| Parameter                  | Symbol           | ,   | Variable   | 12.5 | MHz | 20 N | 1Hz | Unit  |
|----------------------------|------------------|-----|------------|------|-----|------|-----|-------|
| Farameter                  | Symbol           | Min | Max        | Min  | Max | Min  | Max | Offic |
| BUSRQ setup time to CLK    | t <sub>BRC</sub> | 120 |            | 120  |     | 120  |     | ns    |
| CLK→BUSAK falling edge     | tCBAL            |     | 1.5X + 120 |      | 240 |      | 195 | ns    |
| CLK→BUSAK rising edge      | tCBAH            |     | 0.5x + 40  |      | 80  |      | 65  | ns    |
| Output buffer off to BUSAK | t <sub>ABA</sub> | 0   | 80         | 0    | 80  | 0    | 80  | ns    |
| BUSAK to output buffer on  | t <sub>BAA</sub> | 0   | 80         | 0    | 80  | 0    | 80  | ns    |

Note 1: Even if the  $\overline{\text{BUSRQ}}$  signal goes low, the bus will not be released while the  $\overline{\text{WAIT}}$  signal is low. The bus will only be released when  $\overline{\text{BUSRQ}}$  goes low while  $\overline{\text{WAIT}}$  is high.

Note 2: This line shows only that the output buffer is in the off state.

It does not indicate that the signal level is fixed.

Just after the bus is released, the signal level set before the bus was released is maintained dynamically by the external capacitance. Therefore, to fix the signal level using an external resistor during bus release, careful design is necessary, as fixing of the level is delayed.

The internal programmable pull-up/pull-down resistor is switched between the active and non-active states by the internal signal.

### 4.10 Recommended Oscillator

The TMP93CS40/S41 are evaluated with various resonators. The evaluation results are displayed below to enable appropriate selection for any given application.

Note: The load capacitance of the resonator consists of the load capacitors C1 and C2 which are to be connected and the floating capacitance of the target board.

Even if the specified values of C1 and C2 are used, there is a possibility that the oscillator will malfunction due to varying load capacitance on the target boards. Hence the oscillator's wiring patterns on the board should be designed to be as short as possible.

It is recommended that evaluation of the resonators be conducted on the target board.

### (1) Examples of resonator connection



Figure 1: Example of High-frequency
Resonator Connection



Figure 2: Example of Low-frequency
Resonator Connection

### (2) Ceramic resonator: Murata Manufacturing. Co., Ltd (Note 1)

 $Ta = -20 \text{ to } 80^{\circ}\text{C}$ 

| Parameter                  | Frequency | Recommended    | Recor                       | mmended Va    | alue                     | \/a= [\/]           |
|----------------------------|-----------|----------------|-----------------------------|---------------|--------------------------|---------------------|
| i arameter                 | (MHz)     | Resonator      | C1 [pF]                     | C2 [pF]       | $Rd\left[k\Omega\right]$ | V <sub>CC</sub> [V] |
|                            | 4.00      | CSA4.00MG      | 30                          | 30            |                          |                     |
|                            | 4.00      | CST4.00MGW     | (30) (Note 2)               | (30) (Note 2) |                          |                     |
|                            | 10.00     | CSA10.0MTZ093  | 30                          | 30            |                          | 2.7 to 5.5          |
| High fraguency             | 10.00     | CST10.0MTW093  | (30) (Note 2) (30) (Note 2) |               |                          | 2.7 10 5.5          |
| High-frequency oscillation | 12.50     | CSA12.5MTZ093  | 30                          | 30            | 0                        |                     |
| OSCIIIALION                | 12.50     | CST12.5MTW093  | (30) (Note 2)               | (30) (Note 2) |                          |                     |
|                            | 16.00     | CSA16.00MXZ040 | 5                           | 5             |                          |                     |
| _                          | 16.00     | CST16.00MXW0C1 | (5) (Note 2)                | (5) (Note 2)  |                          | 4.5 to 5.5          |
|                            | 20.00     | CSA20.00MXZ040 | 3                           | 3             |                          |                     |

Note 1: Murata Manufacturing. Co., Ltd. (Japan)

The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change.

For up-to-date information, please refer to the following URL:

http://www.murata.com/

Note 2: For built-in condenser type

## (3) Crystal resonator: Nihon Denpa Kogyo (Note 1)

Ta = -10 to 60°C

Fax: +1-510-623-6590

Fax: +65-6293-1150

Fax: +852-2956-1567

Fax: +44-20-8390-6926

Fax: +33-1-60-95-8200

Fax: +39-02-96703284

| Parameter      | Frequency | Recommended Resonator | Reco    | mmended | Value         | Vcc [V]    |
|----------------|-----------|-----------------------|---------|---------|---------------|------------|
| Parameter      | (MHz)     | Recommended Resonator | C1 [pF] | C2 [pF] | $Rd[k\Omega]$ | VCC [V]    |
|                | 4.00      | NT040016A             | 12      | 12      |               |            |
| High fraguancy | 10.00     | NT100016A             | 10      | 10      |               | 2.7 to 5.5 |
| High-frequency | 12.50     | NT125016A             | 10      | 10      | 0             |            |
| oscillation    | 16.00     | NT160016A             | 10      | 10      |               | 1 E to E E |
|                | 20.00     | NT200016A             | 7       | 7       |               | 4.5 to 5.5 |

Note 1: NDK AMERICA, INC.: U.S.A

NDK ELECTRONICS SINGAPORE PTE, LTD. Phone: +65-6298-9878, NDK ELECTRONICS (HK) LIMITED: HONG KONG Phone: +852-2956-3181,

NDK EUROPE LIMITED: ENGLAND NDK FRANCE SARL: FRANCE

NDK ITALY SRL: ITALY

Note 2: High-frequency resonator

NR-18: AT-51: CP12A: Phone: +1-510-623-6512,

Phone: +65-6298-9878, Phone: +852-2956-3181, Phone: +44-20-8390-8344, Phone: +33-1-60-95-0000,

Phone: +39-02-96702920,

Lead mount type Lead mount type Surface mount type

93CS40-220

# 5. Table of Special Function Registers (SFRs)

(SFR: Special function register)

The special function registers (SFRs) include the I/O ports and peripheral control registers allocated to the 128 bytes whose addresses run from 000000H to 00007FH.

- (1) I/O ports
- (2) I/O port control
- (3) Timer control
- (4) Pattern generator control
- (5) Watchdog timer control
- (6) Serial channel control
- (7) AD converter control
- (8) Interrupt control
- (9) Chip select/wait control
- (10) Clock control

## Configuration of the table

| Symbol | Name | Address | 7 | 6      |                 |              | 1         | 0         |                             |
|--------|------|---------|---|--------|-----------------|--------------|-----------|-----------|-----------------------------|
|        |      |         |   | !      | $[ \ \ \ \ \ ]$ | $\int$       | !         | !<br>!    | → Bit symbol                |
|        |      |         |   |        |                 | $\mathbb{Z}$ | !         | <br>      | → Read/Write                |
|        |      |         |   | i<br>! | i<br>!          |              | !<br>!    | <br>      | → Initial value after reset |
|        |      |         |   | <br>   | <br>            | 7/           | <br> <br> | <br> <br> | → Remarks                   |

Note: "Prohibit RMW" in the table means that you cannot use RMW instructions on these registers.

(Example) When setting only bit0 of register P0CR, "SET 0, (0002H)" cannot be used. The LD (Transfer) instruction must be used to write all eight bits.

Table 5.1 I/O Register Address Map

| Address | Name | Address | Name   | Address | Name   | Address | Name     |
|---------|------|---------|--------|---------|--------|---------|----------|
| 000000H | P0   | 20H     | TRUN   | 40H     | TREG6L | 60H     | ADREG04L |
| 1H      | P1   | 21H     |        | 41H     | TREG6H | 61H     | ADREG04H |
| 2H      | P0CR | 22H     | TREG0  | 42H     | TREG7L | 62H     | ADREG15L |
| 3H      |      | 23H     | TREG1  | 43H     | TREG7H | 63H     | ADREG15H |
| 4H      | P1CR | 24H     | TMOD   | 44H     | CAP3L  | 64H     | ADREG26L |
| 5H      | P1FC | 25H     | TFFCR  | 45H     | CAP3H  | 65H     | ADREG26H |
| 6H      | P2   | 26H     | TREG2  | 46H     | CAP4L  | 66H     | ADREG37L |
| 7H      | P3   | 27H     | TREG3  | 47H     | CAP4H  | 67H     | ADREG37H |
| 8H      | P2CR | 28H     | P0MOD  | 48H     | T5MOD  | 68H     | B0CS     |
| 9H      | P2FC | 29H     | P1MOD  | 49H     | T5FFCR | 69H     | B1CS     |
| AH      | P3CR | 2AH     | PFFCR  | 4AH     |        | 6AH     | B2CS     |
| ВН      | P3FC | 2BH     |        | 4BH     |        | 6BH     |          |
| CH      | P4   | 2CH     |        | 4CH     | PG0REG | 6CH     |          |
| DH      | P5   | 2DH     |        | 4DH     | PG1REG | 6DH     | CKOCR    |
| EH      | P4CR | 2EH     |        | 4EH     | PG01CR | 6EH     | SYSCR0   |
| FH      |      | 2FH     |        | 4FH     |        | 6FH     | SYSCR1   |
| 10H     | P4FC | 30H     | TREG4L | 50H     | SC0BUF | 70H     | INTE0AD  |
| 11H     |      | 31H     | TREG4H | 51H     | SC0CR  | 71H     | INTE45   |
| 12H     | P6   | 32H     | TREG5L | 52H     | SC0MOD | 72H     | INTE67   |
| 13H     | P7   | 33H     | TREG5H | 53H     | BR0CR  | 73H     | INTET10  |
| 14H     | P6CR | 34H     | CAP1L  | 54H     | SC1BUF | 74H     | INTEPW10 |
| 15H     | P7CR | 35H     | CAP1H  | 55H     | SC1CR  | 75H     | INTET54  |
| 16H     | P6FC | 36H     | CAP2L  | 56H     | SC1MOD | 76H     | INTET76  |
| 17H     | P7FC | 37H     | CAP2H  | 57H     | BR1CR  | 77H     | INTES0   |
| 18H     | P8   | 38H     | T4MOD  | 58H     | ODE    | 78H     | INTES1   |
| 19H     | P9   | 39H     | T4FFCR | 59H     |        | 79H     |          |
| 1AH     | P8CR | 3AH     | T45CR  | 5AH     |        | 7AH     |          |
| 1BH     | P9CR | 3BH     |        | 5BH     |        | 7BH     | IIMC     |
| 1CH     | P8FC | 3CH     |        | 5CH     | WDMOD  | 7CH     | DMA0V    |
| 1DH     | P9FC | 3DH     |        | 5DH     | WDCR   | 7DH     | DMA1V    |
| 1EH     | PA   | 3EH     |        | 5EH     | ADMOD1 | 7EH     | DMA2V    |
| 1FH     | PACR | 3FH     |        | 5FH     | ADMOD2 | 7FH     | DMA3V    |

Note: Do not access addresses which do not have register names allocated.

## (1) I/O port

| Symbol | Name    | Address | 7             | 6      | 5    | 4      | 3             | 2        | 1         | 0            |
|--------|---------|---------|---------------|--------|------|--------|---------------|----------|-----------|--------------|
|        |         |         | P07           | P06    | P05  | P04    | P03           | P02      | P01       | P00          |
| P0     | Port0   | 00H     |               |        |      | R/     | W             |          |           |              |
|        |         |         |               |        |      | Input  | mode          |          |           |              |
|        |         |         |               |        |      | Unde   | fined         |          |           | 1            |
|        |         |         | P17           | P16    | P15  | P14    | P13           | P12      | P11       | P10          |
| P1     | Port1   | 01H     |               |        |      |        | W             |          |           |              |
|        |         |         |               | T      | T    |        | mode          | T        | 1         |              |
|        |         |         | 0             | 0      | 0    | 0      | 0             | 0        | 0         | 0            |
|        | D 10    | 2011    | P27           | P26    | P25  | P24    | P23           | P22      | P21       | P20          |
| P2     | Port2   | 06H     |               |        |      |        | Note 3)       |          |           |              |
|        |         |         |               |        |      |        | mode          |          | 1 -       |              |
|        |         |         | 0             | 0      | 0    | 0      | 0             | 0        | 0         | 0            |
| DO     | Dt 0    | 0711    | P37           | P36    | P35  | P34    | P33           | P32      | P31       | P30 (Note 1) |
| P3     | Port 3  | 07H     |               |        |      | ,      | Note 3)       |          |           |              |
|        |         |         | 4             | 4      |      | mode   | 4             |          |           | t mode       |
|        |         |         | 1             | 1      | 1    | 1      | 1             | 1<br>P42 | 1<br>P41  | 1<br>P40     |
| P4     | Port4   | 0CH     | $\overline{}$ |        |      |        | $\overline{}$ |          | R/W (Note |              |
| F 4    | 10114   | 0011    | $\overline{}$ |        |      |        |               | ,        | :         |              |
|        |         |         | $\overline{}$ |        |      |        |               | 0        | 1         |              |
|        |         |         | P57           | P56    | P55  | P54    | P53           | P52      | 1<br>P51  | P50          |
| P5     | Port5   | 0DH     | 107           | 1 00   | 1 00 |        | ₹             | 102      | 101       | 1 00         |
|        |         |         |               |        |      |        | mode          |          |           |              |
|        |         |         | P67           | P66    | P65  | P64    | P63           | P62      | P61       | P60          |
| P6     | Port6   | 12H     |               |        |      | *R/W ( |               | <u> </u> |           |              |
|        |         |         |               |        |      | •      | mode          |          |           |              |
|        |         |         | 1             | 1      | 1    | 1      | 1             | 1        | 1         | 1            |
|        |         |         |               |        |      |        | P73           | P72      | P71       | P70          |
| P7     | Port7   | 13H     |               |        |      |        |               | *R/W (   | Note 3)   |              |
|        |         |         |               |        |      |        |               | Input    | mode      | 1            |
|        |         |         |               |        |      |        | 1             | 1        | 1         | 1            |
|        |         |         | P87           | P86    | P85  | P84    | P83           | P82      | P81       | P80          |
| P8     | Port8   | 18H     |               |        |      | *R/W ( |               |          |           |              |
|        |         |         |               | T      | T    |        | mode          | T        | 1         |              |
|        |         |         | 1             | 1      | 1    | 1      | 1             | 1        | 1         | 1            |
|        |         |         | P97           | P96    | P95  | P94    | P93           | P92      | P91       | P90          |
| P9     | Port9   | 19H     | R/W           | R/W    |      |        | ,             | Note 3)  |           |              |
|        | (Note2) |         | Output        | Output |      |        | Input         | mode     |           |              |
|        |         |         | mode          | mode   |      | ,      | ,             |          | 1 4       |              |
|        |         |         | <u>1</u>      | 1      | 1    | 1      | 1             | 1        | 1         | 1            |
| PA     | PortA   | 1EH     | PA7           | PA6    | PA5  | PA4    | PA3           | PA2      | PA1       | PA0          |
| F-A    | FULA    | I IEH   |               |        |      |        | W             |          |           |              |
|        |         |         |               |        |      |        | mode<br>1     |          |           |              |
|        |         |         | 1             |        |      |        |               |          |           |              |

Note 1: When P30 pin is defined as  $\overline{RD}$  signal output mode (P30F = 1), clearing the output latch register P30 to "0" outputs the  $\overline{RD}$  strobe from P30 pin for PSRAM, even when the internal address is accessed. If the output latch register P30 remains "1", the  $\overline{RD}$  strobe is output only when the external address is accessed.

Note 2: Port 96, 97 is also used as XT1, XT2. Therefore these pins are open-drain output type.

### Read/Write

R/W: Either read or write is possible

R: Only read is possible
W: Only write is possible
Prohibit RMW: Prohibit read-modify-write.

 $(Prohibit\ RES/SET/TSET/CHG/STCF/ANDCF/ORCF/XORCF\ instruction.)$ 

Note 3: \*R/W: Read-modify-write is prohibited when controlling the PU/PD resistors.

(2) I/O port control (1/2)

| Symbol | Name     | Address   | 7       | 6            | 5            | 4                                                                                   | 3             | 2           | 1            | 0       |
|--------|----------|-----------|---------|--------------|--------------|-------------------------------------------------------------------------------------|---------------|-------------|--------------|---------|
|        |          |           | P07C    | P06C         | P05C         | P04C                                                                                | P03C          | P02C        | P01C         | P00C    |
| P0CR   | Port 0   | 02H       |         |              |              | V                                                                                   | ٧             |             |              |         |
|        | control  | (Prohibit | 0       | 0            | 0            | 0                                                                                   | 0             | 0           | 0            | 0       |
|        |          | RMW)      | 0: Ir   | nput 1: Outp | out (When ex | kternal acces                                                                       | ss, set as Al | D7 to AD0 a | nd cleared t | o 0.)   |
|        |          |           | P17C    | P16C         | P15C         | P14C                                                                                | P13C          | P12C        | P11C         | P10C    |
| P1CR   | Port 1   | 04H       |         |              |              | V                                                                                   | ٧             |             |              |         |
|        | control  | (Prohibit | 0       | 0            | 0            | 0                                                                                   | 0             | 0           | 0            | 0       |
|        |          | RMW)      |         |              |              | < <refer td="" to<=""><td>the P1FC&gt;&gt;</td><td>1</td><td></td><td></td></refer> | the P1FC>>    | 1           |              |         |
|        |          |           | P17F    | P16F         | P15F         | P14F                                                                                | P13F          | P12F        | P11F         | P10F    |
| P1FC   | Port 1   | 05H       |         |              | _            | V                                                                                   | V             |             |              |         |
|        | function | (Prohibit | 0       | 0            | 0            | 0                                                                                   | 0             | 0           | 0            | 0       |
|        |          | RMW)      |         | P1FC/P1C     | CR = 00: Inp | ut 01: Outpu                                                                        | ut 10: AD15   | to AD8 11:  | : A15 to A8  |         |
|        |          |           | P27C    | P26C         | P25C         | P24C                                                                                | P23C          | P22C        | P21C         | P20C    |
| P2CR   | Port 2   | 08H       |         |              |              | V                                                                                   | V             |             |              |         |
|        | control  | (Prohibit | 0       | 0            | 0            | 0                                                                                   | 0             | 0           | 0            | 0       |
|        |          | RMW)      |         |              | _            | < <refer td="" to<=""><td>the P2FC&gt;&gt;</td><td></td><td></td><td></td></refer>  | the P2FC>>    |             |              |         |
|        |          |           | P27F    | P26F         | P25F         | P24F                                                                                | P23F          | P22F        | P21F         | P20F    |
| P2FC   | Port 2   | 09H       |         |              |              | V                                                                                   | V             |             |              |         |
|        | function | (Prohibit | 0       | 0            | 0            | 0                                                                                   | 0             | 0           | 0            | 0       |
|        |          | RMW)      |         | P2FC/P2      | 2CR = 00: In | put 01: Out                                                                         | put 10: A7 t  | o A0 11: A2 | 23 to A16    |         |
|        |          |           | P37C    | P36C         | P35C         | P34C                                                                                | P33C          | P32C        |              |         |
| P3CR   | Port 3   | 0AH       |         |              | . \          | V                                                                                   |               |             |              |         |
|        | control  | (Prohibit | 0       | 0            | 0            | 0                                                                                   | 0             | 0           |              |         |
|        |          | RMW)      |         | 0            | : Input      | 1: Outp                                                                             | ut            |             |              |         |
|        |          |           | P37F    | P36F         | P35F         | P34F                                                                                |               | P32F        | P31F         | P30F    |
| P3FC   | Port 3   | 0BH       |         | ١            | N            |                                                                                     |               |             | W            |         |
|        | function | (Prohibit | 0       | 0            | 0            | 0                                                                                   |               | 0           | 0            | 0       |
|        |          | RMW)      | 0: Port | 0: Port      | 0: Port      | 0: Port                                                                             |               | 0: Port     | 0: Port      | 0: Port |
|        |          |           | 1: RAS  | 1: R/W       | 1: BUSAK     | 1: BUSRQ                                                                            |               | 1: HWR      | 1: WR        | 1: RD   |
|        |          |           |         |              |              |                                                                                     |               | P42C        | P41C         | P40C    |
| P4CR   | Port 4   | 0EH       |         |              |              |                                                                                     |               |             | W            | 1       |
|        | control  | (Prohibit |         |              |              |                                                                                     |               | 0           | 0            | 0       |
|        |          | RMW)      |         |              |              |                                                                                     |               | 0: In       | put 1: 0     | utput   |
|        |          | 10H       |         |              |              |                                                                                     |               | P42F        | P41F         | P40F    |
| P4FC   | Port 4   | (Prohibit |         |              |              |                                                                                     |               |             | W            | 1       |
|        | function | RMW)      |         |              |              |                                                                                     |               | 0           | 0            | 0       |
|        |          |           |         |              |              |                                                                                     |               | 0: Poi      | rt 1: CS     | / CAS   |

Note: With the TMP93CS41, which requires an external ROM, port 0 functions as AD0 to AD7; port 1, AD8 to AD15 or A8 to A15; P30, the  $\overline{\text{RD}}$  signal; P31, the  $\overline{\text{WR}}$  signal, regardless of the values set in P0CR, P1CR, P1FC, P30F, and P31F.

# I/O port control (2/2)

| Symbol | Name            | Address           | 7             | 6       | 5          | 4        | 3              | 2              | 1          | 0       |
|--------|-----------------|-------------------|---------------|---------|------------|----------|----------------|----------------|------------|---------|
|        |                 |                   | P67C          | P66C    | P65C       | P64C     | P63C           | P62C           | P61C       | P60C    |
| P6CR   | Port 6          | 14H               |               |         |            | ١        | N              |                |            |         |
|        | control         | (Prohibit         | 0             | 0       | 0          | 0        | 0              | 0              | 0          | 0       |
|        |                 | RMW)              |               |         |            | ): Input | 1: Outp        | ut             |            |         |
|        |                 |                   |               |         |            |          | P73C           | P72C           | P71C       | P70C    |
| P7CR   | Port 7          | 15H               |               |         |            |          |                | ١              | N          | _       |
|        | control         | (Prohibit         |               |         |            |          | 0              | 0              | 0          | 0       |
|        |                 | RMW)              |               |         |            |          |                | 0: Input       | 1: Output  |         |
|        |                 |                   | P67F          | P66F    | P65F       | P64F     | P63F           | P62F           | P61F       | P60F    |
| P6FC   | Port 6          | 16H               |               | 1       |            | ١        | N              | 1              |            |         |
|        | function        | (Prohibit         | 0             | 0       | 0          | 0        | 0              | 0              | 0          | 0       |
|        |                 | RMW)              | 0:            | Port    | 1: PG1 out | put      | 0:             | Port           | 1: PG0 out | put     |
|        |                 |                   | $ \ge $       |         |            |          | P73F           | P72F           | P71F       |         |
| P7FC   | Port 7          | 17H               |               |         |            |          |                | W              |            |         |
|        | function        | (Prohibit         |               |         |            |          | 0              | 0              | 0          |         |
|        |                 | RMW)              |               |         |            |          | 0: Port        | 0: Port        | 0: Port    |         |
|        |                 |                   |               |         |            |          | 1: TO3         | 1: TO2         | 1: TO1     |         |
|        |                 |                   | P87C          | P86C    | P85C       | P84C     | P83C           | P82C           | P81C       | P80C    |
| P8CR   | Port 8          | 1AH               |               | 1       |            | 1        | N              | 1              |            |         |
|        | control         | (Prohibit         | 0             | 0       | 0          | 0        | 0              | 0              | 0          | 0       |
|        |                 | RMW)              |               | 1       |            | : Input  | 1: Outp        |                |            |         |
|        |                 |                   | P97C          | P96C    | P95C       | P94C     | P93C           | P92C           | P91C       | P90C    |
| P9CR   | Port 9          | 1BH               | W             | W       |            |          | 1              | N<br>I         |            |         |
|        | control         | (Prohibit<br>RMW) | 1             | 1       | 0          | 0        | 0              | 0              | 0          | 0       |
|        |                 | KIVIVV)           |               |         | 0          | : Input  | 1: Outp        |                |            |         |
| DOFO   | D 0             | 4011              | $\overline{}$ | P86F    |            |          | P83F           | P82F           |            |         |
| P8FC   | Port 8 function | 1CH<br>(Prohibit  | $\overline{}$ | W       |            |          | W              | W              |            |         |
|        | Turiction       | RMW)              |               | 0       |            |          | 0              | 0              |            |         |
|        |                 | TXIVIVV)          |               | 0: Port |            |          | 0: Port        | 0: Port        |            |         |
|        | 1               |                   |               | 1: TO6  | P95F       |          | 1: TO5<br>P93F | 1: TO4<br>P92F |            | P90F    |
| P9FC   | Port 9          | 1DH               | $\overline{}$ |         | W P95F     |          | W P93F         | P92F<br>W      |            | W P90F  |
| 1310   | function        | (Prohibit         | $\overline{}$ |         | 0          |          | 0              | 0              |            | 0       |
|        | - anotion       | RMW)              |               |         | 0: Port    |          | 0: Port        | 0: Port        |            | 0: Port |
|        |                 | ,                 |               |         | 1: SCLK1   |          | 1: TXD1        | 1: SCLK0       |            | 1: TXD0 |
|        | 1               |                   | PA7C          | PA6C    | PA5C       | PA4C     | PA3C           | PA2C           | PA1C       | PA0C    |
| PACR   | Port A          | 1FH               | 1 7/10        | 1 700   | 1 430      |          | N FASC         | TAZO           | TAIC       | 1 400   |
| 17.010 | control         | (Prohibit         |               |         |            |          | 0              |                |            |         |
|        |                 | RMW)              |               |         |            | ): Input | 1: Outp        | ıt             |            |         |
|        | L               | ,                 |               |         | · ·        | mpat     | i. Guipi       | a1.            |            |         |

## (3) Timer control (1/3)

| Symbol   | Name            | Address           | 7      | 6                    | 5                                            | 4            | 3                   | 2        | 1                              | 0           |
|----------|-----------------|-------------------|--------|----------------------|----------------------------------------------|--------------|---------------------|----------|--------------------------------|-------------|
|          |                 |                   | PRRUN  |                      | T5RUN                                        | T4RUN        | P1RUN               | P0RUN    | T1RUN                          | T0RUN       |
|          |                 |                   | R/W    |                      |                                              |              | R                   | W        | _                              |             |
| TRUN     | Timer           | 20H               | 0      |                      | 0                                            | 0            | 0                   | 0        | 0                              | 0           |
| 11(01)   | control         | 2011              |        |                      | Prescal                                      | er and timer | run/stop co         | ntrol    |                                |             |
|          |                 |                   |        |                      |                                              | 0: Stop and  | dclear              |          |                                |             |
|          |                 |                   |        |                      |                                              | 1: Run (Co   | unt up)             |          |                                |             |
|          | 8-bit           | 22H               |        |                      |                                              | -            |                     |          |                                |             |
| TREG0    | timer           | (Prohibit         |        |                      |                                              | V            | V                   |          |                                |             |
|          | register 0      | RMW)              |        |                      |                                              | Unde         | efined              |          |                                |             |
|          | 8-bit           | 23H               |        |                      |                                              |              | _                   |          |                                |             |
| TREG1    | timer           | (Prohibit         |        |                      |                                              |              | V                   |          |                                |             |
|          | register 1      | RMW)              |        |                      |                                              |              | efined              |          | T                              |             |
|          |                 |                   | T10M1  | T10M0                | PWMM1                                        | PWMM0        | T1CLK1              | T1CLK0   | T0CLK1                         | T0CLK0      |
|          | 8-bit           |                   |        |                      | _                                            |              | V<br>I -            | _        | 1 _                            | _           |
| TMOD     | timer           | 24H               | 0      | 0                    | 0                                            | 0            | 0                   | 0        | 0                              | 0           |
| TMOD     | source<br>CLK & | (Prohibit<br>RMW) |        | bit timer            | 00: -                                        | 4            | 00: TO              |          | 00: TI0                        | •           |
|          | mode            | KIVIVV)           |        | bit timer<br>bit PPG | 01: 2 <sup>6</sup> -<br>10: 2 <sup>7</sup> - |              | 01: φT1<br>10: φT1  |          | 01: φT1                        |             |
|          | mode            |                   |        | bit PWM              | 10. 2 -                                      |              | 10. φ1 1<br>11: φT2 |          | 10: φT <sup>2</sup><br>11: φT1 |             |
|          |                 |                   | 11. 0  | DICT VVIVI           | 11.2                                         | DBEN         | TFF1C1              | TFF1C0   | TFF1IE                         | TFF1IS      |
|          |                 |                   |        |                      |                                              | R/W          |                     | V        |                                | W           |
|          | 8-bit           |                   |        |                      |                                              | 0            | 1                   | 1        | 0                              | 0           |
| TFFCR    | timer           | 25H               |        |                      |                                              | 1: Double    |                     | ert TFF1 | 1: TFF1                        | 0: Inverted |
|          | flip-flop       |                   |        |                      |                                              | buffer       | 01: Set             |          | invert                         | by timer    |
|          | control         |                   |        |                      |                                              | enable       |                     | ar TFF1  | enable                         | 0           |
|          |                 |                   |        |                      |                                              |              | 11: Doi             |          |                                |             |
|          | PWM             |                   |        |                      | •                                            |              | _                   |          | •                              |             |
| TREG2    | timer           | 26H               |        |                      | (R)/W (                                      | Can read do  | ouble buffer        | values.) |                                |             |
|          | register 2      |                   |        |                      |                                              | Unde         | efined              |          |                                |             |
|          | PWM             |                   |        |                      |                                              | -            | _                   |          |                                |             |
| TREG3    | timer           | 27H               |        |                      | (R)/W (                                      | Can read do  | ouble buffer        | values.) |                                |             |
|          | register 3      |                   |        |                      |                                              | Unde         | efined              |          |                                |             |
|          |                 |                   | FF2RD  | DB2EN                | <b>PWM0INT</b>                               | PWM0M        | T2CLK1              | T2CLK0   | PWM0S1                         | PWM0S0      |
|          |                 |                   | R      |                      |                                              |              | W                   |          |                                |             |
|          |                 | 28H               | _      | 0                    | 0                                            | 0            | 0                   | 0        | 0                              | 0           |
| POMOD    | PWM0            | (Prohibit         | TFF2   | 1: Double            | 0: Overflow                                  | 0: PWM       | 00: φP1             |          | 00: 2 <sup>6</sup> -           |             |
| 1 011102 | mode            | RMW)              | output | buffer               | interrupt                                    | mode         | 01: φP4             |          | 01: 27 -                       |             |
|          |                 | ,                 | value  | enable               | 1: Compare/                                  | 1: Timer     | 10: φP1             | 6        | 10: 2 <sup>8</sup> -           | - 1         |
|          |                 |                   |        |                      | match                                        | mode         | 11: Doi             | n't care | 11: Do                         | n't care    |
|          | -               |                   |        |                      | interrupt                                    |              |                     |          |                                |             |
|          |                 |                   | FF3RD  | DB3EN                | PWM1INT                                      | PWM1M        | T3CLK1              | T3CLK0   | PWM1S1                         | PWM1S0      |
|          |                 |                   | R      | _                    | _                                            |              | W                   |          | 1 -                            |             |
|          | DVVVV4          | 29H               |        | 0                    | 0                                            | 0            | 0                   | 0        | 0                              | 0           |
| P1MOD    | PWM1            | (Prohibit         | TFF3   | 1: Double            | 0: Overflow                                  | 0: PWM       | 00: φP1             |          | 00: 2 <sup>6</sup> -           |             |
|          | mode            | RMW)              | output | buffer               | interrupt                                    | mode         | 01: φP4             |          | 01: 2 <sup>7</sup> -           |             |
|          |                 |                   | value  | enable               | 1: Compare/                                  | 1: Timer     | 10: φP1             |          | 10: 2 <sup>8</sup> -           |             |
|          |                 |                   |        |                      | match                                        | mode         | 11: Doi             | ı ı care | 11: Do                         | ıı care     |
|          |                 |                   |        |                      | interrupt                                    | ]            |                     |          |                                |             |

## Timer control (2/3)

| Symbol   | Name                    | Address             | 7                 | 6                 | 5                 | 4                 | 3                   | 2                 | 1                   | 0             |
|----------|-------------------------|---------------------|-------------------|-------------------|-------------------|-------------------|---------------------|-------------------|---------------------|---------------|
|          |                         |                     | FF3C1             | FF3C0             | FF3TRG1           | FF3TRG0           | FF2C1               | FF2C0             | FF2TRG1             | FF2TRG0       |
|          |                         |                     | ١                 | N                 | R/                | W                 | V                   | V                 | R/                  | W             |
|          |                         |                     | 1                 | 1                 | 0                 | 0                 | 1                   | 1                 | 0                   | 0             |
|          | PWM                     |                     | 00: Do            | n't care          | 00: Prohib        | it TFF3           | 00: Do              | n't care          | 00: Prohib          | t TFF2        |
| PFFCR    | flip-flop               | 2AH                 | 01: Se            | t TFF3            | invert            |                   | 01: Se              | t TFF2            | invert              |               |
|          | control                 | _,                  | 10: Cle           | ear TFF3          | 01: Invert i      | f matched         | 10: Cle             | ear TFF2          | 01: Invert i        | f matched     |
|          |                         |                     | 11: Do            | n't care          | 10: Set if n      |                   | 11: Do              | n't care          | 10: Set if n        | ,             |
|          |                         |                     |                   |                   |                   | overflow          |                     |                   |                     | overflow      |
|          |                         |                     |                   |                   | 11: Clear i       | ,                 |                     |                   | 11: Clear if        | ,             |
|          | 10 hit time au          | 0011                |                   |                   | set if o          | verflow           |                     |                   | set if o            | verflow       |
| TREG4L   | 16-bit timer register 4 | 30H<br>(Prohibit    |                   |                   |                   | -                 | <br>V               |                   |                     |               |
| IKEG4L   | low                     | (Profilibit<br>RMW) |                   |                   |                   |                   |                     |                   |                     |               |
|          | 16-bit timer            | 31H                 |                   |                   |                   | Unde              | efined              |                   |                     |               |
| TREG4H   | register 4              | (Prohibit           |                   |                   |                   |                   | <br>V               |                   |                     |               |
| INLU4FI  | high                    | (Profilibit<br>RMW) |                   |                   |                   |                   | efined              |                   |                     |               |
|          | 16-bit timer            | 32H                 |                   |                   |                   | - Office          | -                   |                   |                     |               |
| TREG5L   | register 5              | 3211<br>(Prohibit   |                   |                   |                   | \ <u></u>         | <br>V               |                   |                     |               |
| 1112002  | low                     | RMW)                |                   |                   |                   |                   | efined              |                   |                     |               |
|          | 16-bit timer            | 33H                 |                   |                   |                   | -                 | -                   |                   |                     |               |
| TREG5H   | register 5              | (Prohibit           |                   |                   |                   | V                 | V                   |                   |                     |               |
|          | high                    | RMW)                |                   |                   |                   | Unde              | efined              |                   |                     |               |
|          | Capture                 |                     |                   |                   |                   |                   | _                   |                   |                     |               |
| CAP1L    | register 1              | 34H                 |                   |                   |                   | F                 | ₹                   |                   |                     |               |
|          | low                     |                     |                   |                   |                   | Unde              | efined              |                   |                     |               |
|          | Capture                 |                     |                   |                   |                   | -                 | _                   |                   |                     |               |
| CAP1H    | register 1              | 35H                 |                   |                   |                   | F                 | ₹                   |                   |                     |               |
|          | high                    |                     |                   |                   |                   | Unde              | efined              |                   |                     |               |
|          | Capture                 |                     |                   |                   |                   | -                 |                     |                   |                     |               |
| CAP2L    | register 2              | 36H                 |                   |                   |                   |                   | 7                   |                   |                     |               |
|          | low                     |                     |                   |                   |                   | Unde              | efined              |                   |                     |               |
| 0.4.00.4 | Capture                 | 0=11                |                   |                   |                   | -                 |                     |                   |                     |               |
| CAP2H    | register 2              | 37H                 |                   |                   |                   |                   | <del>?</del>        |                   |                     |               |
|          | high                    |                     | CARCTE            | FOSTS             | CADAIN            |                   | efined              | OL F              | T401144             | T4011/0       |
|          |                         |                     | CAP2T5            | EQ5T5             | CAP1IN            | CAP12M1           | CAP12M0             | CLE               | T4CLK1              | T4CLK0        |
|          |                         |                     |                   | W<br>I o          | W                 | 0                 | 0                   | R/W               | _                   | 0             |
|          | 16-bit                  |                     | 0<br>TFF5 IN      | V TRG             | 1<br>0: Soft-     | 0<br>Capture t    |                     | 0<br>1: UC4       | 0<br>Source         |               |
| THIOD    | timer 4                 | 0011                | 0: TRG            | disable           | ware              | 00: Disab         | le                  | clear             | 00: T14             |               |
| T4MOD    | source CLK              | 38H                 | 1: TRG            |                   | capture           |                   | ↑ T15 ↑             | enable            | 01: φT1             |               |
|          | and mode                |                     | Inverted when the | Inverted when the | 1: Don't care     |                   | ↑ T14 ↓<br>↑ TFF1 ↓ |                   | 10: φT4<br>11: φT10 | 3             |
|          |                         |                     | UC value          | up counter        | Jaro              |                   | , · •               |                   | Ι ψ                 |               |
|          |                         |                     | is latched        | matches           |                   |                   |                     |                   |                     |               |
|          |                         |                     | to CAP2           | TREG5             |                   |                   |                     |                   |                     |               |
|          |                         |                     | TFF5C1            | TFF5C0            | CAP2T4            | CAP1T4            | EQ5T4               | EQ4T4             | TFF4C1              | TFF4C0        |
|          |                         |                     |                   | N<br>  1          | 0                 |                   | W<br>L              | 0                 | V                   |               |
|          | 16-bit                  |                     | 00: Inve          | rt TFF5           | 0                 | 0<br>TFF4 inv     | ert trigger         | 0                 | 1<br>00: Inve       | 1<br>ert TFF4 |
| T45505   | timer 4                 | 0611                | 01: Set           |                   |                   | 0: Trigge         |                     |                   | 01: Set             |               |
| T4FFCR   | flip-flop               | 39H                 |                   | ar TFF5           |                   | 1: Trigge         |                     |                   | 10: Clea            |               |
|          | control                 |                     | 11: Dor           | rt care           | Inverted when the | Inverted when the | Inverted when the   | Inverted when the | 11: Don             | t care        |
|          |                         |                     |                   |                   | UC value          | UC value          | UC value            | UC value          |                     |               |
|          |                         |                     |                   |                   | is latched        | is latched        | matches             | matches           |                     |               |
|          |                         |                     |                   |                   | to CAP2           | to CAP1           | TREG5               | TREG4             |                     |               |

## Timer control (3/3)

| Symbol | Name               | Address   | 7        | 6 | 5             | 4             | 3                 | 2             | 1           | 0         |
|--------|--------------------|-----------|----------|---|---------------|---------------|-------------------|---------------|-------------|-----------|
|        |                    |           | QCU      |   |               |               | PG1T              | PG0T          | DB6EN       | DB4EN     |
|        |                    |           | R/W      |   |               |               |                   | R/            | W           |           |
|        |                    |           | 0        |   |               |               | 0                 | 0             | 0           | 0         |
| T45CR  | T4, T5             | 3AH       | Watchdog |   |               |               | PG1 shift         | PG0 shift     | 1: Double b | uffer     |
| 145CR  | control            | ЗАП       | /warm-up |   |               |               | trigger           | trigger       | enable      |           |
|        |                    |           | timer    |   |               |               | 0: Timer 0, 1     | 0: Timer 0, 1 | Double      | Double    |
|        |                    |           | control  |   |               |               | 1: Timer 5        | 1: Timer 4    | buffer of   | buffer of |
|        |                    |           |          |   |               |               |                   |               | TREG6       | TREG4     |
|        | 16-bit timer       | 40H       |          |   |               |               | _                 |               |             |           |
| TREG6L | register 6         | (Prohibit |          |   |               | 1             | W                 |               |             |           |
|        | low                | RMW)      |          |   |               | Unde          | efined            |               |             |           |
|        | 16-bit timer       | 41H       |          |   |               |               | _                 |               |             |           |
| TREG6H | register 6         | (Prohibit |          |   |               | ١             | W                 |               |             |           |
|        | high               | RMW)      |          |   |               | Unde          | efined            |               |             |           |
|        | 16-bit timer       | 42H       |          |   |               |               | _                 |               |             |           |
| TREG7L | register 7         | (Prohibit |          |   |               | \             | W                 |               |             |           |
|        | low                | RMW)      |          |   |               | Unde          | efined            |               |             |           |
|        | 16-bit timer       | 43H       |          |   |               |               |                   |               |             |           |
| TREG7H | register 7         | (Prohibit |          |   |               |               | W                 |               |             |           |
|        | high               | RMW)      |          |   |               | Unde          | efined            |               |             |           |
|        | Capture            |           |          |   |               |               | _                 |               |             |           |
| CAP3L  | register 3         | 44H       |          |   |               |               | R                 |               |             |           |
|        | low                |           |          |   |               | Unde          | efined            |               |             |           |
|        | Capture            |           |          |   |               |               | _                 |               |             |           |
| CAP3H  | register 3         | 45H       |          |   |               |               | R                 |               |             |           |
|        | high               |           |          |   |               | Unde          | efined            |               |             |           |
|        | Capture            |           |          |   |               |               | _                 |               |             |           |
| CAP4L  | register 4         | 46H       |          |   |               |               | R                 |               |             |           |
|        | low                |           |          |   |               |               | efined            |               |             |           |
| CAP4H  | Capture            | 4711      |          |   |               |               | <u> </u>          |               |             |           |
| CAP4H  | register 4<br>high | 47H       |          |   |               |               | R                 |               |             |           |
|        | riigii             |           |          |   | CAP3IN        |               | efined<br>CAP34M0 | CLE           | TECL K4     | TECLICO   |
|        |                    |           |          |   | W             | CAP34WH       | CAP34IVIU         |               | T5CLK1      | T5CLK0    |
|        | 16-bit             |           |          |   | 1             | 0             | 0                 | R/W<br>0      | 0           | 0         |
|        | timer 5            |           |          |   | 0: Soft       | Capture t     |                   | 1: UC5        | Source      |           |
| T5MOD  | source CLK         | 48H       |          |   | capture       | 00: Disab     | -                 | clear         | 00: T16     | CIOCK     |
|        | and mode           |           |          |   | 1: Don't      | 01: T16       | ↑ T17 ↑           | enable        | 01: φT1     |           |
|        |                    |           |          |   | care          | 10: T16       | ↑ T16 ↓           | 3113.313      | 10: φT4     |           |
|        |                    |           |          |   |               | 11: TFF1      |                   |               | 11: φT10    | 6         |
|        |                    |           |          |   | CAP4T6        | CAP3T6        | EQ7T6             | EQ6T6         | TFF6C1      | TFF6C0    |
|        |                    |           |          |   |               | R             | /W                |               | V           | V         |
|        |                    |           |          |   | 0             | 0             | 0                 | 0             | 1           | 1         |
|        | 16-bit             |           |          |   |               | TFF6 inv      | ert trigger       |               | 00: Inve    |           |
|        | timer 5            |           |          |   |               |               | er disable        |               | 01: Set     |           |
| T5FFCR | flip-flop          | 49H       |          |   |               |               | er enable         | T             | 10: Clea    |           |
|        | control            |           |          |   | Inverted when | Inverted when | Inverted when     | Inverted when | 11: Don     | 't care   |
|        |                    |           |          |   | the UC        | the UC        | the UC            | the UC        |             |           |
|        |                    |           |          |   | value is      | value is      | value             | value         |             |           |
|        |                    |           |          |   | latched       | latched       | matches           | matches       |             |           |
|        | ĺ                  |           |          |   | to CAP4       | to CAP3       | TREG7             | TREG6         |             |           |

# (4) Pattern generator

| Symbol  | Name     | Address   | 7        | 6          | 5        | 4         | 3        | 2          | 1        | 0         |
|---------|----------|-----------|----------|------------|----------|-----------|----------|------------|----------|-----------|
|         | PG0      | 4CH       | PG03     | PG02       | PG01     | PG00      | SA03     | SA02       | SA01     | SA00      |
| PG0REG  |          | (Prohibit |          | V          | V        |           |          | R/         | W        |           |
|         | register | RMW)      | 0        | 0          | 0        | 0         |          | Unde       | fined    |           |
|         | DO4      | 4DH       | PG13     | PG12       | PG11     | PG10      | SA13     | SA12       | SA11     | SA10      |
| PG1REG  | PG1      | (Prohibit |          | V          | V        |           |          | R/         |          |           |
|         | register | RMW)      | 0        | 0          | 0        | 0         |          | Unde       | fined    |           |
|         |          |           | PAT1     | CCW1       | PG1M     | PG1TE     | PAT0     | CCW0       | PG0M     | PG0TE     |
|         |          |           |          |            |          | R         | W        |            |          |           |
|         |          |           | 0        | 0          | 0        | 0         | 0        | 0          | 0        | 0         |
| PG01CR  | PG0, 1   | 4EH       | 0: 8-bit | 0: Normal  | 0: 4-bit | PG1       | 0: 8-bit | 0: Normal  | 0: 4-bit | PG0       |
| FOULCIX | control  | 4611      | write    | rotation   | step     | trigger   | write    | rotation   | step     | trigger   |
|         |          |           | 1: 4-bit | 1: Reverse | 1: 8-bit | input     | 1: 4-bit | 1: Reverse | 1: 8-bit | input     |
|         |          |           | write    | rotation   | step     | enable    | write    | rotation   | step     | enable    |
|         |          |           |          |            |          | 1: Enable |          |            |          | 1: Enable |

# (5) Watchdog timer

| Symbol | Name                                     | Address | 7                | 6                                                                                                                                                            | 5        | 4                                                                                                         | 3                        | 2            | 1                                                      | 0                                         |
|--------|------------------------------------------|---------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------|--------------------------|--------------|--------------------------------------------------------|-------------------------------------------|
|        |                                          |         | WDTE             | WDTP1                                                                                                                                                        | WDTP0    | WARM                                                                                                      | HALTM1                   | HALTM0       | RESCR                                                  | DRVE                                      |
|        |                                          |         |                  |                                                                                                                                                              |          | R                                                                                                         | W                        |              |                                                        |                                           |
|        |                                          |         | 1                | 0                                                                                                                                                            | 0        | 0                                                                                                         | 0                        | 0            | 0                                                      | 0                                         |
| WDMOD  | Watchdog<br>timer<br>mode                | 5CH     | 1: WDT<br>enable | 00: 2 <sup>15</sup> /f <sub>SY</sub><br>01: 2 <sup>17</sup> /f <sub>SY</sub><br>10: 2 <sup>19</sup> /f <sub>SY</sub><br>11: 2 <sup>21</sup> /f <sub>SY</sub> | rs<br>rs | Warm-up<br>time<br>0: 2 <sup>14</sup> /inputted<br>frequency<br>1: 2 <sup>16</sup> /inputted<br>frequency | 10: IDLI                 | •            | 1: Connect<br>internally<br>WDT out<br>to reset<br>pin | 1: Drive<br>the pin<br>in<br>STOP<br>mode |
| WDCR   | Watchdog<br>timer<br>control<br>register | 5DH     |                  |                                                                                                                                                              | B1H: WDT | V<br>disable code                                                                                         | -<br>V<br>-<br>e 4EH: WD | T clear code | )                                                      |                                           |

## (6) Serial channel

| Symbol | Name              | Address | 7                 | 6             | 5                 | 4                 | 3                       | 2            | 1                         | 0          |
|--------|-------------------|---------|-------------------|---------------|-------------------|-------------------|-------------------------|--------------|---------------------------|------------|
|        | Serial            |         | RB7<br>TB7        | RB6<br>TB6    | RB5<br>TB5        | RB4<br>TB4        | RB3<br>TB3              | RB2<br>TB2   | RB1<br>RB1                | RB0<br>TB0 |
| SC0BUF | channel 0         | 50H     |                   |               |                   | Receiving)/M      |                         |              |                           | .20        |
|        | buffer            |         |                   |               | •                 | Unde              | efined                  | •            |                           |            |
|        |                   |         | RB8               | EVEN          | PE                | OERR              | PERR                    | FERR         | SCLKS                     | IOC        |
|        |                   |         | R                 | R             | W                 | R (Clea           | red to 0 by             | reading)     | R                         | W          |
|        | Serial            |         | Undefined         | 0             | 0                 | 0                 | 0                       | 0            | 0                         | 0          |
| SC0CR  | channel 0         | 51H     | Receiving         | Parity        | 1: Parity         |                   | 1: Error                | ı            | 0: SCLK0                  | 1: Input   |
|        | control           |         | data bit8         | 0: Odd        | enable            | Overrun           | Parity                  | Framing      |                           | SCLK0      |
|        |                   |         |                   | 1: Even       |                   |                   |                         |              | 1: SCLK0                  | pin        |
|        |                   |         | TB8               | CTSE          | RXE               | WU                | SM1                     | SM0          | SC1                       | SC0        |
|        |                   |         |                   |               |                   |                   | /W                      |              |                           |            |
| CCOMOD | Serial            | 5011    | Undefined         | 0             | 0                 | 0                 | 0<br>00: I/O Int        | 0<br>erface  | 0<br>00: TO0 ti           | 0<br>igger |
| SC0MOD | channel 0<br>mode | 52H     | Transmission      | 1: CTS enable | 1: Receive enable |                   | 01: UART                |              | 00: 100 ti                | 00         |
|        | mode              |         | data bit8         | enable        | enable            | up<br>enable      | 10: UART                |              | genera                    |            |
|        |                   |         |                   |               |                   | CHADIC            | 11: UART                | 9 bits       | 10: Internation 11: Don't |            |
|        |                   |         | _                 |               | BR0CK1            | BR0CK0            | BR0S3                   | BR0S2        | BR0S1                     | BR0S0      |
|        |                   |         | R/W               |               | BIKOOKI           | Bitooito          |                         | W            | DIXOUT                    | Dittoco    |
|        | Baud rate         |         | 0                 |               | 0                 | 0                 | 0                       | 0            | 0                         | 0          |
| BR0CR  | control           | 53H     | Always            |               | 00: 0             | •                 |                         |              | •                         | •          |
|        |                   |         | fixed to 0        |               | 01: 0             | •                 | S                       |              | y divisor 0 to            | F          |
|        |                   |         |                   |               | 10: d<br>11: d    | րτο<br>∮T32       |                         | ("1" pro     | ohibited)                 |            |
|        | Serial            |         | RB7               | RB6           | RB5               | RB4               | RB3                     | RB2          | RB1                       | RB0        |
| SC1BUF | channel 1         | 54H     | TB7               | TB6           | TB5               | TB4               | TB3                     | TB2          | RB1                       | TB0        |
| 001201 | buffer            | 0111    |                   |               | R (F              | Receiving)/M      |                         | sion)        |                           |            |
|        |                   |         | DDO               | E)/EN         | DE                |                   | efined                  | FEDD         | 00110                     | 100        |
|        |                   |         | RB8<br>R          | EVEN          | PE<br>W           | OERR<br>P. (Close | PERR<br>red to 0 by     | FERR         | SCLKS                     | IOC<br>W   |
|        | Serial            |         | Undefined         | 0             | 0                 | 0                 | 0                       | 0            | 0                         | 0          |
| SC1CR  | channel 1         | 55H     | Receiving         | Parity        | 1: Parity         |                   | 1: Error                |              | 0:SCLK1                   | 1: Input   |
|        | control           |         | data bit8         | 0: Odd        | enable            | Overrun           | Parity                  | Framing      |                           | SCLK1      |
|        |                   |         |                   | 1: Even       |                   |                   |                         |              | 1: SCLK1                  | pin        |
|        |                   |         | TB8               | _             | RXE               | WU                | SM1                     | SM0          | SC1                       | SC0        |
|        |                   |         |                   |               |                   | R/                | W                       |              | _                         |            |
|        | Serial            |         | 0                 | 0             | 0                 | 0                 | 0                       | 0            | 0                         | 0          |
| SC1MOD | channel 1         | 56H     | Transmission      | Always        | 1: Receive        | 1: Wake           | 00: I/O int<br>01: UART |              | 00: TO0 T<br>01: Baud     |            |
|        | mode              |         | data bit8         | fixed to 0    | enable            | up<br>            | 10: UART                |              | genera                    |            |
|        |                   |         |                   |               |                   | enable            | 11: UART                | 9 bits       | 10: Interna               |            |
|        |                   |         |                   |               | DD 10:11          | DE (C):-          | DD 16-                  | DD 12-       | 11: Don't                 |            |
|        |                   |         | -<br>DAM          |               | BR1CK1            | BR1CK0            | BR1S3                   | BR1S2        | BR1S1                     | BR1S0      |
|        | D 1               |         | R/W               |               | 0                 | _                 |                         | W<br>I o     |                           | 0          |
| BR1CR  | Baud rate         | 57H     | 0<br>Always       |               | 0 00: 0           | 0<br>bT0          | 0                       | 0            | 0                         | 0          |
|        | control           |         | Always fixed to 0 |               | 01: 0             | ,<br>þT2          | s                       | et frequency | y divisor 0 to            | F          |
|        |                   |         | lixed to 0        |               | 10: d<br>11: d    | ∳Т8<br>∮Т32       |                         | ("1" pro     | ohibited)                 |            |
|        |                   |         |                   |               |                   |                   |                         |              | ODE1                      | ODE0       |
|        | Serial            |         |                   |               |                   |                   |                         |              | R/                        | W          |
| ODE    | open-             | 58H     |                   |               |                   |                   |                         |              | 0                         | 0          |
| ODE    | drain             | ЭОП     |                   |               |                   |                   |                         |              | 1: P93                    | 1: P90     |
|        | enable            |         |                   |               |                   |                   |                         |              | Open                      | Open       |
|        | 1                 |         | 1                 | 1             | 1                 |                   |                         | 1            | drain                     | drain      |

## (7) AD converter control

| Symbol   | Name       | Address | 7                                        | 6       | 5         | 4       | 3      | 2                    | 1           | 0         |  |  |
|----------|------------|---------|------------------------------------------|---------|-----------|---------|--------|----------------------|-------------|-----------|--|--|
|          | AD         |         | EOCF                                     | ADBF    | REPET     | SCAN    |        | ADS                  |             |           |  |  |
| ADMOD1   | mode       | 5EH     | F                                        | ?       | R/        | W       |        | R/W                  |             |           |  |  |
| ADIVIODI | register 1 | JEH     | 0                                        | 0       | 0         | 0       |        | 0                    |             |           |  |  |
|          | register i |         | 1: End                                   | 1: Busy | 1: Repeat | 1: Scan |        | 1: Start             |             |           |  |  |
|          |            |         | VREFON                                   |         | SPEED1    | SPEED0  |        | ADCH2                | ADCH1       | ADCH0     |  |  |
|          | AD         |         | R/W                                      |         | R         | W       |        |                      | R/W         |           |  |  |
| ADMOD2   | mode       | 5FH     | 1                                        |         | 0         | 0       |        | 0                    | 0           | 0         |  |  |
| ABINOBE  | register 2 | 0111    | Ladder<br>resistance<br>switch<br>ON/OFF |         | Speed     | select  |        | Analog               | input chann | el select |  |  |
| (Note 1) | AD result  |         | ADR01                                    | ADR00   |           |         |        |                      |             |           |  |  |
| AD       | register   | 60H     | F                                        | ₹       |           |         |        |                      |             |           |  |  |
| REG04L   | 0/4 low    |         | Unde                                     | efined  |           |         |        |                      |             |           |  |  |
| AD       | AD result  |         | ADR09                                    | ADR08   | ADR07     | ADR06   | ADR05  | ADR04                | ADR03       | ADR02     |  |  |
| REG04H   | register   | 61H     |                                          |         |           | F       | ₹      | ADR04   ADR03   ADR0 |             |           |  |  |
| KEG04H   | 0/4 high   |         |                                          |         |           | Unde    | fined  |                      |             |           |  |  |
| (Note 1) | AD result  |         | ADR11                                    | ADR10   |           |         |        |                      |             |           |  |  |
| AD       | register   | 62H     | F                                        | ₹       |           |         |        |                      |             |           |  |  |
| REG15L   | 1/5 low    |         | Unde                                     | efined  |           |         |        |                      |             |           |  |  |
| AD       | AD result  |         | ADR19                                    | ADR18   | ADR17     | ADR16   | ADR15  | ADR14                | ADR13       | ADR12     |  |  |
| REG15H   | register   | 63H     |                                          |         |           | F       | ₹      |                      |             |           |  |  |
| REOTOTT  | 1/5 high   |         |                                          | 1       |           | Unde    | fined  |                      |             |           |  |  |
| (Note 1) | AD result  |         | ADR21                                    | ADR20   |           |         |        |                      |             |           |  |  |
| AD       | register   | 64H     | F                                        | }       |           |         |        |                      |             |           |  |  |
| REG26L   | 2/6 low    |         | Unde                                     | efined  |           |         |        |                      |             |           |  |  |
| AD       | AD result  |         | ADR29                                    | ADR28   | ADR27     | ADR26   | ADR25  | ADR24                | ADR23       | ADR22     |  |  |
| REG26H   | register   | 65H     |                                          |         |           | F       | ₹      |                      |             |           |  |  |
|          | 2/6 high   |         |                                          | 1       |           | Unde    | fined  |                      |             |           |  |  |
| (Note 1) | AD result  |         | ADR31                                    | ADR30   |           |         |        |                      |             |           |  |  |
| AD       | register   | 66H     | F                                        | ₹       |           |         |        |                      |             |           |  |  |
| REG37L   | 3/7 low    |         |                                          | efined  |           |         |        |                      |             |           |  |  |
| AD       | AD result  |         | ADR39                                    | ADR38   | ADR37     | ADR36   | ADR35  | ADR34                | ADR33       | ADR32     |  |  |
| REG37H   | register   | 67H     |                                          |         |           |         | ₹      |                      |             |           |  |  |
|          | 3/7 high   |         |                                          |         |           | Unde    | efined |                      |             |           |  |  |

Note 1: Data to be stored in AD conversion result register low are the lower 2 bits of the conversion result. The contents of the lower 6 bits of this register are always read as "1".



# (8) Interrupt control (1/2)

| اء حامص  | Name =         | ۸۵۵۰۰۰      | 7             | -          |               | 4                                     | 2             | 2             | 4      |          |
|----------|----------------|-------------|---------------|------------|---------------|---------------------------------------|---------------|---------------|--------|----------|
| Symbol   | Name           | Address     | 7             | 6          | 5             | 4                                     | 3             | 2             | 1      | 0        |
|          | Interrupt      | 70H         |               |            | AD            | -                                     |               |               | T0     |          |
| INTE0AD  | enable         | (Prohibit   | IADC          | IADM2      | IADM1         | IADM0                                 | IOC           | I0M2          | I0M1   | I0M0     |
|          | 0 & AD         | RMW)        | R/W           |            | W             |                                       | R/W           |               | W      |          |
|          |                | ,           | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      | 0        |
|          | Interrupt      | 71H         |               |            | T5            |                                       |               |               | T4     |          |
| INTE45   | enable         | (Prohibit   | I5C           | I5M2       | I5M1          | I5M0                                  | I4C           | I4M2          | I4M1   | I4M0     |
|          | 4/5            | `RMW)       | R/W           |            | W             |                                       | R/W           |               | W      |          |
|          |                | ,           | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      | 0        |
|          | Interrupt      | 72H         |               |            | T7            |                                       |               |               | T6     |          |
| INTE67   | enable         | (Prohibit   | I7C           | I7M2       | I7M1          | 17M0                                  | I6C           | I6M2          | I6M1   | I6M0     |
|          | 6/7            | RMW)        | R/W           |            | W             |                                       | R/W           | _             | W      | _        |
|          |                |             | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      | 0        |
|          | Interrupt      | 73H         |               | ,          | Timer 1)      |                                       |               | INTTO (       | ,      |          |
| INTET10  | enable         | (Prohibit   | IT1C          | IT1M2      | IT1M1         | IT1M0                                 | IT0C          | IT0M2         | IT0M1  | IT0M0    |
|          | timer 1/0      | RMW)        | R/W           |            | W             |                                       | R/W           |               | W      |          |
|          |                |             | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      | 0        |
|          | Interrupt      | 74H         |               | ,          | er 3/PWM1)    |                                       |               | INTT2 (Tim    |        |          |
| INTEPW10 | •              | (Prohibit   | IPW1C         | IPW1M2     | IPW1M1        | IPW1M0                                | IPW0C         | IPW0M2        | IPW0M1 | IPW0M0   |
|          | PWM 1/0        | RMW)        | R/W           |            | W             |                                       | R/W           |               | W      |          |
|          |                |             | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      | 0        |
|          | Interrupt      | 75H         |               |            | (TREG5)       |                                       |               | INTTR4        | ·      |          |
| INTET54  | enable         | (Prohibit   | IT5C          | IT5M2      | IT5M1         | IT5M0                                 | IT4C          | IT4M2         | IT4M1  | IT4M0    |
|          | T register     | RMW)        | R/W           |            | W             |                                       | R/W           | _             | W      |          |
|          | 5/4            |             | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      | 0        |
|          | Interrupt      | 76H         |               | INTTR7     | · ·           |                                       |               | INTTR6        | ·      |          |
| INTET76  | enable         | (Prohibit   | IT7C          | IT7M2      | IT7M1         | IT7M0                                 | IT6C          | IT6M2         | IT6M1  | IT6M0    |
|          | T register 7/6 | RMW)        | R/W           |            | W             |                                       | R/W           |               | W      |          |
|          | 170            |             | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      |          |
|          | Interrupt      | 77H         | ITVOO         |            | TX0           | ITYONAO                               | IDVOO         | INT           |        | IDVOMO   |
| INTES0   | enable         | (Prohibit   | ITX0C         | ITX0M2     | ITX0M1        | ITX0M0                                | IRX0C         | IRX0M2        | IRX0M1 | IRX0M0   |
|          | serial 0       | RMW)        | R/W           | 0          | W             | 0                                     | R/W           | 0             | W      | 0        |
|          |                |             | 0             |            | 0             | 0                                     | 0             |               | 0      | 0        |
|          | Interrupt      | 78H         | ITX1C         | ITX1M2     | TX1<br>ITX1M1 | ITX1M0                                | IRX1C         | INT<br>IRX1M2 | IRX1M1 | IRX1M0   |
| INTES1   | enable         | (Prohibit   | R/W           | II A IIVIZ | W             | TIATIVIO                              | R/W           | IKA IIVIZ     | W      | IKATIVIO |
|          | serial 1       | RMW)        | 0             | 0          | 0             | 0                                     | 0             | 0             | 0      | 0        |
|          |                |             |               |            | U             | 0                                     |               |               | U      | U        |
|          |                |             | -             |            |               |                                       |               |               |        |          |
|          |                |             | 1             | T          |               |                                       |               | 1             |        |          |
|          | lxxM2          | lxxM1       | lxxM0         |            | Function      | on (Write)                            |               |               |        |          |
|          | 0              | 0           | 0             | Prohibit i | nterrupt req  | uest.                                 |               |               |        |          |
|          | 0              | 0           | 1             | Set inter  | rupt request  | level to "1".                         |               |               |        |          |
|          | 0              | 1           | 0             | Set inter  | rupt request  | level to "2".                         |               |               |        |          |
|          | 0              | 1           | 1             |            |               | level to "3".                         |               |               |        |          |
|          | 1              | 0           | 0             |            |               | level to "4".                         |               |               |        |          |
|          | 1              | 0           | 1             |            |               | level to "5".                         |               |               |        |          |
|          | 1              | 1           | 0             |            |               | level to "6".                         |               |               |        |          |
| L        | 1              | 1           | 1             | Prohibit i | nterrupt req  | uest.                                 |               | J             |        |          |
|          | IxxC           | F           | unction (F    | Read)      |               | Functi                                | ion (Write)   | )             |        |          |
|          | 0              | Indicate no | interrupt red | quest.     | Clea          | ır interrupt re                       | quest flag.   |               |        |          |
|          | 1              |             | errupt reque  |            |               | · · · · · · · · · · · · · · · · · · · | on't care – – |               |        |          |
| <u> </u> |                |             |               |            |               |                                       |               |               |        |          |

# Interrupt control (2/2)

| Symbol  | Name              | Address           | 7 | 6 | 5 | 4      | 3      | 2          | 1       | 0            |
|---------|-------------------|-------------------|---|---|---|--------|--------|------------|---------|--------------|
|         |                   | -011              |   |   |   |        | Micro  | DMA0 start | vector  |              |
| DMA0V   | DMA 0             | 7CH               |   |   |   | DMA0V4 | DMA0V3 | DMA0V2     | DMA0V1  | DMA0V0       |
| DIVIAUV | request<br>vector | (Prohibit<br>RMW) |   |   |   |        |        | W          |         |              |
|         | Vector            | IXIVIVV)          |   |   |   | 0      | 0      | 0          | 0       | 0            |
|         | DMA 1             | 7DH               |   |   |   |        | Micro  | DMA1 start | vector  |              |
| DMA1V   | request           | (Prohibit         |   |   |   | DMA1V4 | DMA1V3 | DMA1V2     | DMA1V1  | DMA1V0       |
| DIVIATV | vector            | RMW)              |   |   |   |        |        | W          |         |              |
|         | VCCtO             | TXIVIVY           |   |   |   | 0      | 0      | 0          | 0       | 0            |
|         | DMA 2             | 7EH               |   |   |   |        | Micro  | DMA2 start | vector  |              |
| DMA2V   | request           | (Prohibit         |   |   |   | DMA2V4 | DMA2V3 | DMA2V2     | DMA2V1  | DMA2V0       |
| DIVIAZV | vector            | RMW)              |   |   |   |        |        | W          |         |              |
|         | Vooloi            | 14,111            |   |   |   | 0      | 0      | 0          | 0       | 0            |
|         | DMA 3             | 7FH               |   |   |   |        | Micro  | DMA3 start | vector  |              |
| DMA3V   | request           | (Prohibit         |   |   |   | DMA3V4 | DMA3V3 | DMA3V2     | DMA3V1  | DMA3V0       |
| DIVIAGV | vector            | RMW)              |   |   |   |        | T      | W          | T       |              |
|         | Vooloi            | 14,111            |   |   |   | 0      | 0      | 0          | 0       | 0            |
|         |                   |                   |   |   |   |        |        | IOIE       | IOLE    | NMIREE       |
|         |                   |                   |   |   |   |        |        | W          | W       | W            |
|         | Interrupt         |                   |   |   |   |        |        | 0          | 0       | 0            |
|         | input             | 7BH               |   |   |   |        |        | 0: INT0    | 0: INT0 | 0: Operation |
| IIMC    | mode              | (Prohibit         |   |   |   |        |        | input      | edge    | even at      |
|         | control           | RMW)              |   |   |   |        |        | enable     | mode    | NMI          |
|         |                   |                   |   |   |   |        |        |            | 1: INT0 | rising       |
|         |                   |                   |   |   |   |        |        |            | level   | edge         |
|         |                   |                   |   |   |   |        |        |            | mode    |              |

# (9) Chip select/wait controller

| Symbol | Name               | Address   | 7       | 6 | 5                 | 4         | 3        | 2        | 1         | 0          |
|--------|--------------------|-----------|---------|---|-------------------|-----------|----------|----------|-----------|------------|
|        |                    |           | B0E     |   | B0CAS             | B0BUS     | B0W1     | B0W0     | B0C1      | B0C0       |
|        | Diagle 0           |           | W       |   | W                 | W         | W        | W        | W         | W          |
|        | Block 0<br>CS/WAIT | 68H       | 0       |   | 0                 | 0         | 0        | 0        | 0         | 0          |
| B0CS   | control            | (Prohibit | 1: B0CS |   | 0: <del>CS0</del> | 0: 16-bit | 00: 2 wa | iits     | 00: 7F00H | l to 7FFFH |
|        | register           | RMW)      | master  |   | 1: CAS0           | bus       | 01: 1 wa | iit      | 01: 40000 | 0H to      |
|        | register           |           | bit     |   |                   | 1: 8-bit  | 10: (1 + | n) waits | 10: 80000 | 0H to      |
|        |                    |           |         |   |                   | bus       | 11: 0 wa | its      | 11: C0000 | 00H to     |
|        |                    |           | B1E     |   | B1CAS             | B1BUS     | B1W1     | B1W0     | B1C1      | B1C0       |
|        | Dis els 4          |           | W       |   | W                 | W         | W        | W        | W         | W          |
|        | Block 1<br>CS/WAIT | 69H       | 0       |   | 0                 | 0         | 0        | 0        | 0         | 0          |
| B1CS   | control            | (Prohibit | 1: B1CS |   | 0: CS1            | 0: 16-bit | 00: 2 wa | its      | 00: 880H  | to 7FFFH   |
|        | register           | RMW)      | master  |   | 1: CAS1           | bus       | 01: 1 wa | iit      | 01: 40000 | 0H to      |
|        | register           |           | bit     |   |                   | 1: 8-bit  | 10: (1 + | n) waits | 10: 80000 | 0H to      |
|        |                    |           |         |   |                   | bus       | 11: 0 wa | its      | 11: C0000 | 00H to     |
|        |                    |           | B2E     |   | B2CAS             | B2BUS     | B2W1     | B2W0     | B2C1      | B2C0       |
|        | Block 2            |           | W       |   | W                 | W         | W        | W        | W         | W          |
|        | CS/WAIT            | 6AH       | 1       |   | 0                 | 0         | 0        | 0        | 0         | 0          |
| B2CS   | control            | (Prohibit | 1: B2CS |   | 0: <del>CS2</del> | 0: 16-bit | 00: 2 wa | its      | 00: 8000H | l to       |
|        | register           | RMW)      | master  |   | 1: CAS2           | bus       | 01: 1 wa | iit      | 01: 40000 | 0H to      |
|        | register           |           | bit     |   |                   | 1: 8-bit  | 10: (1 + | n) waits | 10: 80000 | 0H to      |
|        |                    |           |         |   |                   | bus       | 11: 0 wa | iits     | 11: C0000 | 00H to     |

Note: After reset, only "Block 2" is set to enable.

## (10) Clock control

| Symbol | Name       | Address | 7              | 6          | 5               | 4               | 3                   | 2             | 1                    | 0            |
|--------|------------|---------|----------------|------------|-----------------|-----------------|---------------------|---------------|----------------------|--------------|
|        |            |         |                |            |                 |                 | SCOSEL              | SCOEN         | ALEEN                | CLKEN        |
|        |            |         |                |            |                 |                 |                     | R/            | W                    |              |
|        | Clock      |         |                |            |                 |                 | 0                   | 0             | 0/1 (Note 1)         | 0/1 (Note 1) |
|        | output     |         |                |            |                 |                 | SCOUT               | SCOUT         | ALE pin              | CLK pin      |
| CKOCR  | control    | 006DH   |                |            |                 |                 | select              | output        | control              | control      |
|        | register   |         |                |            |                 |                 | 0: f <sub>FPH</sub> | control       | 0:High-Z             | 0:High-Z     |
|        | . og.oto.  |         |                |            |                 |                 | 1: f <sub>SYS</sub> | 0: I/O port   | output               | output       |
|        |            |         |                |            |                 |                 |                     | 1: SCOUT      | 1: ALE               | 1: CLK       |
|        |            |         |                |            |                 |                 |                     | output        | output               | output       |
|        |            |         | XEN            | XTEN       | RXEN            | RXTEN           | RSYSCK              | WUEF          | PRCK1                | PRCK0        |
|        |            |         |                |            |                 | R/              | W                   | ı             | ı                    |              |
|        |            |         | 1              | 0          | 1               | 0               | 0                   | 0             | 0                    | 0            |
|        |            |         | High-          | Low-       | High-           | Low-            | Selected            | Warm-up       | Select preso         | aler clock   |
|        |            |         | frequency      | frequency  | frequency       | frequency       | clock after         | timer         | 00: f <sub>FPH</sub> |              |
|        | System     |         | oscillator     | oscillator | oscillator (fc) | oscillator (fs) | Release of          | 0 Write:      | 01: fs               |              |
|        | clock      |         | (fc)           | (fs)       | after           | after           | Stop mode           | Don't care    | 10: fc/16            |              |
| SYSCR0 | control    | 006EH   | 0: Stop        | 0: Stop    | release of      | release of      | 0: fc               | 1 Write:      | 11: (Rese            | rved)        |
|        | register 0 |         | 1: Oscillation |            |                 | STOP mode       | 1: fs               | Start timer   |                      |              |
|        |            |         |                |            | 0: Stop         |                 |                     | 0 Read:       |                      |              |
|        |            |         |                |            | 1: Oscillation  | 0: Stop         |                     | End           |                      |              |
|        |            |         |                |            |                 | 1: Oscillation  |                     | warm up       |                      |              |
|        |            |         |                |            |                 |                 |                     | 1 Read:       |                      |              |
|        |            |         |                |            |                 |                 |                     | Continue      |                      |              |
|        |            |         |                |            |                 |                 |                     | warm up       |                      |              |
|        |            |         |                |            |                 |                 | SYSCK               | GEAR2         | GEAR1                | GEAR0        |
|        |            |         |                |            |                 |                 |                     |               | W                    |              |
|        |            |         |                |            |                 |                 | 0                   | 1             | 0                    | 0            |
|        |            |         |                |            |                 |                 | Select              | Select gear v | alue of high fre     | equency (fc) |
|        | System     |         |                |            |                 |                 | system clock        | 000: fc       |                      |              |
| SYSCR1 | clock      | 006FH   |                |            |                 |                 | 0: fc               | 001: fc/2     |                      |              |
|        | control    |         |                |            |                 |                 | 1: fs               | 010: fc/4     |                      |              |
|        | register 1 |         |                |            |                 |                 | (Note2)             | 011: fc/8     |                      |              |
|        |            |         |                |            |                 |                 |                     | 100: fc/16    |                      |              |
|        |            |         |                |            |                 |                 |                     | 101: (Rese    | •                    |              |
|        |            |         |                |            |                 |                 |                     | 110: (Rese    | *                    |              |
|        |            |         |                |            |                 |                 |                     | 111: (Rese    | rved)                |              |

Note 1: The value after reset of <CLKEN>, <ALEEN> is as follows:

TMP93CS40: 0 (High impedance output)

TMP93CS41: 1 (CLK or ALE output)

However, during reset the CLK pin is pulled up internally on both models.

Note 2: The high-frequency oscillator will be enabled when SYSCR1<SYSCK> is set to 0 regardless of the value of SYSCR0<XEN>.

The low-frequency oscillator will be enabled when SYSCR1<SYSCK> is set to 1 regardless of the value of SYSCR0<XTEN>.

# 6. Port Section Equivalent Circuit Diagram

· Reading the circuit diagram

Basically, the gate symbols written are the same as those used for the standard CMOS logic IC [74HCXX] series.

The dedicated signal is described below.

Stop: This signal becomes active "1" when the HALT mode setting register is set to the STOP mode and the CPU executes the HALT instruction. When the drive enable bit [DRVE] is set to "1", however, stop remains at "0".

- The input protection resistance ranges from several tens of ohms to several hundreds of ohms.
- P0 (AD0 to AD7), P1 (AD8 to AD15, A8 to A15), P2 (A16 to A23, A0 to A7)



■ P30 (RD), P31 (WR)



P32 to P37, P40 to P41, P6, P7, P80 to P86, P91 to P92, P94 to P95, PA



## ■ P42 ( CS2 , CAS2 )



## ■ P5 (AN0 to AN7)



## ■ P87 (INT0)



## ■ P90 (TXD0), P93 (TXD1)



## ■ P96 (XT1), P97 (XT2)



■ NMI



■ WDTOUT



■ CLK



■ EA



■ AM8/ AM16



■ ALE



## ■ RESET



## ■ X1, X2



## ■ VREFH, VREFL



## Points of Note and Restrictions

- (1) Notation
  - 1. How a built-in I/O register is denoted: Register symbol<Bit symbol>
    - e.g.) TRUN<T0RUN> ... Bit T0RUN of register TRUN
  - 2. Read-modify-write instruction

An instruction in which the CPU reads data from memory and writes the data to the same memory location in one instruction.

```
Example 1: SET 3, (TRUN) ... Set bit3 of TRUN

Example 2: INC 1, (100H) ... Increment the data at 100H
```

A sample read-modify-write instructions using the TLCS-900

```
Exchange instruction
  EX
        (mem), R
Arithmetic operation
  ADD (mem), R/#
                       ADC (mem), R/#
  SUB (mem), R/#
                       SBC (mem), R/#
  INC #3, (mem)
                       DEC #3, (mem)
Logic operation
  AND (mem), R/#
                       OR (mem), R/#
  XOR (mem), R/#
Bit manipulation
  STCF #3/A, (mem)
                       RES #3, (mem)
  SET #3, (mem)
                       CHG #3, (mem)
  TSET #3, (mem)
Rotate, Shift
                       RRC (mem)
  RLC (mem)
                       RR (mem)
  RL
        (mem)
  SLA
                       SRA (mem)
       (mem)
  SLL (mem)
                       SRL (mem)
  RLD (mem)
                       RRD (mem)
```

3. fc, fFPH, fSYS, one state

The clock frequency input from pins X1 and X2 is called fc, the clock selected by SYSCR<SYSCK> is called fFPH, and the clock frequency given by fFPH divided by 2 is called fSYS. One cycle of fSYS is called one state.

#### (2) Points to note

### 1. $\overline{\text{EA}}$ , AM8/ $\overline{\text{AM16}}$ pin

Fix these pins to V<sub>CC</sub> or GND unless changing voltage.

#### 2. TEST1, TEST2 pin

Connect the TEST1 pin with the TEST2 pin. Do not connect to any other pins.

#### 3. Reserved area in memory space

The 256 bytes of memory between FFFF00H and FFFFFFH cannot be used because they are reserved.

#### 4. Standby mode (IDLE1)

When IDLE1 mode (Oscillator operation only) is used, set TRUN<PRRUN> to 0 to stop the prescaler before the HALT instruction is executed.

#### 5. Warm-up counter

The warm-up counter operates when STOP mode is released even if the system is using an external oscillator. As a result, a time equivalent warm-up time elapses from input of the release request to output of the system clock.

#### 6. Micro DMA (DRAM refresh mode)

When the bus is released ( $\overline{BUSAK} = 0$ ). DRAM refresh cannot be performed because the micro DMA cannot access the bus.

### 7. Programmable pull-up/pull-down resistance

The programmable pull-up/pull-down resistors can be turned ON/OFF by the program when the ports are used as input ports. When the ports are used as outputs, they cannot be turned ON/OFF by the program.

The data registers (e.g., P2, P3, ...) are used for the pull-up/pull-down resistors ON/OFF. Consequently read-modify-write instructions are prohibited.

### 8. Bus release function

Refer to the note about the bus release in 3.5 "Functions of Ports" as it describes the state of the pins when the bus is released.

## 9. Watchdog timer

The watchdog timer starts operation immediately after the reset is released. When the watch dog timer will not be used, disable it.

### 10. Watchdog timer

When the bus is released, neither internal memory nor internal I/O can be accessed. However, the internal I/O continues to operate and hence, the watchdog timer continues to run. Thus, take care when setting the bus release time and the detection timer for the watchdog timer.

#### 11. AD converter

The ladder resistor between the VREFH and VREFL pins can be cut by a program to reduce power consumption. When standby mode is used, disable the resistor using the program before the HALT instruction is executed. And set ADMOD2<SPEED1:0>= "00".

#### 12. CPU (Micro DMA)

Only the "LDC cr, r" and "LDC r, cr" instructions can be used to access the control registers in the CPU (like the transfer source address register (DMASn)).

#### 13. POP SR instruction

Please execute POP SR instruction during DI condition.

#### 14. Pin states in STOP mode

Open-drain output state. Input gate in operation. Set output to "L" or attach pull up on pin so that the input gate stays constant.

15. Releasing the HALT mode by requesting an interruption

Usually, interrupts can release all halts status. However, the interrupts ( $\overline{\text{NMI}}$ , INT0) which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 3 clocks of fFPH) with IDLE1 or STOP mode (IDLE2/RUN are not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficulty. The priority of this interrupt is compared with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

# 8. TMP93XX40/41 Different Points

| ltem                                              | TMP93CM40F                                  | TMP93CS40F                                   | TMP93CS41F TMP93PS40F | TMP93PS40F                              | TMP93CW40F TMP93CW41F                                     |                          | TMP93PW40F                               |
|---------------------------------------------------|---------------------------------------------|----------------------------------------------|-----------------------|-----------------------------------------|-----------------------------------------------------------|--------------------------|------------------------------------------|
| Built-in ROM                                      | 32-Kbyte<br>mask ROM<br>(8000H to<br>FFFFH) | 64-Kbyte<br>mask ROM<br>(8000H to<br>17FFFH) | None                  | 64-Kbyte<br>OTP<br>(8000H to<br>17FFFH) | 128-Kbyte<br>mask ROM<br>(8000H to<br>27FFFH)             | None                     | 128-Kbyte<br>OTP<br>(8000H to<br>27FFFH) |
| Built-in RAM                                      |                                             | 2-Kbyte (0080H to 087FH)                     | )H to 087FH)          |                                         | -4                                                        | 4-Kbyte (0080H to 107FH) | H)                                       |
| Operation frequency: fc (3 V $\pm$ 10%)           | 4 to 10 MHz                                 |                                              |                       | 4 to 12                                 | 4 to 12.5 MHz                                             |                          |                                          |
| ADC operation voltage range                       | 5 V ± 10%<br>(4 to 20 MHz)                  |                                              |                       | 5 V ± 10% (·<br>3 V ± 10% (4            | 5 V $\pm$ 10% (4 to 20 MHz) 3 V $\pm$ 10% (4 to 12.5 MHz) |                          |                                          |
| Port 5<br>input level (VIL)                       | 0.2 V <sub>CC</sub>                         |                                              |                       | 0.3                                     | 0.3 Vcc                                                   |                          |                                          |
| CS2 Mapping area (B2CS < B2C1 to $0 \ge 00$ )     | from 10000H                                 | from 18000H                                  | from 08000H           | from 18000H                             | from 28000H                                               | from 08000H              | from 28000H                              |
| CS1<br>Mapping area<br>(B1CS < B1C1 to<br>0 ≥ 00) |                                             | 880H to 7FFFH                                | 76 FFH                |                                         |                                                           | 1080H to 7FFFH           |                                          |

# 9. Package Dimensions

P-QFP100-1414-0.50

Unit: mm



## P-LQFP100-1414-0.50F

Unit: mm

