

## CMOS 8-BIT MICROCONTROLLER

## TMP87CH34BN, TMP87CK34BN, TMP87CM34BN

The 87CH34B/K34B/M34B is the high speed and high performance 8-bit single chip microcomputer. This MCU contains CPU core, ROM, RAM, input/output ports, six multi-function timer/counter, serial interface, on-screen display, PWM, 6-bit A/D conversion inputs and remote control signal processor on a chip.

The functions of the OSD circuit conform to the on-screen display functions of closed caption decoders based on FCC standards.

| PART No.    | ROM       | RAM      | PACKAGE           | OTP MCU     |
|-------------|-----------|----------|-------------------|-------------|
| TMP87CH34BN | 16K bytes |          |                   |             |
| TMP87CK34BN | 24K bytes | 1K bytes | SDIP42-P-600-1.78 |             |
| TMP87CM34BN | 32K bytes |          |                   | TMP87PM34AN |

## FEATURES

- ◆ 8-bit single chip microcomputer TLCS-870 Series
- ◆ Instruction execution time :  $0.5 \mu\text{s}$  (at 8 MHz)
- ◆ 412 basic instructions
  - Multiplication and Division (8 bits  $\times$  8 bits, 16 bits  $\div$  8 bits)
  - Bit manipulations (Set/Clear/Complement/Move/Test/Exclusive Or)
  - 16-bit data operations
  - 1-byte jump/subroutine-call (Short relative jump / Vector call)
- ◆ 14 interrupt sources (External : 5, Internal : 9)
  - All sources have independent latches each, and nested interrupt control is available.
  - 4 edge-selectable external interrupts with noise reject
  - High-speed task switching by register bank changeover
- ◆ Input/Output ports (33 pins)
  - High current output : 4 pins (typ. 20 mA)
- ◆ Two 16-bit Timer/Counters
  - Timer, Event counter, Pulse width measurement, External trigger timer window modes
- ◆ Two 8-bit Timer/Counters
  - Timer, Event counter, Capture (Pulse width/duty measurement) modes
- ◆ Time Base Timer (Interrupt frequency : 1 Hz to 16 kHz)
- ◆ Watchdog Timer
  - Interrupt source/reset output (programmable)
- ◆ Serial Interface
  - I<sup>2</sup>C-bus (Single master) / 8-bits SIO timeshared 2-ch
- ◆ On-screen display circuit
  - Character patterns : 256 characters
  - Character displayed : 32 column 8 lines
  - Composition : 8  $\times$  9 dots
  - Size of character : 3 kinds (line by line)
  - Color of character : 7 kinds (character by character)
  - Variable display position : Horizontal/Vertical 128/256 steps
  - Fringing, Smoothing function
  - Conform to US CLOSED CAPTION DECODER REGULATION
- ◆ PWM outputs
  - 14-bit PWM output (1 channel)
  - 7-bit PWM outputs (9 channels)
- ◆ 6-bit A/D conversion input (4 channels)
- ◆ Pulse output (Clock for PLL IC)
- ◆ Remote control signal processor
- ◆ Jitter elimination circuit
- ◆ Data slicer circuit
- ◆ Two Power saving operating modes
  - STOP mode : Oscillation stops. Battery/Capacitor back-up. Port output hold/high-impedance.
  - IDLE mode : CPU stops, and Peripherals operate using high-frequency clock. Release by interrupts.
- ◆ Emulation Pod : BM87CM34AN0A

SDIP42-P-600-1.78


 TMP87CH34BN  
 TMP87CK34BN  
 TMP87CM34BN


Purchase of TOSHIBA I<sup>2</sup>C components conveys a license under the Philips I<sup>2</sup>C Patent Rights to use these components in an I<sup>2</sup>C system, provided that the system conforms to the I<sup>2</sup>C Standard Specification as defined by Philips.

## PIN ASSIGNMENTS (TOP VIEW)

SDIP42-P-600-1.78

|                                                                                       |    |    |                                                |
|---------------------------------------------------------------------------------------|----|----|------------------------------------------------|
| ( $\overline{\text{PWM}0}$ ) P40                                                      | 1  | 42 | VDD                                            |
| ( $\overline{\text{PWM}1}$ ) P41                                                      | 2  | 41 | P33 (CDATA / TC4 / VINO)                       |
| ( $\overline{\text{PWM}2}$ ) P42                                                      | 3  | 40 | P32 (CCLK / VIN1 / CSIN)                       |
| ( $\overline{\text{PWM}3}$ ) P43                                                      | 4  | 39 | VVSS                                           |
| ( $\overline{\text{PWM}4}$ ) P44                                                      | 5  | 38 | P35 (SI1 / SDA1)                               |
| ( $\overline{\text{PWM}5}$ ) P45                                                      | 6  | 37 | P34 (SCK1 / SCL1)                              |
| ( $\overline{\text{PWM}6}$ ) P46                                                      | 7  | 36 | P31 (INT4 / TC3)                               |
| ( $\overline{\text{PWM}7}$ ) P47                                                      | 8  | 35 | P30 (INT3 / RXIN)                              |
| ( $\overline{\text{SCK0}} / \text{SCL0} / \text{INT0} / \overline{\text{PWM}8}$ ) P50 | 9  | 34 | P20 ( $\overline{\text{INT5}} / \text{STOP}$ ) |
| ( $\text{SI0} / \text{SDA0} / \overline{\text{PWM}9}$ ) P51                           | 10 | 33 | RESET                                          |
| ( $\text{SO0} / \text{TC2} / \overline{\text{PULSE}}$ ) P52                           | 11 | 32 | XOUT                                           |
| ( $\text{INT2} / \text{TC1}$ ) P53                                                    | 12 | 31 | XIN                                            |
| ( $\text{CIN}0$ ) P54                                                                 | 13 | 30 | TEST                                           |
| ( $\text{CIN}1$ ) P55                                                                 | 14 | 29 | OSC2                                           |
| ( $\text{CIN}2$ ) P56                                                                 | 15 | 28 | OSC1                                           |
| ( $\text{CIN}3$ ) P57                                                                 | 16 | 27 | P71 ( $\overline{V_D}$ )                       |
| ( $\text{YIN/BLIN}$ ) P60                                                             | 17 | 26 | P70 ( $\overline{H_D}$ )                       |
| ( $\text{BIN}$ ) P61                                                                  | 18 | 25 | P67 (Y / BL)                                   |
| ( $\text{GIN/CSOUT}$ ) P62                                                            | 19 | 24 | P66 (B)                                        |
| ( $\text{RIN/FIELD}$ ) P63                                                            | 20 | 23 | P65 (G)                                        |
| VSS                                                                                   | 21 | 22 | P64 (R)                                        |

I/O Ports  
P67 to P60  
P71 to P70

## BLOCK DIAGRAM



## PIN FUNCTION

| PIN NAME                        | Input/Output                  | Function                                                                                                                                                                                                                                               |                                                                                                                           |
|---------------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| P20 (INT5/STOP)                 | I/O (Input)                   | 1-bit input / output port with latch. When used as an input port, or an interrupt input/STOP mode release signal input, the latch must be set to "1".                                                                                                  | External interrupt input 5 / STOP mode release signal input                                                               |
| P35 (SI1/SDA1)                  | I/O (Input, I/O)              |                                                                                                                                                                                                                                                        | SIO1 serial data input/I <sup>2</sup> Cbus2 serial data input/output                                                      |
| P34 (SCK1/SCL1)                 | I/O (Input, I/O)              | 6-bit input/output port with latch.                                                                                                                                                                                                                    | SIO1 serial clock data input/I <sup>2</sup> Cbus2 serial clock input/output                                               |
| P33 (CDATA/TC4/VIN0)            | I/O (Input, Input, Input)     | When used as an input port, a serial interface input/output, a timer/counter input, a remote control signal processor input, a slicer interface, or an interrupt input, the latch must be set to "1".                                                  | Caption data input/Timer/counter 4 input/Video signal input 0                                                             |
| P32 (CCLK/VIN1/CSIN)            | I/O (Input, Input, Input)     |                                                                                                                                                                                                                                                        | Caption clock input/Video signal input 1 /Composite sync input                                                            |
| P31 (INT4/TC3)                  | I/O (Input, Input)            |                                                                                                                                                                                                                                                        | External interrupt input 4/Timer/Counter 3 input                                                                          |
| P30 (INT3/RXIN)                 | I/O (Input, Input)            |                                                                                                                                                                                                                                                        | External interrupt input 3 / remote control signal processor input                                                        |
| P47 (PWM7) to P41 (PWM1)        | I/O (Output)                  | 8-bit programmable input/output port (tri-state). Each bit of this port can be individually as an input or an output under software control. During reset, all bits are configured as inputs. When used as a PWM output, the latch must be set to "1". | 7-bit PWM outputs                                                                                                         |
| P40 (PWM0)                      | I/O (Output)                  |                                                                                                                                                                                                                                                        | 14-bit PWM output                                                                                                         |
| P57 (CIN3) to P54 (CIN0)        | I/O (Input)                   | 8-bit input/output port with latch. (P57~P54 : tri-state)                                                                                                                                                                                              | Comparator inputs                                                                                                         |
| P53 (INT2 / TC1)                | I/O (Input, Input)            | Each bit of this port can be individually as an input or an output under software control.                                                                                                                                                             | External interrupt input 2/Timer/Counter 1 input                                                                          |
| P52 (SO0/TC2/PULSE)             | I/O (Output, Input, Output)   |                                                                                                                                                                                                                                                        | SIO1 serial data output/Timer/Counter 2 input/Pulse output                                                                |
| P51 (PWM9/SI0/SDA0)             | I/O (Output, Input, I/O)      | When used as an input port, a PWM output, or a pulse output, the latch must be set to "1".                                                                                                                                                             | 7-bit PWM outputs/SIO1 serial data input /I <sup>2</sup> Cbus 1 serial data input/output                                  |
| P50 (PWM8 / SCK0 / SCL0 / INT0) | I/O (Output, I/O, I/O, Input) |                                                                                                                                                                                                                                                        | 7-bit PWM outputs/SIO1 serial clock data input/I <sup>2</sup> Cbus 1 serial clock input/output/External interrupt input 0 |
| OSC1, OSC2                      | Input, Output                 | Resonator connecting pin of on-screen display circuit                                                                                                                                                                                                  |                                                                                                                           |
| P71 (VD)                        | I/O (Input)                   | 2-bit input/output port with latch. When used as an input port, a vertical synchronous signal input, or a horizontal synchronous signal input. the latch must be set to "1".                                                                           | Vertical synchronous signal input                                                                                         |
| P70 (HD)                        | I/O (Input)                   |                                                                                                                                                                                                                                                        | Horizontal synchronous signal input                                                                                       |
| P67 (Y/BL)                      | I/O (Output)                  | 8-bit programmable input/output port (P67 to P64 : tri-state, P63 to P60 : High current output). Each bit of this port can be individually as an input or an output under software control. During reset, all bits are configured as inputs.           |                                                                                                                           |
| P66 (B)                         | I/O (Output)                  |                                                                                                                                                                                                                                                        | R, G, B, Y/BL output                                                                                                      |
| P65 (G)                         | I/O (Output)                  |                                                                                                                                                                                                                                                        |                                                                                                                           |
| P64 (R)                         | I/O (Output)                  |                                                                                                                                                                                                                                                        |                                                                                                                           |
| P63 (RIN/FIELD)                 | I/O                           | When P67 to P64 ports are used as output port, bits 7 to 4 of address 0F91H must be set to "1".                                                                                                                                                        | R input/Field status input                                                                                                |
| P62 (GIN/CSOUT)                 | I/O                           | When P63 to P60 port used as RIN/FIELD, GIN, BIN, Y/BLIN input, these ports must be set to "1".                                                                                                                                                        | GIN input/Test video signal output                                                                                        |
| P61 (BIN)                       | I/O                           |                                                                                                                                                                                                                                                        | B input                                                                                                                   |
| P60 (YIN/BLIN)                  | I/O                           |                                                                                                                                                                                                                                                        | Y/BL input                                                                                                                |
| XIN, XOUT                       | Input, Output                 | Resonator connecting pin (High frequency). For external clock input, XIN is used and XOUT is opened.                                                                                                                                                   |                                                                                                                           |
| RESET                           | I/O                           | Reset signal input or watchdog timer output/address-trap- reset output/system-clock-reset output.                                                                                                                                                      |                                                                                                                           |
| TEST                            | Input                         | Test pin for out-going test. Be tied to low.                                                                                                                                                                                                           |                                                                                                                           |
| VDD, VSS, VVSS                  | Power Supply                  | + 5 V, 0 V (GND)                                                                                                                                                                                                                                       |                                                                                                                           |

## OPERATIONAL DESCRIPTION

### 1. CPU CORE FUNCTIONS

The CPU core consists of a CPU, a system clock controller, an interrupt controller, and a watchdog timer. This section provides a description of the CPU core, the program memory (ROM), the data memory (RAM), and the reset circuit.

#### 1.1 Memory Address Map

The TLCS-870 Series is capable of addressing 64K bytes of memory. Figure 1-1 shows the memory address maps of the 87CH34B/K34B/M34B. In the TLCS-870 Series, the memory is organized 4 address spaces (ROM, RAM, SFR, and DBR). It uses a memory mapped I/O system, and all I/O registers are mapped in the SFR / DBR address spaces. There are 16 banks of general-purpose registers. The register banks are also assigned to the first 128 bytes of the RAM address space.



Figure 1-1. Memory Address Map

## 1.2 Program Memory (ROM)

The 87CH34B/K34B/M34B has an 8K/12K/16K/24K/32Kbytes (addresses C000<sub>H</sub>/A000<sub>H</sub> /8000<sub>H</sub> to FFFF<sub>H</sub>) of program memory (mask programmed ROM).

Addresses FF00<sub>H</sub> to FFFF<sub>H</sub> in the program memory can also be used for special purposes.

### (1) Interrupt / Reset vector table (addresses FFE0<sub>H</sub> to FFFF<sub>H</sub>)

This table consists of a reset vector and 15 interrupt vectors (2 bytes/vector). These vectors store a reset start address and 15 interrupt service routine entry addresses.

### (2) Vector table for vector call instructions (addresses FFC0<sub>H</sub> to FFDF<sub>H</sub>)

This table stores call vectors (subroutine entry address, 2 bytes/vector) for the vector call instructions [CALLV n]. There are 16 vectors. The CALLV instruction increases memory efficiency when utilized for frequently used subroutine calls (called from 3 or more locations).

### (3) Entry area (addresses FF00<sub>H</sub> to FFFF<sub>H</sub>) for page call instructions

This is the subroutine entry address area for the page call instructions [CALLP n]. Addresses FF00<sub>H</sub>-FFBF<sub>H</sub> are normally used because address FFC0<sub>H</sub> to FFFF<sub>H</sub> are used for the vector tables.

Programs and fixed data are stored in the program memory. The instruction to be executed next is read from the address indicated by the current contents of the program counter (PC). There are relative jump and absolute jump instructions. The concepts of page or bank boundaries are not used in the program memory concerning any jump instruction.

Example: The relationship between the jump instructions and the PC.

#### ① 5-bit PC-relative jump [JRS cc, \$ + 2 + d]

E8C4H: JRS T, \$ + 2 + 08H

When JF = 1, the jump is made to E8CE<sub>H</sub>, which is 08<sub>H</sub> added to the contents of the PC. (The PC contains the address of the instruction being executed + 2; therefore, in this case, the PC contents are E8C4<sub>H</sub> + 2 = E8C6<sub>H</sub>.)

#### ② 8-bit PC-relative jump [JR cc, \$ + 2 + d]

E8C4H : JR Z, \$ + 2 + 80H

When ZF = 1, the jump is made to E846<sub>H</sub>, which is FF80<sub>H</sub> (-128) added to the current contents of the PC.

#### ③ 16-bit absolute jump [JP a]

E8C4H : JP 0C235H

An unconditional jump is made to address C235<sub>H</sub>. The absolute jump instruction can jump anywhere within the entire 64K-byte space.



Figure 1-2. Program Memory Map

In the TLCS-870 Series, the same instruction used to access the data memory (e.g. [LD A, (HL)]) is also used to read out fixed data (ROM data) stored in the program memory. The register-offset PC-relative addressing (PC + A) instructions can also be used, and the code conversion, table look-up and n-way multiple jump processing can easily be programmed.

Example 1 : Loads the ROM contents at the address specified by the HL register pair contents into the accumulator (HL  $\geq$  C000<sub>H</sub> for 87CH34B):

LD A, (HL) ; A  $\leftarrow$  ROM (HL)

Example 2 : Converts BCD to 7-segment code (common anode LED). When A = 05<sub>H</sub>, 92<sub>H</sub> is output to port P5 after executing the following program:

ADD A, TABLE - \$ - 4 ; P5  $\leftarrow$  ROM (TABLE + A)

LD (P5), (PC + A)

JRS T, SNEXT ; Jump to SNEXT

TABLE : DB 0C0H, 0F9H, 0A4H, 0B0H, 99H, 92H, 82H, 0D8H, 80H, 98H

SNEXT :

*Notes : "\$" is a header address of ADD instruction.*

*DB is a byte data definition instruction.*



Example 3 : N-way multiple jump in accordance with the contents of accumulator (0  $\leq$  A  $\leq$  3):

SHLC A ; if A = 00<sub>H</sub> then PC  $\leftarrow$  C234<sub>H</sub>

JP (PC + A) ; if A = 01<sub>H</sub> then PC  $\leftarrow$  C378<sub>H</sub>

if A = 02<sub>H</sub> then PC  $\leftarrow$  DA37<sub>H</sub>

if A = 03<sub>H</sub> then PC  $\leftarrow$  E1B0<sub>H</sub>

DW 0C234H, 0C378H, 0DA37H, 0E1B0H

*Note : DW is a word data definition instruction.*

### 1.3 Program Counter (PC)

The program counter (PC) is a 16-bit register which indicates the program memory address where the instruction to be executed next is stored. After reset, the user defined reset vector stored in the vector table (addresses FFFF<sub>H</sub> and FFFE<sub>H</sub>) is loaded into the PC ; therefore, program execution is possible from any desired address. For example, when C0<sub>H</sub> and 3E<sub>H</sub> are stored at addresses FFFF<sub>H</sub> and FFFE<sub>H</sub>, respectively, the execution starts from address C03E<sub>H</sub> after reset.

The TLCS-870 Series utilizes pipelined processing (instruction pre-fetch); therefore, the PC always indicates 2 addresses in advance. For example, while a 1-byte instruction stored at address C123<sub>H</sub> is being executed, the PC contains C125<sub>H</sub>.



Figure 1-3. Program Counter

### 1.4 Data Memory (RAM)

The 87CH34B/K34B/M34B has a 1K bytes (addresses 0040<sub>H</sub> to 043F<sub>H</sub>) of data memory (static RAM). Figure 1-4 shows the data memory map.

Addresses 0000<sub>H</sub> to 00FF<sub>H</sub> are used as a direct addressing area to enhance instructions which utilize this addressing mode; therefore, addresses 0040<sub>H</sub> to 00FF<sub>H</sub> in the data memory can also be used for user flags or user counters. General-purpose register banks (8 registers  $\times$  16 banks) are also assigned to the 128 bytes of addresses 0040<sub>H</sub> to 00BF<sub>H</sub>. Access as data memory is still possible even when being used for registers. For example, when the contents of the data memory at address 0040<sub>H</sub> is read out, the contents of the accumulator in the bank 0 are also read out. The stack can be located anywhere within the data memory except the register bank area. The stack depth is limited only by the free data memory size. For more details on the stack, see section "1.7 Stack and Stack Pointer".

The TLCS-870 Series cannot execute programs placed in the data memory. When the program counter indicates a data memory address, a bus error occurs and an address-trap-reset applies. The RESET pin goes low during the address-trap-reset.

Example 1 : If bit 2 at data memory address  $00C0H$  is "1",  $00H$  is written to data memory at address  $00E3H$ ; otherwise,  $FFH$  is written to the data memory at address  $00E3H$ :

```

TEST      (00C0H).2      ; if (00C0H)2 = 0 then jump
JRS      T,SZERO
CLR      (00E3H)      ; (00E3H) ← 00H
JRS      T,SNEXT
SZERO : LD      (00E3H), 0FFH ; (00E3H) ← FFH
SNEXT :

```

Example 2 : Increments the contents of data memory at address  $00F5H$ , and clears to  $00H$  when  $10H$  is exceeded:

```

INC      (00F5H)      ; (00F5H) ← (00F5H) + 1
AND      (00F5H), 0FH   ; (00F5H) ← (00F5H)  $\wedge$  0FH

```

The data memory contents become unstable when the power supply is turned on; therefore, the data memory should be initialized by an initialization routine.

*Note: The general-purpose registers are mapped in the RAM ; therefore, do not clear RAM at the current bank addresses.*

Example : Clears RAM to "00H" except the bank 0:

```

LD      HL, 0048H      ; Sets start address to HL register pair
LD      A, H           ; Sets initial data (00H) to A register
LD      BC, 03F7H      ; Sets number of byte to BC register pair
SRAMCLR : LD      (HL +), A
DEC     BC
JRS      F, SRAMCLR

```

| Address | 0                | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A                | B | C | D | E | F |
|---------|------------------|---|---|---|---|---|---|---|---|---|------------------|---|---|---|---|---|
| 0040H   | Register bank 0  |   |   |   |   |   |   |   |   |   | Register bank 1  |   |   |   |   |   |
| 0050    | Register bank 2  |   |   |   |   |   |   |   |   |   | Register bank 3  |   |   |   |   |   |
| 0060    | Register bank 4  |   |   |   |   |   |   |   |   |   | Register bank 5  |   |   |   |   |   |
| 0070    | Register bank 6  |   |   |   |   |   |   |   |   |   | Register bank 7  |   |   |   |   |   |
| 0080    | Register bank 8  |   |   |   |   |   |   |   |   |   | Register bank 9  |   |   |   |   |   |
| 0090    | Register bank 10 |   |   |   |   |   |   |   |   |   | Register bank 11 |   |   |   |   |   |
| 00A0    | Register bank 12 |   |   |   |   |   |   |   |   |   | Register bank 13 |   |   |   |   |   |
| 00B0    | Register bank 14 |   |   |   |   |   |   |   |   |   | Register bank 15 |   |   |   |   |   |
| 00C0    |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |
| 00D0    |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |
| 00E0    |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |
| 00F0    |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |
| 0100    |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |
| 0110    |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |
| ...     |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |
| 0430    |                  |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |

Figure 1-4. Data Memory Map

## 1.5 General-purpose Register Banks

General-purpose registers are mapped into addresses  $0040_{\text{H}}$ - $00BF_{\text{H}}$  in the data memory as shown in Figure 1-5. There are 16 register banks, and each bank contains eight 8-bit registers W, A, B, C, D, E, H, and L. Figure 1-5. shows the general-purpose register bank configuration.



Figure 1-5. General-purpose Register Banks

In addition to access in 8-bit units, the registers can also be accessed in 16-bit units as the register pairs WA, BC, DE, and HL. Besides its function as a general-purpose register, the register also has the following functions:

### (1) A, WA

The A register has a function as an 8-bit accumulator and the WA register pair has a function as a 16-bit accumulator (W is high byte and A is low byte). Other registers than A can also be used as accumulators for 8-bit operations.

Examples : ① ADD A, B ; Adds B contents to A contents and stores the result into A.  
 ② SUB WA, 1234H ; Subtracts  $1234_{\text{H}}$  from WA contents and stores the result into WA.  
 ③ SUB E, A ; Subtracts A contents from E contents, and stores the result into E.

### (2) HL, DE

The HL and DE specify a memory address. The HL register pair has a function as data pointer (HL) / index register (HL + d) / base register (HL + C), and the DE register pair has a function as a data pointer (DE). The HL also has an auto-post- increment and auto-pre-decrement functions. This function simplifies a multiple digit data processing, software LIFO (last-in first-out) processing, etc.

Example 1 : ① LD A, (HL) ; Loads the memory contents at the address specified by HL into A.  
 ② LD A, (HL + 52H) ; Loads the memory contents at the address specified by the value obtained by adding  $52_{\text{H}}$  to HL contents into A.  
 ③ LD A, (HL + C) ; Loads the memory contents at the address specified by the value obtained by adding the register C contents to HL contents into A.  
 ④ LD A, (HL +) ; Loads the memory contents at the address specified by HL into A. Then increments HL.  
 ⑤ LD A, (-HL) ; Decrements HL. Then loads the memory contents at the address specified by new HL into A.

The TLCS-870 Series can directly transfer data memory to memory, and directly operate between memory data and memory data. This facilitates the programming of block processing.

## Example 2 : Block transfer

|         |               |                                               |
|---------|---------------|-----------------------------------------------|
| LD      | B, n - 1      | ; Sets (number of bytes to transfer) - 1 to B |
| LD      | HL, DSTA      | ; Sets destination address to HL              |
| LD      | DE, SRCA      | ; Sets source address to DE                   |
| SLOOP : | LD (HL), (DE) | ; (HL) $\leftarrow$ (DE)                      |
| INC     | HL            | ; HL $\leftarrow$ HL + 1                      |
| INC     | DE            | ; DE $\leftarrow$ DE + 1                      |
| DEC     | B             | ; B $\leftarrow$ B - 1                        |
| JRS     | F, SLOOP      | ; if B $\geq$ 0 then loop                     |

## (3) B, C, BC

Registers B and C can be used as 8-bit buffers or counters, and the BC register pair can be used as a 16-bit buffer or counter. The C register functions as an offset register for register-offset index addressing (refer to example 1 ③ above) and as a divisor register for the division instruction [DIV gg, C].

## Example 1 : Repeat processing

|           |            |                                            |
|-----------|------------|--------------------------------------------|
| LD        | B, n       | ; Sets n as the number of repetitions to B |
| SREPEAT : | processing | (n + 1 times processing)                   |
| DEC       | B          |                                            |
| JRS       | F, SREPEAT |                                            |

Example 2 : Unsigned integer division (16-bit  $\div$  8-bit)

|     |       |                                                                                               |
|-----|-------|-----------------------------------------------------------------------------------------------|
| DIV | WA, C | ; Divides the WA contents by the C contents, places the quotient in A and the remainder in W. |
|-----|-------|-----------------------------------------------------------------------------------------------|

The general-purpose register banks are selected by the 4-bit register bank selector (RBS). During reset, the RBS is initialized to "0". The bank selected by the RBS is called the current bank. The RBS is assigned to address 003FH in the SFR as the program status word (PSW) with the flag. There are 3 instructions [LD RBS, n], [PUSH PSW] and [POP PSW] to access the PSW. The PSW can be also operated by the memory access instruction.

## Example 1 : Incrementing the RBS

|     |         |                            |
|-----|---------|----------------------------|
| INC | (003FH) | ; RBS $\leftarrow$ RBS + 1 |
|-----|---------|----------------------------|

## Example 2 : Reading the RBS

|    |            |                                                                                               |
|----|------------|-----------------------------------------------------------------------------------------------|
| LD | A, (003FH) | ; A $\leftarrow$ PSW (A <sub>3-0</sub> $\leftarrow$ RBS, A <sub>7-4</sub> $\leftarrow$ Flags) |
|----|------------|-----------------------------------------------------------------------------------------------|

High efficient programming and high-speed task switching are possible by using bank changeover to save registers during interrupt and to transfer parameters during subroutine processing.

During interrupt, the PSW is automatically saved onto the stack. The bank used before the interrupt was accepted is restored automatically by executing an interrupt return instruction [RETI]/[RETN] ; therefore, there is no need for the RBS save/restore software processing.

The TLCS-870 Series supports a maximum of 15 interrupt sources. One bank is assigned to the main program, and one bank can be assigned to each source. Also, to increase the efficiency of data memory usage, assign the same bank to interrupt sources which are not nested.

## Example: Saving /restoring registers during interrupt task using bank changeover.

|         |                      |                                              |
|---------|----------------------|----------------------------------------------|
| PINT1 : | LD RBS, n            | ; RBS $\leftarrow$ n (Bank changeover)       |
|         | Interrupt processing |                                              |
|         | RETI                 | ; Maskable interrupt return (Bank restoring) |

## 1.6 Program Status Word (PSW)

The program status word (PSW) consists of a register bank selector (RBS) and four flags, and the PSW is assigned to address  $003F_H$  in the SFR.

The RBS can be read and written by using the memory access instruction (e. g. [LD A, (003FH)], [LD (003FH), A], however the flags can only be read. When writing to the PSW, the change specified by the instruction

is made without writing data to the flags. For example, when the instruction [LD (003FH), 05H] is executed, "5" is written to the RBS and the JF is set to "1", but the other flags are not affected.

[PUSH PSW] and [POP PSW] are PSW access instructions.

### 1.6.1 Register Bank Selector (RBS)

The register bank selector (RBS) is a 4-bit register used to select general-purpose register banks. For example, when RBS = 2, bank 2 is currently selected. During reset, the RBS is initialized to "0".



Figure 1-6. PSW (Flags, RBS) Configuration

### 1.6.2 Flags

The flags are configured with the upper 4 bits : a zero flag, a carry flag, a half carry flag and a jump status flag. The flags are set or cleared under conditions specified by the instruction. These flags except the half carry flag are used as jump condition "cc" for conditional jump instructions [JR cc, \$ + 2 + d]/[JRS cc, \$ + 2 + d]. After reset, the jump status flag is initialized to "1", other flags are not affected.

#### (1) Zero flag (ZF)

The ZF is set to "1" if the operation result or the transfer data is  $00_H$  (for 8-bit operations and data transfers)/ $0000_H$  (for 16-bit operations); otherwise the ZF is cleared to "0".

During the bit manipulation instructions [SET, CLR, and CPL], the ZF is set to "1" if the contents of the specified bit is "0"; otherwise the ZF is cleared to "0".

This flag is set to "1" when the upper 8 bits of the product are  $00_H$  during the multiplication instruction [MUL], and when  $00_H$  for the remainder during the division instruction [DIV]; otherwise it is cleared to "0".

#### (2) Carry flag (CF)

The CF is set to "1" when a carry out of the MSB (most significant bit) of the result occurred during addition or when a borrow into the MSB of the result occurred during subtraction; otherwise the CF is cleared to "0". During division, this flag is set to "1" when the divisor is  $00_H$  (divided by zero error), or when the quotient is  $100_H$  or higher (quotient overflow error); otherwise it is cleared. The CF is also affected during the shift/rotate instructions [SHLC, SHRC, ROLC, and RORC]. The data shifted out from a register is set to the CF.

This flag is also a 1-bit register (a boolean accumulator) for the bit manipulation instructions.

Set/clear/complement are possible with the CF manipulation instructions.

Example1 : Bit manipulation

```
LD      CF, (0007H).5      ; (0001)2 ← (0007)5 ∨ (009A)H0
XOR    CF, (009AH).0
LD      (0001H).2, CF
```

Example2 : Arithmetic right shift

```
LD      CF, A.7      ; A ← A/2
RORC   A
```

#### (3) Half carry flag (HF)

The HF is set to "1" when a carry occurred between bits 3 and 4 of the operation result during an 8-bit addition, or when a borrow occurred from bit 4 into bit 3 of the result during an 8-bit subtraction; otherwise the HF is cleared to "0". This flag is useful in the decimal adjustment for BCD operations (adjustments using the [DAA r], or [DAS r] instructions).

## Example : BCD operation

(The A becomes  $47_H$  after executing the following program when  $A = 19_H$ ,  $B = 28_H$ )

|     |      |                                                               |
|-----|------|---------------------------------------------------------------|
| ADD | A, B | ; $A \leftarrow 41_H$ , HF $\leftarrow 1$ , CF $\leftarrow 0$ |
| DAA | A    | ; $A \leftarrow 41_H + 06_H = 47_H$ (decimal-adjust)          |

## (4) Jump status flag (JF)

Zero or carry information is set to the JF after operation (e. g. INC, ADD, CMP, TEST).

The JF provides the jump condition for conditional jump instructions [JRS T/F,  $\$ + 2 + d$ ], [JR T/F,  $\$ + 2 + d$ ] (T or F is a condition code). Jump is performed if the JF is "1" for a true condition (T), or the JF is "0" for a false condition (F).The JF is set to "1" after executing the load/exchange/swap/nibble rotate/jump instruction, so that [JRS T,  $\$ + 2 + d$ ] and [JR T,  $\$ + 2 + d$ ] can be regarded as an unconditional jump instruction.

## Example : Jump status flag and conditional jump instruction

|     |            |                                                                                                           |
|-----|------------|-----------------------------------------------------------------------------------------------------------|
| INC | A          |                                                                                                           |
| JRS | T, SLABLE1 | ; Jump when a carry is caused by the immediately preceding operation instruction.                         |
| :   |            |                                                                                                           |
| LD  | A, (HL)    |                                                                                                           |
| JRS | T, SLABLE2 | ; JF is set to "1" by the immediately preceding instruction, making it an unconditional jump instruction. |
| :   |            |                                                                                                           |

Example : The accumulator and flags become as shown below after executing the following instructions when the WA register pair, the HL register pair, the data memory at address  $00C5_H$ , the carry flag and the half carry flag contents being " $219AH$ ", " $00C5_H$ ", " $D7_H$ ", "1" and "0", respectively.

| Instruction  | Acc. after execution | Flag after execution |    |    |    | Instruction    | Acc. after execution | Flag after execution |    |    |    |
|--------------|----------------------|----------------------|----|----|----|----------------|----------------------|----------------------|----|----|----|
|              |                      | JF                   | ZF | CF | HF |                |                      | JF                   | ZF | CF | HF |
| ADDC A, (HL) | 72                   | 1                    | 0  | 1  | 1  | INC A          | 9B                   | 0                    | 0  | 1  | 0  |
| SUBB A, (HL) | C2                   | 1                    | 0  | 1  | 0  | ROLC A         | 35                   | 1                    | 0  | 1  | 0  |
| CMP A, (HL)  | 9A                   | 0                    | 0  | 1  | 0  | RORC A         | CD                   | 0                    | 0  | 0  | 0  |
| AND A, (HL)  | 92                   | 0                    | 0  | 1  | 0  | ADD WA, 0F508H | 16A2                 | 1                    | 0  | 1  | 0  |
| LD A, (HL)   | D7                   | 1                    | 0  | 1  | 0  | MUL W, A       | 13DA                 | 0                    | 0  | 1  | 0  |
| ADD A, 66H   | 00                   | 1                    | 1  | 1  | 1  | SET A.5        | BA                   | 1                    | 1  | 1  | 0  |

## 1.7 Stack and Stack Pointer

## 1.7.1 Stack

The stack provides the area in which the return address or status, etc. are saved before a jump is performed to the processing routine during the execution of a subroutine call instruction or the acceptance of an interrupt. On a subroutine call instruction [CALL a] / [CALLP n] / [CALLV n], the contents of the PC (the return address) is saved; on an interrupt acceptance, the contents of the PC and the PSW are saved (the PSW is pushed first, followed by  $PC_H$  and  $PC_L$ ). Therefore, a subroutine call occupies two bytes on the stack; an interrupt occupies three bytes.

When returning from the processing routine, executing a subroutine return instruction [RET] restores the contents to the PC from the stack; executing an interrupt return instruction [RETI] / [RETN] restores the contents to the PC and the PSW (the  $PC_L$  is popped first, followed by  $PC_H$  and PSW).

The stack can be located anywhere within the data memory space except the register bank area, therefore the stack depth is limited only by the free data memory size.

### 1.7.2 Stack Pointer (SP)

The stack pointer (SP) is a 16-bit register containing the address of the next free locations on the stack.

The SP is post-decremented when a subroutine call or a push instruction is executed, or when an interrupt is accepted; and the SP is pre-incremented when a return or a pop instruction is executed. Figure 1-8 shows the stacking order.

The SP is not initialized hardware-wise but requires initialization by an initialize routine (sets the highest stack address). [LD SP, mn], [LD SP, gg] and [LD gg, SP] are the SP access instructions (mn ; 16-bit immediate data, gg ; register pair).

Example 1 : To initialize the SP

LD SP, 043FH ; SP←043FH

Example 2 : To read the SP

LD HL, SP ; HL←SP



Figure 1-7. Stack Pointer



Figure 1-8. Stack

### 1.8 System Clock Controller

The system clock controller consists of a clock generator, a timing generator, and a stand-by controller.



Figure 1-9. System Clock Controller

### 1.8.1 Clock Generator

The clock generator generates the basic clock which provides the system clocks supplied to the CPU core and peripheral hardware. It contains a oscillation circuit for the high-frequency clock.

The high-frequency ( $f_c$ ) clock can be easily obtained by connecting a resonator between the XIN/XOUT pins, respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to the XIN pin with the XOUT pin not connected. The 87C834/C34/H34/K34/M34 is not provided an RC oscillation.



Figure 1-10. Examples of Resonator Connection

**Note :** *Accurate Adjustment of the Oscillation Frequency:*

*Although no hardware to externally and directly monitor the basic clock pulse is not provided, the oscillation frequency can be adjusted by providing a program to output fixed frequency pulses to the port while disabling all interrupts and monitoring this pulse. With a system requiring adjustment of the oscillation frequency, the adjusting program must be created beforehand.*

### 1.8.2 Timing Generator

The timing generator generates from the basic clock the various system clocks supplied to the CPU core and peripheral hardware. The timing generator provides the following functions :

- ① Generation of main system clock
- ② Generation of source clocks for time base timer
- ③ Generation of source clocks for watchdog timer
- ④ Generation of internal source clocks for timer/counters TC1 – TC4
- ⑤ Generation of warm-up clocks for releasing STOP mode
- ⑥ Generation of a clock for releasing reset output

#### (1) Configuration of Timing Generator

The timing generator consists of a 21-stage divider with a divided-by-4 prescaler, a main system clock generator, and machine cycle counters, shown in Figure 1-11 as follows. During reset and upon releasing STOP mode, the divider is cleared to "0", however, the prescaler is not cleared.



Figure 1-11. Configuration of Timing Generator

## (2) Machine Cycle

Instruction execution and peripherals operation are synchronized with the main system clock. The minimum instruction execution unit is called an "machine cycle". There are a total of 10 different types of instructions for the TLCS-870 Series: ranging from 1-cycle instructions which require one machine cycle for execution to 10-cycle instructions which require 10 machine cycles for execution. A machine cycle consists of 4 states (S0 to S3), and each state consists of one main system clock.



Figure 1-12. Machine Cycle

### 1.8.3 Stand-by Controller

The stand-by controller starts and stops the oscillation circuit for the high-frequency clock. Operating modes are controlled by the system control registers (SYSCR1, SYSCR2).

Figure 1-13 shows the operating mode transition diagram and Figure 1-14 shows the system control registers. Either the single-clock or the dual-clock mode can be selected by an option during reset.

## (1) Operating mode

### ① NORMAL mode

In this mode, both the CPU core and on-chip peripherals operate.

② IDLE mode

In this mode, the internal oscillation circuit remains active. The CPU and the watchdog timer are halted; however, on-chip peripherals remain active. IDLE mode is started by setting IDLE bit in the system control register 2 (SYSCR2), and IDLE mode is released to NORMAL mode by an interrupt request from on-chip peripherals or external interrupt inputs. When IMF (interrupt master enable flag) is "1" (interrupt enable), the execution will resume upon acceptance of the interrupt, and the operation will return to normal after the interrupt service is completed. When IMF is "0" (interrupt disable), the execution will resume with the next instruction which follows IDLE mode start instruction.

③ STOP mode

In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with the lowest power consumption during this mode. The output status of all output ports can be set to either output hold or high-impedance under software control.

STOP mode is started by setting STOP bit in the system control register 1 (SYSCR1), and STOP mode is released by an input (either level-sensitive or edge-sensitive can be programmably selected) to the STOP pin. After the warming-up period is completed, the execution resumes with the next instruction which follows the STOP mode start instruction.



Figure 1-13. Operating Mode Transition Diagram

## System Control Register 1

| SYSCR1<br>(0038H) |       |                                        |       |     |                                                                                                            |   |   | (Initial value: 0000 00**) |
|-------------------|-------|----------------------------------------|-------|-----|------------------------------------------------------------------------------------------------------------|---|---|----------------------------|
| 7                 | 6     | 5                                      | 4     | 3   | 2                                                                                                          | 1 | 0 |                            |
| STOP              | RELM  | RETM                                   | OUTEN | WUT |                                                                                                            |   |   |                            |
| R/W               | STOP  | STOP mode start                        |       |     | 0 : CPU core and peripherals remain active<br>1 : CPU core and peripherals are halted<br>(start STOP mode) |   |   |                            |
|                   | RELM  | Release method for STOP mode           |       |     | 0 : Edge-sensitive release<br>1 : Level-sensitive release                                                  |   |   |                            |
|                   | RETM  | Operating mode after STOP mode         |       |     | 0 : Return to NORMAL mode<br>1 : Reserved                                                                  |   |   |                            |
|                   | OUTEN | Port output control during STOP mode   |       |     | 0 : High-impedance<br>1 : Remain unchanged                                                                 |   |   |                            |
|                   | WUT   | Warming-up time at releasing STOP mode |       |     | 00 : $3 \times 2^{19} / fc$ [s]<br>01 : $2^{19} / fc$<br>1* : Reserved                                     |   |   |                            |

Note 1 : Always set RETM to "0" when transitioning from NORMAL mode to STOP mode.

Note 2 : If 87C834/C34/H34/K34/M34 is moved to STOP mode while OUTEN = "0", internal inputs fix "0".

Then there is a possibility to set interrupt of falling edge.

Note 3 : Bits 1 and 0 in SYSCR1 are read in as undefined data when a read instruction is executed.

Note 4 : fc ; high-frequency clock [Hz]

\* ; don't care

Note 5 : 87C834/C34/H34/K34/M34 returns to NORMAL mode without value of RETM, when STOP mode is returned by input of RESET pin.

## System Control Register 2

| SYSCR2<br>(0039H) |      |                 |      |   |                                                                                                      |   |   | (Initial value: 1000 ****) |
|-------------------|------|-----------------|------|---|------------------------------------------------------------------------------------------------------|---|---|----------------------------|
| 7                 | 6    | 5               | 4    | 3 | 2                                                                                                    | 1 | 0 |                            |
| "1"               | "0"  | "0"             | IDLE |   |                                                                                                      |   |   |                            |
| R/W               | IDLE | IDLE mode start |      |   | 0 : CPU and watchdog timer remain active<br>1 : CPU and watchdog timer are stopped (start IDLE mode) |   |   |                            |
|                   |      |                 |      |   |                                                                                                      |   |   |                            |

Note 1 : A reset is applied (RESET pin output goes low) if both bit 7 in SYSCR2 are cleared to "0".

Note 2 : Do not clear bit 7 in SYSCR2 to "0", and do not set bits 6-5 in SYSCR2 to "1".

Note 3 : \* ; don't care

Note 4 : Bits 3 - 0 in SYSCR2 are always read in as "1" when a read instruction is executed.

Figure 1-14. System Control Registers

### 1.8.4 Operating Mode Control

#### (1) STOP mode

STOP mode is controlled by the system control register 1 (SYSCR1) and the STOP pin input. The STOP pin is also used both as a port P20 and an INT5 (external interrupt input 5) pin. STOP mode is started by setting STOP (bit 7 in SYSCR1) to "1". During STOP mode, the following status is maintained.

- ① Oscillation is turned off, and all internal operations are halted.
- ② The data memory, registers and port output latches are all held in the status in effect before STOP mode was entered. The port output can be select either output hold or high-impedance by setting OUTEN (bit 4 in SYSCR1).
- ③ The divider of the timing generator is cleared to "0".
- ④ The program counter holds the address of the instruction following the instruction which started STOP mode.

STOP mode includes a level-sensitive release mode and an edge-sensitive release mode, either of which can be selected with RELM (bit 6 in SYSCR1).

##### a. Level-sensitive release mode (RELM = 1)

In this mode, STOP mode is released by setting the STOP pin high. This mode is used for capacitor back-up when the main power supply is cut off and for long term battery back-up.

When the STOP pin input is high, executing an instruction which starts the STOP mode will not place in STOP mode but instead will immediately start the release sequence (warm-up). Thus, to start STOP mode in the level-sensitive release mode, it is necessary for the program to first confirm that the STOP pin input is low. The following one method can be used for confirmation:

- Using an external interrupt input INT5 (INT5 is a falling edge-sensitive input).

Example : Starting STOP mode with an INT5 interrupt.

|         |                            |                                                                    |
|---------|----------------------------|--------------------------------------------------------------------|
| PINT5 : | TEST (P2) . 0              | ; To reject noise, STOP mode does not start if port P20 is at high |
|         | JRS F, SINT5               |                                                                    |
|         | LD (SYSCR1), 01000000B     | ; Sets up the level-sensitive release mode.                        |
|         | SET (SYSCR1) . 7           | ; Starts STOP mode                                                 |
|         | LDW (IL) 1110011101010111B | ; IL12, 11, 7, 5, 3 ← 0 (clears interrupt latches)                 |
| SINT5 : | RETI                       |                                                                    |



Figure 1-15. Level-sensitive Release Mode

Note1 : After warming up is started, when STOP pin input is changed "L" level, STOP mode is not placed.

Note2 : When changing to the level-sensitive release mode from the edge-sensitive release mode, the release mode is not switched until a rising edge of the STOP pin input is detected.

**b. Edge-sensitive release mode (RELM = 0)**

In this mode, STOP mode is released by a rising edge of the  $\overline{\text{STOP}}$  pin input. This is used in applications where a relatively short program is executed repeatedly at periodic intervals. This periodic signal (for example, a clock from a low-power consumption oscillator) is input to the  $\overline{\text{STOP}}$  pin.

In the edge-sensitive release mode, STOP mode is started even when the  $\overline{\text{STOP}}$  pin input is high.

Example : Starting STOP mode operation in the edge-sensitive release mode

```

LD  (SYSCR1),0000000B ; OUTEN<-0 (specifies high-impedance)
DI ; IMF<-0 (disables interrupt service)
SET (SYSCR1).STOP ; STOP<-1 (activates stop mode)
LDW (IL),1110011101010111B ; IL12,11,7,5,3<-0 (clears interrupt latches)
EI ; IMF<-1 (enables interrupt service)

```



Figure 1-16. Edge-sensitive Release Mode

STOP mode is released by the following sequence:

- ① The high-frequency clock oscillator is turned on.
- ② A warming-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Two different warming-up times can be selected with WUT (bits 2 and 3 in SYSCR1) as determined by the resonator characteristics.
- ③ When the warming-up time has elapsed, normal operation resumes with the instruction following the STOP mode start instruction (e.g. [SET (SYSCR1). 7]). The start is made after the divider of the timing generator is cleared to "0".

Table 1-1. Warming-up Time Example

| WUT                                           | At $f_c = 4.194304$ MHz | At $f_c = 8$ MHz   |
|-----------------------------------------------|-------------------------|--------------------|
| $3 \times 2^{19} / f_c$ [s]<br>$2^{19} / f_c$ | 375 [ms]<br>125         | 196.6 [ms]<br>65.5 |

**Note :** The warming-up time is obtained by dividing the basic clock by the divider: therefore, the warming-up time may include a certain amount of error if there is any fluctuation of the oscillation frequency when STOP mode is released. Thus, the warming-up time must be considered an approximate value.

STOP mode can also be released by setting the  $\overline{\text{RESET}}$  pin low, which immediately performs the normal reset operation.



Figure 1-17. STOP Mode Start / Release

**Note :** When STOP mode is released with a low hold voltage, the following cautions must be observed.  
The power supply voltage must be at the operating voltage level before releasing the STOP mode. The  $\overline{\text{RESET}}$  pin input must also be high, rising together with the power supply voltage. In this case, if an external time constant circuit has been connected, the  $\overline{\text{RESET}}$  pin input voltage will increase at a slower rate than the power supply voltage. At this time, there is a danger that a reset may occur if input voltage level of the  $\overline{\text{RESET}}$  pin drops below the non-inverting high-level input voltage (hysteresis input).

## (2) IDLE mode

IDLE mode is controlled by the system control register 2 and maskable interrupts. The following status is maintained during IDLE mode.

- ① Operation of the CPU and watchdog timer is halted. On-chip peripherals continue to operate.
- ② The data memory, CPU registers and port output latches are all held in the status in effect before IDLE mode was entered.
- ③ The program counter holds the address of the instruction following the instruction which started IDLE mode.

Example : Starting IDLE mode.

SET (SYSCR2).4 ; IDLE←1

IDLE mode includes a normal release mode and an interrupt release mode. Selection is made with the interrupt master enable flag (IMF). Releasing the IDLE mode returns to NORMAL mode.

### a. Normal release mode (IMF = "0")

IDLE mode is released by any interrupt source enabled by the individual interrupt enable flag (EF). Execution resumes with the instruction following the IDLE mode start instruction (e.g. [SET (SYSCR2).4]). Normally, IL (Interrupt Latch) of interrupt source to release IDLE mode must be cleared by load instructions.

### b. Interrupt release mode (IMF = "1")

IDLE mode is released and interrupt processing is started by any interrupt source enabled with the individual interrupt enable flag (EF). After the interrupt is processed, the execution resumes from the instruction following the instruction which started IDLE mode.

IDLE mode can also be released by setting the  $\overline{\text{RESET}}$  pin low, which immediately performs the reset operation. After reset, the 87CH34A/K34A/M34A are placed in NORMAL mode.

**Note :** When a watchdog timer interrupt is generated immediately before IDLE mode is started, the watchdog timer interrupt will be processed but IDLE mode will not be started.



Figure 1-18. IDLE Mode



Figure 1-19. IDLE Mode Start/Release

## 1.9 Interrupt Controller

The 87CH34B/K34B/M34B has a total of 14 interrupt sources: 5 externals and 9 internals. Nested interrupt control with priorities is also possible. Two of the internal sources are pseudo non-maskable interrupts; the remainder are all maskable interrupts.

Interrupt latches (IL) that hold the interrupt requests are provided for interrupt sources. Each interrupt vector is independent.

The interrupt latch is set to "1" when an interrupt request is generated and requests the CPU to accept the interrupt. The acceptance of maskable interrupts can be selectively enabled and disabled by the program using the interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). When two or more interrupts are generated simultaneously, the interrupt is accepted in the highest priority order as determined by the hardware. Figure 1-20 shows the interrupt controller.

Table 1-2. Interrupt Sources

| Interrupt Source  |                                           | Enable Condition           | Interrupt Latch  | Vector Table Address | Priority |
|-------------------|-------------------------------------------|----------------------------|------------------|----------------------|----------|
| Internal/External | (Reset)                                   | Non-Maskable               | —                | FFFE <sub>H</sub>    | High 0   |
| Internal          | INTSW (Software interrupt)                | Pseudo non-maskable        | —                | FFFC <sub>H</sub>    | 1        |
| Internal          | INTWDT (Watchdog Timer interrupt)         |                            | IL <sub>2</sub>  | FFFA <sub>H</sub>    | 2        |
| External          | INT0 (External interrupt 0)               | IMF = 1, INT0EN = 1        | IL <sub>3</sub>  | FFF8 <sub>H</sub>    | 3        |
| Internal          | INTTC1 (16-bit TC1 interrupt)             | IMF · EF <sub>4</sub> = 1  | IL <sub>4</sub>  | FFF6 <sub>H</sub>    | 4        |
| reserved          |                                           | IMF · EF <sub>5</sub> = 1  | IL <sub>5</sub>  | FFF4 <sub>H</sub>    | 5        |
| Internal          | INTTBT (Time Base Timer interrupt)        | IMF · EF <sub>6</sub> = 1  | IL <sub>6</sub>  | FFF2 <sub>H</sub>    | 6        |
| External          | INT2 (External interrupt 2)               | IMF · EF <sub>7</sub> = 1  | IL <sub>7</sub>  | FFF0 <sub>H</sub>    | 7        |
| Internal          | INTTC3 (8-bit TC3 interrupt)              | IMF · EF <sub>8</sub> = 1  | IL <sub>8</sub>  | FFEE <sub>H</sub>    | 8        |
| Internal          | INTSBI (Serial bus Interface interrupt)   | IMF · EF <sub>9</sub> = 1  | IL <sub>9</sub>  | FFEC <sub>H</sub>    | 9        |
| Internal          | INTTC4 (8-bit TC4 interrupt)              | IMF · EF <sub>10</sub> = 1 | IL <sub>10</sub> | FFEA <sub>H</sub>    | 10       |
| External          | INT3 (External interrupt 3)               | IMF · EF <sub>11</sub> = 1 | IL <sub>11</sub> | FFE8 <sub>H</sub>    | 11       |
| External          | INT4 (External interrupt 4)               | IMF · EF <sub>12</sub> = 1 | IL <sub>12</sub> | FFE6 <sub>H</sub>    | 12       |
| Internal          | INTOSD (OSD interrupt / SLICER interrupt) | IMF · EF <sub>13</sub> = 1 | IL <sub>13</sub> | FFE4 <sub>H</sub>    | 13       |
| Internal          | INTTC2 (16-bit TC2 interrupt)             | IMF · EF <sub>14</sub> = 1 | IL <sub>14</sub> | FFE2 <sub>H</sub>    | 14       |
| External          | INT5 (External interrupt 5)               | IMF · EF <sub>15</sub> = 1 | IL <sub>15</sub> | FFE0 <sub>H</sub>    | Low 15   |

### (1) Interrupt Latches (IL<sub>15</sub> to 2)

Interrupt latches are provided for each source, except for a software interrupt. The latch is set to "1" when an interrupt request is generated, and requests the CPU to accept the interrupt. The latch is cleared to "0" just after the interrupt is accepted. All interrupt latches are initialized to "0" during reset.

The interrupt latches are assigned to addresses 003C<sub>H</sub> and 003D<sub>H</sub> in the SFR. Each latch can be cleared to "0" individually by an instruction; however, the *read-modify-write instruction* such as bit manipulation or operation instructions *cannot be used* (Do not clear the IL2 for a watch dog timer interrupt to "0"). Thus, interrupt requests can be cancelled and initialized by the program. Note that interrupt latches cannot be set to "1" by any instruction.

The contents of interrupt latches can be read out by an instruction. Therefore, testing interrupt requests by software is possible.

Example 1 : Clears interrupt latches

LDW (IL), 1110101010111111B ; IL<sub>12</sub>, IL<sub>10</sub>, IL<sub>8</sub>, IL<sub>6</sub>←0



Figure 1-20. Interrupt Controller Block Diagram

## Example 2 : Reads interrupt latches

LD WA, (IL) ; W←IL<sub>H</sub>, A←IL<sub>L</sub>

### Example 3: Tests an interrupt latch

TEST (ILH).4 ; if IL<sub>12</sub> = 1 then jump  
JR F, SSET

## (2) Interrupt Enable Register (EIR)

The interrupt enable registers (EIR) enable and disable the acceptance of interrupts, except for the pseudo non-maskable interrupts (software and watchdog timer interrupts). Pseudo non-maskable interrupts are accepted regardless of the contents of the EIR; however, the pseudo non-maskable interrupts cannot be nested more than once at the same time. For example, the watchdog timer interrupt is not accepted during the software interrupt service.

The EIR consists of an interrupt master enable flag (IMF) and individual interrupt enable flags (EF). These registers are assigned to addresses  $003A_H$  and  $003B_H$  in the SFR, and can be read and written by an instruction (including read-modify-write instructions such as bit manipulation instructions).

## ① Interrupt Master enable Flag (IMF)

The interrupt master enable flag (IMF) enables and disables the acceptance of all interrupts, except for pseudo non-maskable interrupts. Clearing this flag to "0" disables the acceptance of all maskable interrupts. Setting to "1" enables the acceptance of interrupts.

acceptance of all maskable interrupts. Setting to "1" enables the acceptance of interrupts. When an interrupt is accepted, this flag is cleared to "0" to temporarily disable the acceptance of maskable interrupts. After execution of the interrupt service program, this flag is set to "1" by the maskable interrupt return instruction [RETI] to again enable the acceptance of interrupts. If an interrupt request has already been occurred, interrupt service starts immediately after execution of the [RETI] instruction.

Pseudo non-maskable interrupts are returned by the [RETN] instruction. In this case, the IMF is set to "1" only when pseudo non-maskable interrupt service is started with interrupt acceptance enabled (IMF = 1). Note that the IMF remains "0" when cleared by the interrupt service program.

The IMF is assigned to bit 0 at address 003AH in the SFR, and can be read and written by an instruction. The IMF is normally set and cleared by the [EI] and [DI] instructions, and the IMF is initialized to "0" during reset.

## ② Individual interrupt Enable Flags (EF<sub>15</sub> to EF<sub>4</sub>)

These flags enable and disable the acceptance of individual maskable interrupts. Setting the corresponding bit of an individual interrupt enable flag to "1" enables acceptance of an interrupt, setting the bit to "0" disables acceptance.

Example 1 : Sets EF for individual interrupt enable, and sets IMF to "1".

LDW (EIR), 1110100000000001B ; EF<sub>15</sub>~EF<sub>13</sub>, EF<sub>11</sub>, IMF←1

Example 2 : Sets an individual interrupt enable flag to "1".

SET (EIRH).4 ; EF<sub>12</sub>←1



**Note1 : Do not use any read-modify-write instruction such as bit manipulation for clearing IL.**

**Note2 : Do not clear the IL2 by an instruction.**

**Note3 : Do not set IMF to "1" during non-maskable interrupt service programs.**

Figure 1-21. Interrupt Latch (IL) and Interrupt Enable Register (EIR)

### 1.9.1 Interrupt Sequence

An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to "0" by a reset or an instruction. Interrupt acceptance sequence requires 8 machine cycles (4  $\mu$ s at  $f_c = 8$  MHz in NORMAL mode) after the completion of the current instruction execution. The interrupt service task terminates upon execution of an interrupt return instruction [RETI] (for maskable interrupts) or [RETN] (for pseudo non-maskable interrupts).

(1) Interrupt acceptance processing is as follows:

- ① The interrupt master enable flag (IMF) is cleared to "0" to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled.
- ② The interrupt latch (IL) for the interrupt source accepted is cleared to "0".
- ③ The contents of the program counter (return address) and the program status word are saved (pushed) onto the stack. The stack pointer is decremented 3 times.
- ④ The entry address of the interrupt service program is read from the vector table address, and the entry address is loaded to the program counter.
- ⑤ The instruction stored at the entry address of the interrupt service program is executed.



Figure 1-22. Timing Chart of Interrupt Acceptance and Interrupt Return Instruction

Example : Correspondence between vector table address for INTTBT and the entry address of the interrupt service program.



A maskable interrupt is not accepted until the IMF is set to "1" even if a maskable interrupt of higher priority than that of the current interrupt being serviced.

When nested interrupt service is necessary, the IMF is set to "1" in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags.

(2) Saving / Restoring General-purpose Register

During interrupt acceptance processing, the program counter and the program status word are automatically saved on the stack, but not the accumulator and other registers. These registers are saved by the program if necessary. Also, when nesting multiple interrupt services, it is necessary to avoid using the same data memory area for saving registers.

The following method is used to save/restore the general-purpose registers:

① General-purpose register save/restore by register bank changeover:

General-purpose registers can be saved at high-speed by switching to a register bank that is not in use. Normally, bank 0 is used for the main task and banks 1 to 15 are assigned to interrupt service tasks. To increase the efficiency of data memory utilization, the same bank is assigned for interrupt sources which are not nested.

The switched bank is automatically restored by executing an interrupt return instruction [RETI] or [RETN]. Therefore, it is not necessary for a program to save the RBS.

Example : Register Bank Changeover

|          |                      |        |   |                                        |                           |
|----------|----------------------|--------|---|----------------------------------------|---------------------------|
| PINTxx : | LD                   | RBS, n | ; | Switches to bank n (1 $\mu$ s at 8MHz) |                           |
|          | Interrupt processing |        |   |                                        |                           |
|          | RETI                 |        |   | ;                                      | Restores bank and Returns |



Figure 1-23. Saving/Restoring General-purpose Registers

② General-purpose register save/restore using push and pop instructions:

To save only a specific register, and when the same interrupt source occurs more than once, the general-purpose registers can be saved/restored using push/pop instructions.

## Example : Register save using push and pop instructions



## ③ General-purpose registers save/restore using data transfer instructions:

Data transfer instructions can be used to save only a specific general-purpose register during processing of a single interrupt.

## Example : Saving/restoring a register using data transfer instructions

PINTxx :      LD      (GSAVA), A              ; Save A register  
                   [interrupt processing]  
                   LD      A, (GSAVA)              ; Restore A register  
                   RETI                              ; Return

(3) The interrupt return instructions [RETI] / [RETN] perform the following operations.

| [RETI] Maskable interrupt return                                                                                                                                                                                  | [RETN] Non-maskable interrupt return                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>① The contents of the program counter and the program status word are restored from the stack.</p> <p>② The stack pointer is incremented 3 times.</p> <p>③ The interrupt master enable flag is set to "1".</p> | <p>① The contents of the program counter and program status word are restored from the stack.</p> <p>② The stack pointer is incremented 3 times.</p> <p>③ The interrupt master enable flag is set to "1" only when a non-maskable interrupt is accepted in interrupt enable status. However, the interrupt master enable flag remains at "0" when so clear by an interrupt service program.</p> |

Interrupt requests are sampled during the final cycle of the instruction being executed. Thus, the next interrupt can be accepted immediately after the interrupt return instruction is executed.

*Note : When the interrupt processing time is longer than the interrupt request generation time, the interrupt service task is performed but not the main task.*

### 1.9.2 Software Interrupt (INTSW)

Executing the [SWI] instruction generates a software interrupt and immediately starts interrupt processing (INTSW is highest prioritized interrupt). However, if processing of a non-maskable interrupt is already underway, executing the SWI instruction will not generate a software interrupt but will result in the same operation as the [NOP] instruction. Thus, the [SWI] instruction behaves like the [NOP] instruction.

*Note : At the development tool, if processing of a non-maskable interrupt is already underway, executing the SWI instruction will generate a software interrupt as a software brake.*

Use the [SWI] instruction only for detection of the address error or for debugging.

① Address Error Detection

$FF_H$  is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address. Code  $FF_H$  is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing  $FF_H$  to unused areas of the program memory. the address trap reset is generated in case that an instruction fetch from a port of RAM area or SER area .

*Note : The fetch data from addresses  $7F80_H$  to  $7FFF_H$  (test ROM area) is not " $FF_H$ ".*

② Debugging

Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address.

### 1.9.3 External Interrup

The 87CH34B/K34B/M34B have five external interrupt inputs ( $\overline{INT0}$ , INT2, INT3, INT4, and  $\overline{INT5}$ ). Three of these are equipped with digital noise reject circuits (pulse inputs of less than a certain time are eliminated as noise). Edge selection is also possible with INT2, INT3 and INT4.

The  $\overline{INT0}/P50$  pin can be configured as either an external interrupt input pin or an input/output port, and is configured as an input port during reset.

Edge selection, noise reject control and  $\overline{INT0}/P50$  pin function selection are performed by the external interrupt control register (EINTCR). When INT0EN = 0, the IL3 will not be set even if the falling edge of  $\overline{INT0}$  pin input is detected.

Edge selection and noise rejection control for INT3 pin input are performed by the Remote control signal processor control registers (refer to the selection of the Remote control signal processor.)

Table 1-3. External Interrupts

| Source | Pin  | Secondary function pin | Enable conditions          | Edge                                                      | Digital noise reject                                                                                                  |
|--------|------|------------------------|----------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| INT0   | INT0 | P50/PWM8               | IMF = 1, INT0EN = 1        | falling edge                                              | — (hysteresis input)                                                                                                  |
| INT2   | INT2 | P53/TC1                | IMF · EF <sub>7</sub> = 1  | falling edge<br>or<br>rising edge                         | Pulses of less than 7/fc [s] are eliminated as noise. Pulses equal to or more than 24/fc [s] are regarded as signals. |
| INT4   | INT4 | P36/SO                 | IMF · EF <sub>12</sub> = 1 |                                                           |                                                                                                                       |
| INT5   | INT5 | P20/STOP               | IMF · EF <sub>15</sub> = 1 | falling edge                                              | — (hysteresis input)                                                                                                  |
| INT3   | INT3 | P30/RXIN               | IMF · EF <sub>11</sub> = 1 | falling edge,<br>rising edge or<br>falling/rising<br>edge | Refer to the section of the<br>Remote control signal preprocessor.                                                    |

Note 1 : The noise reject function is also affected for timer/counter input (TC1 and TC3 pins).

Note 2 : The pulse width (both "H" and "L" level) for input to the INT0 and INT5 pins must be over 1 machine cycle.



Note 3 : If a noiseless signal is input to the external interrupt pin in the NORMAL or IDLE mode, the maximum time from the edge of input signal until the IL is set is as follows :

① INT2, INT4 pins      25/fc [s]

| EINTCR (0037H)     |                            |  |  |  |  |  |                                                                                     | (Initial value : *000 000*) |
|--------------------|----------------------------|--|--|--|--|--|-------------------------------------------------------------------------------------|-----------------------------|
| INT0EN             | P50/INT0 pin configuration |  |  |  |  |  | 0 : P50 input/output port<br>1 : INT0 pin (Port P50 should be set to an input mode) | R/W                         |
| INT4 ES<br>INT2 ES | INT4, INT2 edge select     |  |  |  |  |  | 0 : Rising edge<br>1 : Falling edge                                                 |                             |

Note 1 : \* ; don't care

Note 2 : Do not change EINTCR when IMF = 1. After changing EINTCR, interrupt latches of external interrupt inputs must be cleared to "0" using load instruction.

Example : Changes INT2 edge selection from rising edge to falling edge

```

DI      ; IMF←0 (disables interrupt service)
LD      (EINTCR),10000110B ; INT2ES←1 (changes edge selection)
LD      (ILL),0111111B    ; IL7←0 (clears interrupt latch)
EI      ; IMF←1 (enables interrupt service)

```

Note 3 : Always write "0" to bit7, 1, 0 in EINTCR.

Note 4 : When high-impedance is specified for port output in stop mode, port input is forcibly fixed to low level internally. Thus, interrupt latches of external interrupt inputs except P20 (INT5/STOP) which are also used as ports may be set to "1". To specify high-impedance for port output in stop mode, first disable interrupt service (IMF = 0), activate stop mode. After releasing stop mode, clear interrupt latches using load instruction, then, enable interrupt service.

Example : Activating stop mode

```

LD      (SYSCR1),1000000B ; OUTEN←0 (specifies high-impedance)
DI      ; IMF←0 (disables interrupt service)
SET    (SYSCR1).STOP      ; STOP←1 (activates stop mode)
LDW   (ILL),1110011101110111B ; IL12,11,7,3←0 (clears interrupt latches)
EI      ; IMF←1 (enables interrupt service)

```

Figure 1-24. External Interrupt Control Register

## 1.10 Watchdog Timer (WDT)

The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or the like, and resumes the CPU to the normal state.

The watchdog timer signal for detecting malfunction can be selected either as a reset output or a non-maskable interrupt request. However, selection is possible only once after reset. At first, the reset output is selected.

When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals.

### 1.10.1 Watchdog Timer Configuration



Figure 1-25. Watchdog Timer Configuration

### 1.10.2 Watchdog Timer Control

Figure 1-26 shows the watchdog timer control registers (WDTCR1, WDTCR2). The watchdog timer is automatically enabled after reset.

### (1) Malfunction detection methods using the watchdog timer

The CPU malfunction is detected as follows:

- ① Setting the detection time, selecting output, and clearing the binary counter.
- ② Repeatedly clearing the binary counter within the setting detection time.

If a CPU malfunction occurs for any cause, the watchdog timer output will become active on the rise of an overflow from the binary counters unless the binary counters are cleared. At this time, when  $WDTOUT = 1$  a reset is generated, which drives the RESET pin low to reset the internal hardware and the external circuits. When  $WDTOUT = 0$ , a watchdog timer interrupt (INTWDT) is generated.

The watchdog timer temporarily stops counting in STOP mode (including warm-up) or IDLE mode, and automatically restarts (continues counting) when STOP/IDLE mode is released.

**Example :** Sets the watchdog timer detection time to 221/fc [s] and resets the CPU malfunction.



Figure 1-26. Watchdog Timer Control Registers

## (2) Watchdog Timer Enable

The watchdog timer is enabled by setting WDTEN (bit 3 in WDTCR1) to "1". WDTEN is initialized to "1" during reset, so the watchdog timer operates immediately after reset is released.

Example : Enables watchdog timer

LD (WPTCR1), 00001000B : WDTEN<1

### (3) Watchdog Timer Disable

The watchdog timer is disabled by writing the disable code ( $B1_H$ ) to WDTCR2 after clearing WDTEN (bit 3 in WDTCR1) to "0". The watchdog timer is not disabled if this procedure is reversed and the disable code is written to WDTCR2 before WDTEN is cleared to "0". The watchdog timer is halted temporarily in STOP mode (including warm-up) and IDLE mode, and restarts automatically after STOP or IDLE mode is released.

During disabling the watchdog timer, the binary counters are cleared to "0".

Example : Disables watchdog timer

LDW (WDTCR1), 0B101H ; WDTEN $\leftarrow$ 0, WDTCR2 $\leftarrow$ disable code

### 1.10.3 Watchdog Timer Interrupt (INTWDT)

This is a pseudo non-maskable interrupt which can be accepted regardless of the contents of the EIR. If a watchdog timer interrupt or a software interrupt is already accepted, however, the new watchdog timer interrupt waits until the previous non-maskable interrupt processing is completed (the end of the [RETN] instruction execution).

The stack pointer (SP) should be initialized before using the watchdog timer output as an interrupt source with WDTOUT.

Example : Watchdog timer interrupt setting up.

LD SP, 043FH ; Sets the stack pointer  
LD (WDTCR1), 00001000B ; WDTOUT $\leftarrow$ 0

### 1.10.4 Watchdog Timer Reset

If the watchdog timer output becomes active, a reset is generated, which drives the RESET pin (sink open drain output) low to reset the internal hardware and the external circuits. The reset output time is  $220/fc$  [s] (131 ms at  $fc = 8$  MHz)



Figure 1-27. Watchdog Timer Interrupt / Reset

## 1.11 Reset Circuit

The TLCS-870 Series has four types of reset generation procedures: an external reset input, an address-trap-reset, a watchdog timer reset and a system-clock-reset. Table 1-4 shows on-chip hardware initialization by reset action. The internal source reset circuit (watchdog timer reset, address trap reset, and system clock reset) is not initialized when power is turned on. Thus, output from the RESET pin may go low ( $220/fc$  [s] (131 ms at 8 MHz) when power is turned on.

Table 1-4. Initializing Internal Status by Reset Action

| On-chip Hardware                       | Initial Value                           | On-chip Hardware            | Initial Value                     |
|----------------------------------------|-----------------------------------------|-----------------------------|-----------------------------------|
| Program counter (PC)                   | $(\text{FFFF}_H) \cdot (\text{FFFE}_H)$ | Divider of Timing generator | 0                                 |
| Register bank selector (RBS)           | 0                                       | Watchdog timer              | Enable                            |
| Jump status flag (JF)                  | 1                                       | Output latches of I/O ports | Refer to I/O port circuitry       |
| Interrupt master enable flag (IMF)     | 0                                       | Control registers           | Refer to each of control register |
| Interrupt individual enable flags (EF) | 0                                       |                             |                                   |
| Interrupt latches (IL)                 | 0                                       |                             |                                   |

### 1.11.1 External Reset Input

When the **RESET** pin is held at low for at least 3 machine cycles ( $12/\text{fc} [\text{s}]$ ) with the power supply voltage within the operating voltage range and oscillation stable, a reset is applied and the internal state is initialized.

When the **RESET** pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses  $\text{FFFE}_H$  to  $\text{FFFF}_H$ .

The **RESET** pin contains a Schmitt trigger (hysteresis) with an internal pull-up resistor. A simple power-on-reset can be applied by connecting an external capacitor and a diode.



Figure 1-28. Simple Power-on-Reset Circuitry

### 1.11.2 Address-Trap-Reset

If a CPU malfunction occurs and an attempt is made to fetch an instruction from the RAM or the SFR area (addresses  $0000_H$  to  $043F_H$ ), and address-trap-reset will be generated. Then, the **RESET** pin output will go low. The reset time is  $220/\text{fc} [\text{s}]$  (131 ms at  $\text{fc} = 8 \text{ MHz}$ ).



Figure 1-29. Address-Trap-Reset

### 1.11.3 Watchdog Timer Reset

Refer to Section "1.10 Watchdog Timer".

### 1.11.4 System-Clock-Reset

Clearing bit 7 in SYSCR2 to "0" stops high-frequency oscillation, and causes the MCU to deadlock. This can be prevented by automatically generating a reset signal whenever (bit7 in SYSCR2) = 0 is detected to continue the oscillation. Then, the **RESET** pin output goes low from high-impedance. The reset time is  $220/\text{fc} [\text{s}]$  (131 ms at  $\text{fc} = 8 \text{ MHz}$ ).

## 2. ON-CHIP PERIPHERALS FUNCTIONS

### 2.1 Special Function Registers (SFR) and Data Buffer Registers (DBR)

The TLCS-870 Series uses the memory mapped I/O system and all peripherals control and data transfers are performed through the special function registers (SFR) and data buffer registers (DBR).

The SFR are mapped to addresses  $0000_H$  to  $003F_H$ , and the DBR to addresses  $0F80_H$  to  $0FFF_H$ .

Figure 2-1 shows the list of the 87CH34B/K34B/M34B SFRs and DBRs.

| Address  | Read                                                 | Write                                   | Address  | Read                                         | Write                                |
|----------|------------------------------------------------------|-----------------------------------------|----------|----------------------------------------------|--------------------------------------|
| $0000_H$ | reserved                                             |                                         | $0020_H$ | —                                            | SBICR1 (SBI control 1)               |
| 01       | reserved                                             |                                         | 21       | SBIDBR (SBI data buffer)                     |                                      |
| 02       | P2 Port                                              |                                         | 22       | —                                            | I2CAR (I <sup>2</sup> C-bus address) |
| 03       | P3 Port                                              |                                         | 23       | SBISR (SBI status)                           | SBICR2 (SBI control 2) **            |
| 04       | P4 Port                                              |                                         | 24       | reserved                                     |                                      |
| 05       | P5 Port                                              |                                         | 25       | PWMSR (PWM status)                           | PWMCR (PWM control)                  |
| 06       | P6 Port                                              |                                         | 26       | —                                            | PWMDBR (PWM data buffer)             |
| 07       | P7 Port                                              |                                         | 27       | PULSECR (Pulse output control)               |                                      |
| 08       | reserved                                             |                                         | 28       | —                                            | PSCR (P5 I/O control)                |
| 09       | reserved                                             |                                         | 29       | reserved                                     |                                      |
| 0A       | reserved                                             |                                         | 2A       | reserved                                     |                                      |
| 0B       | reserved                                             |                                         | 2B       | reserved                                     |                                      |
| 0C       | —                                                    | P4CR (P4 I/O control)                   | 2C       | reserved                                     |                                      |
| 0D       | —                                                    | P6CR (P6 I/O control)                   | 2D       | reserved                                     |                                      |
| 0E       | —                                                    | CMPCR (Comparator)                      | 2E       | reserved                                     |                                      |
| 0F       | CMPDR (Comparator input data register input control) |                                         | 2F       | reserved                                     |                                      |
| 10       | —                                                    | TREG1A <sub>L</sub> (Timer register 1A) | 30       | reserved                                     |                                      |
| 11       | —                                                    | TREG1A <sub>H</sub>                     | 31       | reserved                                     |                                      |
| 12       | TREG1B <sub>L</sub> (Timer register 1B)              |                                         | 32       | reserved                                     |                                      |
| 13       | TREG1B <sub>H</sub>                                  |                                         | 33       | reserved                                     |                                      |
| 14       | —                                                    | TC1CR (TC1 control)                     | 34       | —                                            | WDTCR1 (WDT control)                 |
| 15       | —                                                    | TC2CR (TC2 control)                     | 35       | —                                            | WDTCR2                               |
| 16       | —                                                    | TREG2 <sub>L</sub> (Timer register 2)   | 36       | TBTCR (TBT / TG / DVO control)               |                                      |
| 17       | —                                                    | TREG2 <sub>H</sub>                      | 37       | EINTCR (Exter. interrupt control)            |                                      |
| 18       | —                                                    | TREG3A (Timer register 3A)              | 38       | SYSCR1 (System control)                      |                                      |
| 19       | TREG3B (Timer register 3B)                           |                                         | 39       | SYSCR2                                       |                                      |
| 1A       | —                                                    | TC3CR (TC3 control)                     | 3A       | EIR <sub>L</sub> (Interrupt enable register) |                                      |
| 1B       | —                                                    | TREG4 (Timer register 4)                | 3B       | EIR <sub>H</sub>                             |                                      |
| 1C       | —                                                    | TC4CR (TC4 control)                     | 3C       | IL <sub>L</sub> (Interrupt latch)            |                                      |
| 1D       | reserved                                             |                                         | 3D       | IL <sub>H</sub>                              |                                      |
| 1E       | reserved                                             |                                         | 3E       | reserved                                     |                                      |
| 1F       | reserved                                             |                                         | 3F       | PSW (Program status word)                    | RBS (Register bank selector)         |

*Note \*\* : Higher 4bits are able to read and write.*

(a) Special Function Registers

Figure 2-1-1. SFR & DBR

| Address | Read                                 | Write                                           |
|---------|--------------------------------------|-------------------------------------------------|
| 0F80H   | -                                    | -                                               |
| 0F90    | OSD register                         | OSD control register                            |
| 94      | OSD register                         | -                                               |
| 95      | OSD register                         | -                                               |
| 96      | -                                    | -                                               |
| 97      | -                                    | -                                               |
| 98      | SIFDR0 (SIF data register 0)         | -                                               |
| 99      | SIFDR1 (SIF data register 1)         | -                                               |
| 9A      | SIFSR (SIF data register)            | -                                               |
| 9B      | -                                    | SIFMRS (SIF mode setting register)              |
| 9C      | reserved                             | reserved                                        |
| 0FA0    | SIFSR (Slicer status register)       | SIFSMS1 (Slicer mode setting register 1)        |
| A1      | -                                    | TVSCR (Test video signal control)               |
| A2      | SLVLCR (Slice level register)        | SLVL (Slicer level control register)            |
| A3      | -                                    | -                                               |
| A4      | -                                    | -                                               |
| A5      | -                                    | -                                               |
| A6      | -                                    | DACLCR (Sync chip slice level setting register) |
| A7      | reserved                             | -                                               |
| A8      | -                                    | -                                               |
| A9      | -                                    | -                                               |
| AA      | reserved                             | -                                               |
| AB      | -                                    | JECCR (Jitter elimination control register)     |
| AC      | -                                    | -                                               |
| 0FCF    | reserved                             | reserved                                        |
| 0FD0    | RXCR1 (Remo-con control 1)           | -                                               |
| D1      | RXCR2 (Remo-con control 2)           | -                                               |
| D2      | RXCTR (Remo-con receive counter)     | -                                               |
| D3      | RXDBR (Remo-con receive data buffer) | -                                               |
| D4      | RXSR (Remo-con status)               | -                                               |
| D5      | reserved                             | -                                               |
| 0FFF    | reserved                             | reserved                                        |

(b) Data Buffer Registers

**Note 1 :** Do not access reserved areas by the program.

**Note 2 :** - : Cannot be accessed.

**Note 3 :** When defining address  $003F_H$  with assembler symbols, use GPSW and GRBS.

**Note 4 :** Write-only registers and interrupt latches cannot use the read-modify-write instructions (bit manipulation instructions such as SET, CLR, etc. and logical operation instructions such as AND, OR, etc.)

**Note 5 :** SB1 : Serial Interface.

PWM : Pulse Width Modulation

OSD : On screen display

Remo-con : Remote control

Figure 2-1-2. SFR &amp; DBR

## 2.2 I/O Ports

The 87CH34B/K34B/M34B has 6 parallel input/output ports (35 pins) as follows:

|         | Primary Function | Secondary Functions                                                                                                                                           |
|---------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port P2 | 1-bit I/O port   | external interrupt input, and STOP mode release signal input                                                                                                  |
| Port P3 | 6-bit I/O port   | external interrupt input, remote control signal input, timer/counter input/output, serial bus interface input/output, slicer interface input and serial ports |
| Port P4 | 8-bit I/O port   | pulse width modulation output                                                                                                                                 |
| Port P5 | 8-bit I/O port   | pulse width modulation output, pulse output, comparator input, external interrupt input, timer/counter input, and serial ports                                |
| Port P6 | 8-bit I/O port   | R, G, B and Y/BL output from OSD circuitry, R.G.B and Y/BL input, and test video signal output                                                                |
| Port P7 | 2-bit I/O port   | horizontal synchronous pulse input and vertical synchronous pulse input to OSD circuitry                                                                      |

Each output port contains a latch, which holds the output data. All input ports do not have latches, so the external input data should either be held externally until read or reading should be performed several times before processing. Figure 2-2 shows input/output timing examples.

External data is read from an I/O port in the S1 state of the read cycle during execution of the read instruction. This timing can not be recognized from outside, so that transient input such as chattering must be processed by the program.

Output data changes in the S2 state of the write cycle during execution of the instruction which writes to an I/O port.



Figure 2-2. Input/Output Timing (Example)

When reading an I/O port except programmable I/O ports, whether the pin input data or the output latch contents are read depends on the instructions, as shown below:

### (1) Instructions that read the output latch contents

- ① XCH r, (src)
- ② CLR/SET/CPL (src).b
- ③ CLR/SET/CPL (pp).g
- ④ LD (src).b, CF
- ⑤ LD (pp).b, CF
- ⑥ ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), n
- ⑦ (src) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL)

### (2) Instructions that read the pin input data

- ① Instructions other than the above (1)
- ② (HL) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL)

## 2.2.1 Port P2 (P20)

Port P2 is a 1-bit input/output port. It is also used as an external interrupt input, and a STOP mode release signal input. When used as an input port, or a secondary function pin, the output latch should be set to "1". During reset, the output latch is initialized to "1".

It is recommended that pin P20 should be used as an external interrupt input, a STOP mode release signal input, or an input port. If used as an output port, the interrupt latch is set on the falling edge of the P20 output pulse.

When a read instruction for port P2 is executed, bits 7 to 1 in P2 are read in as undefined data.



## 2.2.2 Port P3 (P35 to P30)

Port P3 is a 6-bit input/output port, and is also used as serial bus interface input/output, an external interrupt input, a timer/counter input, and Remote-control signal input, serial interface input. When used as an input port or a secondary function pin, the output latch should be set to "1". The output latches are initialized to "1" during reset.

Example 1: Outputs an immediate data 5AH to port P3.

LD (P3), 5AH ; P3<=5AH

Example 2: Inverts the output of the lower 4bits (P33 - P30) in port P3.

XOR (P3), 00001111B ; P33 to P30<=P33 to P30



Figure 2-4 Port P3

### 2.2.3 Port P4 (P47 to P40)

Port P4 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P4 input/output control register (P4CR). Port P4 is configured as an input if its corresponding P4CR bit is cleared to "0", and as an output if its corresponding P4CR bit is set to "1". During reset, P4CR is initialized to "0", which configures port P4 as an input. The P4 output latches are also initialized to "1".

Data is written into the output latch regardless of the P4CR contents. Therefore initial output data should be written into the output latch before setting P4CR. Port P4 is also used as a pulse width modulation (PWM) output. When used as a PWM output pin, the output pins should be set to the output mode and beforehand the output latch should be set to "1".

**Note** : *Input mode port is read the state of input pin. When input/output mode is used mixed, the contents of output latch setting input mode may be changed by executing bit manipulation instructions.*



|                 |                         |      |      |      |                |      |      |      |                             |                       |  |
|-----------------|-------------------------|------|------|------|----------------|------|------|------|-----------------------------|-----------------------|--|
| P4<br>(0004H)   | 7                       | 6    | 5    | 4    | 3              | 2    | 1    | 0    | (Initial value : 1111 1111) | Note : $i = 7$ to $0$ |  |
|                 | P47                     | P46  | P45  | P44  | P43            | P42  | P41  | P40  |                             |                       |  |
|                 | PWM7                    | PWM6 | PWM5 | PWM4 | PWM3           | PWM2 | PWM1 | PWM0 |                             |                       |  |
| P4CR<br>(000CH) | 7                       | 6    | 5    | 4    | 3              | 2    | 1    | 0    | (Initial value : 0000 0000) |                       |  |
| P4CR            | I/O control for port P4 |      |      |      | 0 : input mode |      |      |      |                             | write only            |  |

Figure 2-5. Ports P4 and P4CR

## 2.2.4 Port P5 (P57 to P50)

Port P5 is an 8-bit input/output port, and is also used as comparator input, a pulse output, external interrupt, timer/counter input/output, and a pulse width modulation (PWM) output. When used as an input port or a secondary function pin, the output latch should be set to "1". The output latches are initialized to "1" during reset.

Example : Cleare of P53 pin ("L" output)  
 CLR (P5) . 3 ; P53←0

Input/output mode of P57~P54 ports is specified by the corresponding bit in the P5 input/output control register (P5CR). Port P5 is configured as an input if its corresponding P5CR bit is cleared to "0", and as an output if its corresponding P5CR bits is set to "1". During reset, P5CR is initialized to "0", which configures port P5 as input. The P5 output latches are also initialized to "0". Data is written into the output latch regardless of the P5CR contents. Therefore initial output data should be written into the output latch before setting P5CR.



Figure 2-6. Ports P5

### 2.2.5 Port P6 (P67 to P60)

Port P6 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input or output mode is selected by the corresponding bit in the input/output control register (P6CR). For example, port P6 is configured as an input if its corresponding P6CR bit is cleared to "0", and as an output if its corresponding bit is set to "1". During reset, P6CR is initialized to "0", which configures port P6 as an input.

Data is written into the output latch regardless of the P6CR contents. Therefore initial output data should be written into the output latch before setting P6CR.

Port P6 is used as an on screen display (OSD) output (R, G, B, and Y/BL signal). When used as an output pin, the output pins should be set to the output mode and beforehand the port P6 data selection register (P67S to P64S) should be set to "1".



Figure 2-7. Ports P6, P6CR, and P67S to P64S

**Note** : Input mode port is read the state of input pin. When input/output mode is used mixed, the contents of output latch setting input mode may be changed by executing bit manipulation instructions.

Exsample : Set the Lower 4 bit in port P6 to the output port and set the other to the input port.

LD (P6CR), 0FH ; P6CR ← 00001111B

## 2.2.6 Port P7 (P73 to P70)

Port P7 is a 2-bit input /output port, and is also used as a vertical synchronous signal ( $\overline{VD}$ ) input and a horizontal synchronous signal ( $\overline{HD}$ ) input for the on screen display (OSD) circuitry.

The output latches, are initialized to "1" during reset. When used as an input port or a secondary function pin, the output latch should be set to "1".

When a read instruction for port P7 is executed, bits 7 to 2 in P7 are read in as undefined data.



Figure 2-8. Ports P7

## 2.3 Time Base Timer (TBT)

The time base timer generates time base for key scanning, dynamic displaying, etc. It also provides a time base timer interrupt (INTTBT). The time base timer is controlled by a control register (TBTCR) shown in Figure 2-10.

An INTTBT is generated on the first rising edge of source clock (the divider output of the timing generator) after the time base timer has been enabled. The divider is not cleared by the program; therefore, only the first interrupt may be generated ahead of the set interrupt period. (Figure 2-9 (b))

*The interrupt frequency (TBTCK) must be selected with the time base timer disabled* (When the time base timer is changed from enabling to disabling, the interrupt frequency can't be changed.) both frequency selection and enabling can be performed simultaneously.



Example : Sets the time base timer frequency to  $fc/216$  [Hz] and enables an INTTBT interrupt.

LD (TBTCR), 00001010B  
SET (EIRL), 6



Figure 2-9. Time Base Timer

| <b>TBTCR</b><br>$(0036_{\text{H}})$                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  | (Initial value : 0**0 0***) |                                            |                                                                                                                                                                                                                                                                                                                                                                                        |     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|-----------------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;"></td> <td style="width: 40%;">Time base timer enable/disable</td> <td style="width: 50%; text-align: center; padding: 2px;">         0 : Disable<br/>         1 : Enable       </td> </tr> </table> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |                             | Time base timer enable/disable             | 0 : Disable<br>1 : Enable                                                                                                                                                                                                                                                                                                                                                              | R/W |
|                                                                                                                                                                                                                                                                                                     | Time base timer enable/disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0 : Disable<br>1 : Enable                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |                             |                                            |                                                                                                                                                                                                                                                                                                                                                                                        |     |
| TBTEN                                                                                                                                                                                                                                                                                               | <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;"></td> <td style="width: 40%;">Time base timer interrupt frequency select</td> <td style="width: 50%; text-align: center; padding: 2px;">         000 : <math>fc/2^{23}</math> [Hz] ( 0.95 Hz at <math>fc = 8</math> MHz)<br/>         001 : <math>fc/2^{21}</math> ( 3.81 at <math>fc = 8</math> MHz)<br/>         010 : <math>fc/2^{16}</math> ( 122.07 at <math>fc = 8</math> MHz)<br/>         011 : <math>fc/2^{14}</math> ( 488.28 at <math>fc = 8</math> MHz)<br/>         100 : <math>fc/2^{13}</math> ( 976.56 at <math>fc = 8</math> MHz)<br/>         101 : <math>fc/2^{12}</math> ( 1953.12 at <math>fc = 8</math> MHz)<br/>         110 : <math>fc/2^{11}</math> ( 3906.25 at <math>fc = 8</math> MHz)<br/>         111 : <math>fc/2^9</math> ( 15625 at <math>fc = 8</math> MHz)       </td> </tr> </table> |                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |                             | Time base timer interrupt frequency select | 000 : $fc/2^{23}$ [Hz] ( 0.95 Hz at $fc = 8$ MHz)<br>001 : $fc/2^{21}$ ( 3.81 at $fc = 8$ MHz)<br>010 : $fc/2^{16}$ ( 122.07 at $fc = 8$ MHz)<br>011 : $fc/2^{14}$ ( 488.28 at $fc = 8$ MHz)<br>100 : $fc/2^{13}$ ( 976.56 at $fc = 8$ MHz)<br>101 : $fc/2^{12}$ ( 1953.12 at $fc = 8$ MHz)<br>110 : $fc/2^{11}$ ( 3906.25 at $fc = 8$ MHz)<br>111 : $fc/2^9$ ( 15625 at $fc = 8$ MHz) |     |
|                                                                                                                                                                                                                                                                                                     | Time base timer interrupt frequency select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 000 : $fc/2^{23}$ [Hz] ( 0.95 Hz at $fc = 8$ MHz)<br>001 : $fc/2^{21}$ ( 3.81 at $fc = 8$ MHz)<br>010 : $fc/2^{16}$ ( 122.07 at $fc = 8$ MHz)<br>011 : $fc/2^{14}$ ( 488.28 at $fc = 8$ MHz)<br>100 : $fc/2^{13}$ ( 976.56 at $fc = 8$ MHz)<br>101 : $fc/2^{12}$ ( 1953.12 at $fc = 8$ MHz)<br>110 : $fc/2^{11}$ ( 3906.25 at $fc = 8$ MHz)<br>111 : $fc/2^9$ ( 15625 at $fc = 8$ MHz) |  |  |  |  |  |                             |                                            |                                                                                                                                                                                                                                                                                                                                                                                        |     |
| <i>Note1 : fc ; High-frequency clock [Hz], * ; don't care</i>                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |                             |                                            |                                                                                                                                                                                                                                                                                                                                                                                        |     |

Figure 2-10. Time Base Timer Control Register

## 2.4 16-bit Timer 1 (TC1)

## 2.4.1 Configuration



Figure 2-11. Timer/Counter 1 (TC1)

## 2.4.2 Control

The timer/counter 1 is controlled by a timer/counter 1 control register (TC1CR) and two 16-bit timer registers (TREG1A and TREG1B). Reset does not affect the TREG1A and TREG1B.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------|-----------------------------|---|---|---|---|---|---|-----|-------|------|-------|------|-----------------------------|--|--|--|-------|--|--|--|--|--|--|--|-------|--|--|--|--|--|--|
| TREG1A<br>(0010, 0011 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TREG1A <sub>H</sub> (0011 <sub>H</sub> )                                                                                                    | TREG1A <sub>L</sub> (0010 <sub>H</sub> ) |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Write only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| TREG1B<br>(0012, 0013 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TREG1B <sub>H</sub> (0013 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Read only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| TC1CR<br>(0014 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">7</td> <td style="width: 10%;">6</td> <td style="width: 10%;">5</td> <td style="width: 10%;">4</td> <td style="width: 10%;">3</td> <td style="width: 10%;">2</td> <td style="width: 10%;">1</td> <td style="width: 10%;">0</td> </tr> <tr> <td>"0"</td> <td>SCAP1</td> <td>TC1S</td> <td>TC1CK</td> <td>TC1M</td> <td colspan="3" style="text-align: right;">(Initial value : 0000 0000)</td> </tr> <tr> <td></td> <td>MCAP1</td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> </tr> <tr> <td></td> <td>METT1</td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> </tr> </table> |                                                                                                                                             |                                          | 7    | 6                           | 5 | 4 | 3 | 2 | 1 | 0 | "0" | SCAP1 | TC1S | TC1CK | TC1M | (Initial value : 0000 0000) |  |  |  | MCAP1 |  |  |  |  |  |  |  | METT1 |  |  |  |  |  |  |
| 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 5                                                                                                                                           | 4                                        | 3    | 2                           | 1 | 0 |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| "0"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SCAP1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TC1S                                                                                                                                        | TC1CK                                    | TC1M | (Initial value : 0000 0000) |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | MCAP1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | METT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| TC1M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TC1 mode select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 00 : timer / external trigger timer / event counter mode<br>01 : window mode<br>10 : pulse width measurement mode<br>11 : reserved          |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| TC1CK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | TC1 source clock select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00 : internal clock $fc/2^{11}$ [Hz]<br>01 : internal clock $fc/2^7$<br>10 : internal clock $fc/2^3$<br>11 : external clock (TC1 pin input) |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| TC1S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TC1 start control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 00 : stop & counter clear<br>01 : command start<br>10 : reserved<br>11 : external trigger start                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| SCAP1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | software capture control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 : - 1 : software capture trigger (Note 3)                                                                                                 |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| MCAP1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | pulse width measurement control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 : double edge capture 1 : single edge capture                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| METT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | external trigger timer control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 : trigger start 1 : trigger start & stop                                                                                                  |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| write only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |
| <p><i>Note 1 : fc ; High-frequency clock [Hz]</i></p> <p><i>Note 2 : Writing to the low-byte of the timer registers (TREG1A<sub>L</sub>, TREG1B<sub>L</sub>), the comparison is inhibited until the high-byte (TREG1A<sub>H</sub>, TREG1B<sub>H</sub>) is written.</i></p> <p><i>Note 3 : Set the mode, source clock, edge, PPG control and timer F/F control when TC1 stops (TC1S = 00).</i></p> <p><i>Note 4 : Software capture can be used in only timer and event counter modes.</i></p> <p><i>Note 5 : Values to be loaded to timer registers must satisfy the following condition.</i></p> <p style="text-align: center;"><i>TREG1A &gt; 0</i></p> <p><i>Note 6 : TC1CR is write-only register and must not be used with any of the read-modify-write instructions such as SET, CLR, etc. TC1CR must be used with load instructions.</i></p> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                             |                                          |      |                             |   |   |   |   |   |   |     |       |      |       |      |                             |  |  |  |       |  |  |  |  |  |  |  |       |  |  |  |  |  |  |

Figure 2-12. Timer Registers and TC1 Control Register

## 2.4.3 Function

Timer/counter 1 has five operating modes: timer, external trigger timer, event counter, window, pulse width measurement mode.

### (1) Timer Mode

In this mode, counting up is performed using the internal clock. The contents of the timer register 1A (TREG1A) are compared with the contents of the up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0". Counting up resumes after the counter is cleared. The current contents of the up-counter can be transferred to the timer register 1B (TREG1B) by setting SCAP1 (bit 6 in TC1CR) to "1" (software capture function). SCAP1 is automatically cleared to "0" after capturing.

Table 2-1. Timer 1 Source Clock (Internal Clock)

| Source clock     | Resolution (At $f_c = 8$ MHz) | Maximum time setting (At $f_c = 8$ MHz) |    |
|------------------|-------------------------------|-----------------------------------------|----|
| $f_c / 2^3$ [Hz] | 1 $\mu$ s                     | 65.535                                  | ms |
| $f_c / 2^7$      | 16 $\mu$ s                    | 1.04856                                 | s  |
| $f_c / 2^{11}$   | 256 $\mu$ s                   | 16.77696                                | s  |

Example 1 : Sets the source clock to  $f_c/27$ [Hz] and generates an interrupt 1 [s] later (at  $f_c = 8$  MHz).

```

LD      (TC1CR), 00000100B      ; Sets the TC1 source clock
LDW     (TREG1A), 0F424H        ; Sets the timer register (1s ÷  $f_c / 2^7$  = F42416)
SET     (EIRL), EF4           ; Enables INTTC1 interrupt
EI
LD      (TC1CR), 00010100B      ; Starts TC1

```

Example 2 : Software capture

```

LD      (TC1CR), 01010100B      ; SCAP1←1 (Captures)
LD      WA, (TREG1B)           ; Reads captured value

```



Figure 2-13. Timer Mode Timing Chart

## (2) External Trigger Timer mode

This is the timer mode to start counting up by the external trigger. The trigger is the edge of the TC1 pin input. Either rising or falling edge can be selected with INT2ES. Edge selection is the same as for the external interrupt input INT2 pin. Source clock is used an internal clock selected with the TC1CK. The contents of the TREG1A is compared with the contents of the up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0" and halted. The counter is restarted by the selected edge of the TC1 pin input.

The TC1 pin input has the same noise rejection as the INT2 pin; therefore, pulses of  $7/f_c$  [s] or less are eliminated as noise. A pulse width of  $24/f_c$  [s] or more is required for edge detection in the NORMAL or IDEL mode.



Figure 2-14. External Trigger Timer Mode Timing Chart

### (3) Event Counter Mode

In this mode, events are counted at the edge of the TC1 pin input. Either rising or falling edge can be selected with INT2ES in EINTCR. The contents of the TREG1A are compared with the contents of the up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. The maximum applied frequency is  $fc/24$  [Hz] in the NORMAL or IDLE mode.

Setting SCAP1 to "1" transfers the current contents of the up-counter to the TREG1B (software capture function).



Figure 2-15. Event Counter Mode Timing Chart (INT2ES = 1)

#### (4) Window mode

Counting up is performed at the rising edge of the pulse that is the logical AND-ed product of the TC1 pin input (window pulse) and an internal clock. The contents of the TREG1A are compared with the contents of the up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Positive or negative logic for the TC1 pin input can be selected with INT2ES. Setting SCAP1 to "1" transfers the current contents of the up-counter to the TREG1B. It is necessary that the maximum applied frequency (TC1 input) be such that the counter value can be analyzed by the program. That is, the frequency must be considerably slower than the selected internal clock.



Figure 2-16. Window Mode Timing Chart

#### (5) Pulse width measurement mode

Counting is started by the external trigger (set to external trigger start by TC1S). The trigger is selected either rising or falling edge of the TC1 pin input. The source clock is used an internal clock. At the next falling (rising) edge, the counter contents are transferred to the TREG1B and an INTTC1 interrupt is generated. The counter is cleared when single edge capture mode is set. When double edge capture is set, the counter continues and, at the next rising (falling) edge, the counter contents are again transferred to the TREG1B. If a falling (rising) edge capture value is required, it is necessary to read out the TREG1B contents until a rising (falling) edge is detected. Falling or rising edge is selected with INT2ES, and single edge or double edge is selected with MCAP1 (bit 6 in TC1CR).



Figure 2-17. Pulse Width Measurement Mode Timing Chart

Example : Duty measurement (Resolution  $f_c/2^7$  [Hz])

```

CLR  (INTTC1C).0          ; INTTC1 service switch initial setting
LD   (EINTCR), 0000000B    ; Sets the rise edge at the INT2 edge
LD   (TC1CR), 00000110B    ; Sets the TC1 mode and source clock
SET  (EIRL).4              ; Enables INTTC1
LD   (TC1CR), 00110110B    ; Starts TC1 with an external trigger
:
PINTTC1: CPL  (INTTC1C).0  ; Complements INTTC1 service switch
      JRS  F, SINTTC1
      LD   (HPULSE), (TREG1BL) ; Reads TREG1B
      LD   (HPULSE + 1), (TREG1BH)
      RETI
SINTTC1: LD   (WIDTH), (TREG1BL) ; Reads TREG1B (Period)
      LD   (WIDTH + 1), (TREG1BH)
      :

```

## 2.5 16-bit Timer/Counter 2 (TC2)

### 2.5.1 Configuration



Figure 2-18. Timer/Counter 2 (TC2)

## 2.5.2 Control

The timer/counter 2 is controlled by a timer/counter 2 control register (TC2CR) and a 16-bit timer register 2 (TREG2). Reset does not affect the TREG2.

| TREG2<br>(0016, 0017 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                       | 15                                                                                                                                                                                                         | 14         | 13 | 12 | 11 | 10 | 9 | 8 | 7                                       | 6 | 5 | 4 | 3 | 2 | 1 | 0    |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----|----|----|----|---|---|-----------------------------------------|---|---|---|---|---|---|------|---------------------------------------|-------------------------------------------------|------------|-------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------------------|-----------------------------------------|--|--|--|--|--|--|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                       | TREG2 <sub>H</sub> (0017 <sub>H</sub> )                                                                                                                                                                    |            |    |    |    |    |   |   | TREG2 <sub>L</sub> (0016 <sub>H</sub> ) |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
| write only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                       |                                                                                                                                                                                                            |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
| TC2CR<br>(0015 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                       |                                                                                                                                                                                                            |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
| (Initial value : **00 00*0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                       |                                                                                                                                                                                                            |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 25%;">TC2M</td> <td style="width: 25%;">Timer/counter 2 operating mode select</td> <td style="width: 50%;">0 : Timer/Event counter mode<br/>1 : Window mode</td> <td rowspan="4" style="width: 25%; vertical-align: middle; text-align: center;">write only</td> </tr> <tr> <td>TC2CK</td> <td>Timer/counter 2 source clock select</td> <td>           000 : Internal clock <math>fc / 2^{23}</math> [Hz]<br/>           001 : " <math>fc / 2^{13}</math><br/>           010 : " <math>fc / 2^8</math><br/>           011 : " <math>fc / 2^3</math><br/>           100 : Reserved<br/>           101 : Reserved<br/>           110 : Reserved<br/>           111 : External clock (TC2 pin input)         </td> </tr> <tr> <td>TC2S</td> <td>Timer/counter 2 start control</td> <td>0 : Stop and counter clear<br/>1 : Start</td> </tr> <tr> <td></td> <td></td> <td></td> </tr> </table> |                                       |                                                                                                                                                                                                            |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   | TC2M | Timer/counter 2 operating mode select | 0 : Timer/Event counter mode<br>1 : Window mode | write only | TC2CK | Timer/counter 2 source clock select | 000 : Internal clock $fc / 2^{23}$ [Hz]<br>001 : " $fc / 2^{13}$<br>010 : " $fc / 2^8$<br>011 : " $fc / 2^3$<br>100 : Reserved<br>101 : Reserved<br>110 : Reserved<br>111 : External clock (TC2 pin input) | TC2S | Timer/counter 2 start control | 0 : Stop and counter clear<br>1 : Start |  |  |  |  |  |  |  |
| TC2M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Timer/counter 2 operating mode select | 0 : Timer/Event counter mode<br>1 : Window mode                                                                                                                                                            | write only |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
| TC2CK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Timer/counter 2 source clock select   | 000 : Internal clock $fc / 2^{23}$ [Hz]<br>001 : " $fc / 2^{13}$<br>010 : " $fc / 2^8$<br>011 : " $fc / 2^3$<br>100 : Reserved<br>101 : Reserved<br>110 : Reserved<br>111 : External clock (TC2 pin input) |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
| TC2S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Timer/counter 2 start control         | 0 : Stop and counter clear<br>1 : Start                                                                                                                                                                    |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                       |                                                                                                                                                                                                            |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |
| <p><i>Note 1 : fc; High-frequency clock [Hz], *; don't care</i></p> <p><i>Note 2 : When writing to the low-byte of the timer register 2 (TREG2<sub>L</sub>), the comparison is inhibited until the high-byte (TREG2<sub>H</sub>) is written.</i></p> <p><i>After writing to the high-byte, any match during 1 machine cycle (instruction execution cycle) is ignored.</i></p> <p><i>Note 3 : Set the mode and source clock when timer/counter stop (TC2S = 0).</i></p> <p><i>Note 4 : Values to be loaded to the timer register must satisfy the following condition.</i></p> <p><i>TREG2 &gt; 0 (TREG2<sub>15~11</sub> &gt; 0 when warm-up).</i></p> <p><i>Note 5 : The TC2CR and the TREG2 are write-only registers and must not be used with any of the read-modify-write instructions such as SET, CLR, etc.</i></p>                                                                                                                                                            |                                       |                                                                                                                                                                                                            |            |    |    |    |    |   |   |                                         |   |   |   |   |   |   |      |                                       |                                                 |            |       |                                     |                                                                                                                                                                                                            |      |                               |                                         |  |  |  |  |  |  |  |

Figure 2-19. Timer Register 2 and TC2 Control Register

## 2.5.3 Function

The timer/counter 2 has three operating modes: timer, event counter and window modes.

### (1) Timer Mode

In this mode, the internal clock is used for counting up. The contents of the timer register 2 (TREG2) are compared with the contents of the up-counter. If a match is found, a timer/counter 2 interrupt (INTTC2) is generated, and the counter is cleared. Counting up is resumed after the counter is cleared.

Table 2-2. Source Clock (Internal Clock) for Timer 2

| Source clock        | Resolution (At $f_c = 8$ MHz) | Maximum time setting (At $f_c = 8$ MHz) |
|---------------------|-------------------------------|-----------------------------------------|
| $f_c / 2^{23}$ [Hz] | 1.048576 s                    | 19 hour 5 min 18.4 s                    |
| $f_c / 2^{13}$      | 1.024 ms                      | 1 min 7.1 s                             |
| $f_c / 2^8$         | 32 $\mu$ s                    | 2.09712 s                               |
| $f_c / 2^3$         | 1 $\mu$ s                     | 65.535 ms                               |

Example : Sets the source clock  $f_c/2^3$  [Hz] and generates an interrupt every 25 ms (at  $f_c = 8$  MHz).

```

LD      (TC2CR), 00001100B      ; Sets the source clock
LDW     (TREG2), 61A8H          ; Sets TREG2 (25ms ÷ 23/fc = 61A8H)
SET     (EIRH). EF14          ; Enables INTTC2 interrupt
EI
LD      (TC2CR), 00101100B      ; Starts TC2

```

### (2) Event Counter Mode

In this mode, events are counted at the rising edge of the TC2 pin input. The contents of TREG2 are compared with the contents of the up-counter. If a match is found, an INTTC2 interrupt is generated, and the counter is cleared. The maximum frequency applied to the TC2 pin is  $f_c/2^4$  [Hz] in the NORMAL and IDLE mode.

Example : Sets the event counter mode and generates an INTTC2 interrupt 640 counts later.

```

LD      (TC2CR), 00011100B      ; Sets the TC2 mode
LDW     (TREG2), 640            ; Sets TREG2
LD      (TC2CR), 00111100B      ; Starts TC2

```

### (3) Window Mode

In this mode, counting up is performed at rising edge of the pulse that is the logical AND-ed product of the TC2 pin input (window pulse) and an internal clock. The internal clock is selected with the TC2CK. The contents of the TREG2 are compared with the contents of the up-counter. If a match is found, an INTTC2 interrupt is generated, and the up-counter is cleared to "0". It is necessary that the maximum applied frequency (TC2 input) be such that the counter value can be analyzed by the program. That is, the frequency must be considerably slower than the selected internal clock.



Figure 2-20. Window Mode Timing Chart

## 2.6 8-Bit Timer/Counter 3 (TC3)

### 2.6.1 Configuration



Figure 2-21. Timer/Counter (TC3)

## 2.6.2 Control

The timer/counter 3 is controlled by a timer/counter 3 control register (TC3CR) and two 8-bit timer registers (TREG3A and TREG3B). Reset does not affect these timer registers.

|                                |                                                                           |                                                                                                                                                      |
|--------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| TREG3A<br>(0018 <sub>H</sub> ) | 7 6 5 4 3 2 1 0                                                           | Read/Write                                                                                                                                           |
| TREG3B<br>(0019 <sub>H</sub> ) | 7 6 5 4 3 2 1 0                                                           | Read only                                                                                                                                            |
| TC3CR<br>(001A <sub>H</sub> )  | 7 6 5 4 3 2 1 0<br>SCAP TC3S TC3CK TC3M                                   | (Initial value: *0*0 00*0)                                                                                                                           |
| TC3M                           | Timer/counter 3 operation mode select                                     | 0 : Timer/event counter mode<br>1 : Capture mode                                                                                                     |
| TC3CK                          | Timer/counter 3 source clock select                                       | 00 : Internal clock $fc / 2^{12}$ [Hz]<br>01 : Internal clock $fc / 2^{10}$<br>10 : Internal clock $fc / 2^7$<br>11 : External clock (TC3 pin input) |
| TC3S                           | Timer/counter 3 start control                                             | 0 : Stop and counter clear<br>1 : Start                                                                                                              |
| SCAP                           | Software capture control                                                  | 0 : -<br>1 : Software capture                                                                                                                        |
| EINTCR<br>(0037 <sub>H</sub> ) | 7 6 5 4 3 2 1 0<br>"0" (INT0ES) (TC4ES) (INT4ES) (TC3ES) (INT2ES) "0" "0" | (Initial value: 0000 000*)                                                                                                                           |
| TC3ES                          | TC3 edge select                                                           | 0 : Rising edge<br>1 : Falling edge                                                                                                                  |

*Note 1 : fc ; High-frequency clock [Hz], \* ; don't care*  
*Note 2 : Set the mode, the source clock and the edge selection (TC3ES) when the TC3 stops (TC3S = 0).*  
*Note 3 : Values to be loaded to timer register 3A must satisfy the following condition.*  
*TC3CR > 0 (in the timer/event counter mode)*  
*Note 4 : TC3CR and EINTCR is a write-only-register and must not be used with any of read-modify-write instructions.*  
*Note 5 : Always write "0" to bit 7 and 2-1 in EINTCR.*

Figure 2-22. Timer Register 3 and TC3 Control Registers

## 2.6.3 Function

The timer/counter 3 has three operating modes : timer, event counter, and capture mode.

### (1) Timer Mode

In this mode, the internal clock shown in Table 2-3 is used for counting up. The contents of TREG3A are compared with the contents of the up-counter. If a match is found, a timer/counter 3 interrupt (INTTC3) is generated, and the up-counter is cleared. Counting up resumes after the up-counter is cleared. The current contents of up-counter are loaded into TREG3B by setting SCAP (bit 6 in TC3CR) to "1". SCAP is automatically cleared after capturing.

Table 2-3. Source Clock (Internal Clock) for Timer/Counter 3

| Source clock  | Resolution (AT fc = 8 MHz) | Maximum setting time (AT fc = 8 MHz) |
|---------------|----------------------------|--------------------------------------|
| $fc / 2^{12}$ | 512 $\mu$ s                | 130.56 ms                            |
| $fc / 2^{10}$ | 128 $\mu$ s                | 32.64 ms                             |
| $fc / 2^7$    | 16 $\mu$ s                 | 4.08 ms                              |

### (2) Event Counter Mode

In this mode, the TC3 pin input pulse are used for counting up. Either the rising or falling edge can be selected with TC3ES (bit 3 in EINTCR). The contents of TREG3A are compared with the contents of the up-counter. If a match is found, an INTTC3 interrupt is generated and the counter is cleared. The maximum applied frequency is  $fc/24$  [Hz]. Two or more machine cycles are required for both the high and low levels of the pulse width.

The current contents of up-counter are loaded into TREG3B by setting SCAP (bit 6 in TC3CR) to "1". SCAP is automatically cleared after capturing.

Example : Generates an interrupt every 0.5 s, inputting 50Hz pulses to the TC3 pin.

```

LD      (TC3CR), 00001100B      ; Sets TC3 mode and source clock
LD      (TREG3A), 19H           ; 0.5 [s] ÷ 1 / 50 = 25 = 19H
SET    (EIRH).EF8            ; Enables INTTC3 interrupt
EI
LD      (TC3CR), 00011100B      ; Starts TC3

```

### (3) Capture Mode

The pulse width, period and duty of the TC3 pin input are measured in this mode, which can be used in decoding the remote control signal, etc. The counter is running free by the internal clock. On the rising (falling) edge of the TC3 pin input, the current contents of counter is loaded into TREG3A, then the up-counter is cleared to "0" and an INTTC3 interrupt is generated. On the falling (rising) edge of the TC3 pin input, the current contents of the counter is loaded into TREG3B. In this case, counting continued. On the next rising (falling) edge of the TC3 pin input, the current contents of counter are loaded into TREG3A, then the counter is cleared again and an interrupt is generated. If the counter overflows before the edge is detected, FF<sub>H</sub> is set to the TREG3A and an overflow interrupt (INTTC3) is generated. During interrupt processing, it can determine whether or not there is an overflow by checking whether or not the TREG3A value is FF<sub>H</sub>. Also, after an interrupt (capture to TREG3A, or overflow detection) is generated, capture and overflow detection are halted until TREG3A has been read out; however, the counter continues. After TREG3A has been read out, capture and overflow detection start again. Therefore, TREG3B must be read out earlier than TREG3A.



Figure 2-23. Timing Chart for Capture Mode (TC3ES = 0)

## 2.7 8-bit Timer/Counter (TC4)

### 2.7.1 Configuration



Figure 2-24. Timer/Counter 4

### 2.7.2 Control

The timer/counter 4 is controlled by a timer/counter 4 control register (TC4CR) and an 8-bit timer register 4 (TREG4). Reset does not affect the TREG4.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |                           |                                                                                                                                                                            |            |          |          |                             |     |                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|----------|-----------------------------|-----|------------------------------|
| TREG4<br>(001B <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 7     | 6                         | 5                                                                                                                                                                          | 4          | 3        | 2        | 1                           | 0   | Write only                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 7     | 6                         | 5                                                                                                                                                                          | 4          | 3        | 2        | 1                           | 0   |                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | "1"   | "1"                       | "0"                                                                                                                                                                        | TC4S       | TC4CK    | TC4M     | (Initial value : 00*0 0000) |     |                              |
| TC4CR<br>(001C <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TC4M  | TC4 operating mode select | 00 : Timer/event counter mode<br>01 : Reserved<br>1* : Reserved                                                                                                            | write only |          |          |                             |     |                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | TC4CK | TC4 source clock select   | 00 : Internal clock fc / 2 <sup>11</sup> [Hz]<br>01 : Internal clock fc / 2 <sup>7</sup><br>10 : Internal clock fc / 2 <sup>3</sup><br>11 : External clock (TC4 pin input) |            |          |          |                             |     |                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | TC4S  | TC4 start control         | 0 : Stop and counter clear<br>1 : Start                                                                                                                                    |            |          |          |                             |     |                              |
| EINTCR<br>(0037 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 7     | 6                         | 5                                                                                                                                                                          | 4          | 3        | 2        | 1                           | 0   |                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | "0"   | (INT0EN)                  | TC4ES                                                                                                                                                                      | (INT4ES)   | (INT3ES) | (INT2ES) | "0"                         | "0" | (Initial value : 0000 0000*) |
| TC4ES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | TC4 edge select           | 0 : Rising edge<br>1 : Falling edge                                                                                                                                        | R/W        |          |          |                             |     |                              |
| <p>Note 1 : fc; High-frequency clock [Hz], *; don't care</p> <p>Note 2 : Set the operating mode, the source clock selection and the edge selection (TC4ES) when the TC4 stops (TC4S = 0).</p> <p>Note 3 : Always write "1" to bit 7 and bit 6 in TC4CR.</p> <p>Note 4 : Values to be loaded to the timer register must satisfy the following condition.<br/><math>TREG4 &gt; 0</math></p> <p>Note 5 : TC4CR and the TREG4 are write-only registers and must not be used with any of the read-modify-write instructions such as SET, CLR, etc.</p> <p>Note 6 : Always write "0" to bit5 in TC4CR.</p> |       |                           |                                                                                                                                                                            |            |          |          |                             |     |                              |

Figure 2-25. Timer Register 4 and TC4 Control Registers

## 2.7.3 Function

The timer/counter 4 has two operating modes : timer and event counter mode.

### (1) Timer Mode

In this mode, the internal clock is used for counting up. The contents of TREG4 are compared with the contents of the up-counter. If a match is found, a timer/counter 4 interrupt (INTTC4) is generated and the counter is cleared. Counting up resumes after the counter is cleared.

Table 2-4. Source Clock (Internal Clock) for Timer/Counter 4

| Source clock        | Resolution (At $f_c = 8$ MHz) | Maximum setting time (At $f_c = 8$ MHz) |         |
|---------------------|-------------------------------|-----------------------------------------|---------|
| $f_c / 2^{11}$ [Hz] | 256 $\mu$ s                   | 65.28                                   | ms      |
| $f_c / 2^7$         | 16 $\mu$ s                    | 4.08                                    | ms      |
| $f_c / 2^3$         | 1 $\mu$ s                     | 255                                     | $\mu$ s |

### (2) Event Counter Mode

In this mode, the TC4 pin input (external clock) pulse is used for counting up. The contents of TREG4 are compared with the contents of the up-counter. If a match is found, an INTTC4 interrupt is generated and the counter is cleared. Counting up resumes after the counter is cleared. The maximum applied frequency is  $f_c/2^4$  [Hz]. Two or more machine cycles are required for both the high and low levels of the pulse width.

## 2.8 Serial Bus Interface (SBI)

The 87CH34B/K34B/M34B has a time-shared two channels serial bus interface which employs a clocked-synchronous 8-bit serial bus interface and an I<sup>2</sup>C bus (a bus system by Philips).

In case of channel-0, the serial interface is connected to an external device through P51 (SDA0) and P50 (SCL0) in the I<sup>2</sup>C bus mode; and through P50 (SCK0), P52 (SO0), and P51 (SI0) in the clocked-synchronous 8-bit SIO mode. The serial bus interface pins are also used for the P5 port. When used for serial interface pins, set the P5 output latches of these pins to "1". When not used for serial bus interface pins, the P5 port is used as a normal I/O port.

In case of channel-1, the serial interface is connected to an external device through P35 (SDA1) and P34 (SCL1) in the I<sup>2</sup>C bus mode; and through P34 (SCK1), and P35 (SI1) in the clocked-synchronous 8-bit SIO mode.

The serial bus interface pins are also used for the P3 port. When used for serial bus interface pins, set the P3 output latches of these pins to "1". When not used for serial bus interface pins, the P3 port is used as a normal I/O port.

When the 87CH34B/K34B/M34B is used as master mode, another devices on same bus must be slave mode. Because the 87CH34B/K34B/M34B serial bus interface (SBI) does not have arbitration function. (single master-bus-system)

The data transfer is carried 9bits (8bits data and 1bit acknowledge) unit.

### 2.8.1 Configuration



Figure 2-26. Serial Bus Interface (SBI)

## 2.8.2 Serial Bus Interface (SBI) Control

The following registers are used for control and operation status monitoring when using the serial bus interface (SBI).

- Serial bus interface control register 1 (SBICR1)
- Serial bus interface control register 2 (SBICR2)
- Serial bus interface data buffer register (SBIDBR)
- I<sup>2</sup>C bus address register (I2CAR)
- Serial bus interface status register (SBISR)

The above registers differ depending on a mode to be used.

Refer to Section "2.8.4 I<sup>2</sup>C bus Mode Control" and "2.8.6 Clocked-synchronous 8-bit SIO Mode Control".

## 2.8.3 The Data Formats in the I<sup>2</sup>C bus Mode

The data formats when using the 87CH34B/K34B/M34B in the I<sup>2</sup>C bus mode are shown below.

(a) Addressing format



(b) Addressing format (with restart)



(c) Free data format



Notes :    *S* ; Start condition  
*R/W* ; Direction bit  
*ACK* ; Acknowledge bit  
*P* ; Stop condition

Figure 2-27. The Data Format in the I<sup>2</sup>C bus Mode

## 2.8.4 I<sup>2</sup>C Bus Mode Control

The following registers are used for control and operation status monitoring when using the serial bus interface (SBI) in the I<sup>2</sup>C bus mode.

| Serial Bus Interface Control Register 1                                                                                                                                                                                                                      |                                                                                 |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|------------|--|--|--|--|--|--|--|
| SBICR1<br>(0020H)                                                                                                                                                                                                                                            | 7                                                                               | 6   | 5                                                                                                                                                                                                                                                                                                                         | 4   | 3   | 2   | 1 0        |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              | “0”                                                                             | “0” | “0”                                                                                                                                                                                                                                                                                                                       | ACK | CHS | SCK |            |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              | (Initial value ***0 0000)                                                       |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
| ACK                                                                                                                                                                                                                                                          | Acknowledge mode specification                                                  |     | 0 : Acknowledge not returned to transmitter.<br>1 : Acknowledge returned to transmitter.                                                                                                                                                                                                                                  |     |     |     | R/W        |  |  |  |  |  |  |  |
| CHS                                                                                                                                                                                                                                                          | Input/Output channel selection                                                  |     | 0 : Channel 0 (SCL0, SDA0)<br>1 : Channel 1 (SCL1, SDA1)                                                                                                                                                                                                                                                                  |     |     |     | R/W        |  |  |  |  |  |  |  |
| SCK                                                                                                                                                                                                                                                          | Frequency of Serial clock (f <sub>SCL</sub> )<br>selection (only master - mode) |     | 000 : fc/2 <sup>6</sup> [Hz] (125 kHz)<br>001 : fc/2 <sup>7</sup> [Hz] (62.5 kHz)<br>010 : fc/2 <sup>8</sup> [Hz] (31.2 kHz)<br>011 : fc/2 <sup>9</sup> [Hz] (15.6 kHz)<br>100 : fc/2 <sup>10</sup> [Hz] (7.8 kHz)<br>101 : fc/2 <sup>12</sup> [Hz] (1.9 kHz)<br>110 : fc/2 <sup>15</sup> [Hz] (244 Hz)<br>111 : reserved |     |     |     | Write only |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              |                                                                                 |     | at fc = 8 MHz<br>( Output on SCL pin )                                                                                                                                                                                                                                                                                    |     |     |     |            |  |  |  |  |  |  |  |
| Note 1 : * ; don't care<br>Note 2 : The SBICR1 (bit7, 6, 5) is writed to normaly "0"<br>Note 3 : SBICR1 has write-only register bits, which cannot access any of in read-modify-write instructions such as bit operate, etc.                                 |                                                                                 |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
| Serial Bus Interface Data Buffer Register                                                                                                                                                                                                                    |                                                                                 |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
| SBIDBR<br>(0021H)                                                                                                                                                                                                                                            | 7                                                                               | 6   | 5                                                                                                                                                                                                                                                                                                                         | 4   | 3   | 2   | 1 0        |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              | “ ”                                                                             | “ ” | “ ”                                                                                                                                                                                                                                                                                                                       | “ ” | “ ” | “ ” | “ ”        |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              | (Initial value **** * ***) Read / Write                                         |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
| Note 1 : Can not read the data which was written into SBIDBR, since a write data buffer and a read buffer are independend in SBIDBR, Therefore, cannot access it any of in read-modify-write instaction such as bit operate, etc.<br>Note 2 : * ; don't care |                                                                                 |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
| I <sup>2</sup> C bus Address Register                                                                                                                                                                                                                        |                                                                                 |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
| I2CAR<br>(0022H)                                                                                                                                                                                                                                             | 7                                                                               | 6   | 5                                                                                                                                                                                                                                                                                                                         | 4   | 3   | 2   | 1 0        |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              | “ ”                                                                             | “ ” | “ ”                                                                                                                                                                                                                                                                                                                       | “ ” | “ ” | “ ” | “ ”        |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              | Slave address<br>SA6   SA5   SA4   SA3   SA2   SA1   SA0   ALS                  |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                              | (Initial value 0000 0000)                                                       |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |
| SA                                                                                                                                                                                                                                                           | 87CH36/K36/M36 slave address<br>selection                                       |     |                                                                                                                                                                                                                                                                                                                           |     |     |     | Write only |  |  |  |  |  |  |  |
| ALS                                                                                                                                                                                                                                                          | Address recognition mode<br>specification                                       |     | 0 : Slave address recognition<br>1 : Non slave address recognition                                                                                                                                                                                                                                                        |     |     |     |            |  |  |  |  |  |  |  |
| Note : I <sup>2</sup> CAR is write-only registers, which cannot access any of in read-modify-write instruction such as bit operate, etc.                                                                                                                     |                                                                                 |     |                                                                                                                                                                                                                                                                                                                           |     |     |     |            |  |  |  |  |  |  |  |

Figure 2-28. Serial Bus Interface Control Register 1/Serial Bus Interface Data Buffer Register/  
I<sup>2</sup>C bus Address Register in the I<sup>2</sup>C bus Mode

| Serial Bus Interface Control Register 2               |                                                                                                                          |   |   |   |   |   |   |   |
|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|
| SBICR2<br>(0023 <sub>H</sub> )                        | 7                                                                                                                        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MST TRX BB PIN SBIM "0" "0" (Initial value 0001 00**) |                                                                                                                          |   |   |   |   |   |   |   |
| MST                                                   | Master/slave selection (Write), Status monitor (Read)                                                                    |   |   |   |   |   |   |   |
| TRX                                                   | Transmitter/receiver selection (Write), Status monitor (Read)                                                            |   |   |   |   |   |   |   |
| BB                                                    | Start/stop generation (Write), I <sup>2</sup> C bus status monitor (Read)                                                |   |   |   |   |   |   |   |
| PIN                                                   | Cancel interrupt service request(Write), Interrupt service request status monitor (Read)                                 |   |   |   |   |   |   |   |
| SBIM                                                  | Serial bus interface operating mode selection                                                                            |   |   |   |   |   |   |   |
|                                                       | 00 : Port mode (serial bus interface output disable)<br>01 : SIO mode<br>10 : I <sup>2</sup> C bus mode<br>11 : Reserved |   |   |   |   |   |   |   |

  

|          |                                                                                                                             |
|----------|-----------------------------------------------------------------------------------------------------------------------------|
| Note 1 : | * ; don't care                                                                                                              |
| Note 2 : | Switch a mode to port mode after confirming that the bus is free.                                                           |
| Note 3 : | Switch a mode to I <sup>2</sup> Cbus mode after confirming that input signals via port are high-level.                      |
| Note 4 : | SBICR2 has write-only register bits, which cannot access any of in read-modify-write instructions such as bit operate, etc. |
| Note 5 : | Write "0" to bit 1,0 in the SBICR2.                                                                                         |

  

| Serial Bus Interface Status Register                      |                                                        |   |   |   |   |   |   |   |
|-----------------------------------------------------------|--------------------------------------------------------|---|---|---|---|---|---|---|
| SBISR<br>(0023 <sub>H</sub> )                             | 7                                                      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MST TRX BB PIN ..... AAS AD0 LRB (Initial value 0001 000) |                                                        |   |   |   |   |   |   |   |
| AAS                                                       | Slave address match detection monitor                  |   |   |   |   |   |   |   |
| AD0                                                       | "GENERAL CALL" detection monitor                       |   |   |   |   |   |   |   |
| LRB                                                       | Last received bit monitor (acknowledge signal monitor) |   |   |   |   |   |   |   |

Figure 2-29. Serial Bus Interface Control Register 2/Serial Bus Interface Status Register in the I<sup>2</sup>Cbus Mode

### (1) Acknowledge mode specification

Set the ACK (bit 4 in the SBICR1) to "1" for operation in the acknowledge mode. In the receiver mode during the clock pulse cycle, the SDA pin is pulled down to the low level in order to generate the acknowledge signal. When the ACK is cleared to "0", the SDA pin released high-level in the acknowledge timing.



Figure 2-30. Acknowledge Signal Output

### (2) Input / Output channel specification

Set the input/output to the CHS (bit 3 in the SBICR1).



Figure 2-31. Channel Selection

### (3) Serial clock

The SCK (bits 2 to 0 in the SBICR1) is used to select a maximum transfer frequency directed from the SCL pin in the master mode. If the rising time of output clock is more  $2/f_c$  [s], "High" period of clock is extended. If the SCK is set to the "Low" Level with the slave device, the clock is stopped in this period. After restart, the  $t_{HC}$  [s] of first clock is set to the  $[t_{SCL}/2] \leq t_{HC} \leq t_{SCL}$ .



Figure 2-32. Serial Clock

**(4) Slave address and address recognition mode specification**

When the 87CH34B/K34B/M34B is used as a slave device, set the slave address and ALS to the I2CAR. Clear the ALS to "0" for the address recognition mode.

**(5) Master/slave selection**

Set the MST (bit 7 in the SBICR2) to "1" for operating the 87CH34B/K34B/M34B as a master device. Reset the MST to "0" for operation as a slave device. The MST is cleared to "0" by the hardware after a stop condition on the bus is detected.

**(6) Transmitter/receiver selection**

Set the TRX (bit 6 in the SBICR2) to "1" for operating the 87CH34B/K34B/M34B as a transmitter. Clear the TRX to "0" for operation as a receiver. When data with an addressing format is transferred in the slave mode, when a slave address with the same value that sets an I2CAR or when a GENERAL CALL is received (all 8-bit data are "0" after a start condition,) the TRX is set to "1" by the hardware if the direction bit (R/W) sent from the master device is "1", and is cleared to "0" by the hardware if the bit is "0". In the master mode, after an acknowledge signal is returned from the slave device with the hardware, the TRX is cleared to "0" by the hardware if a transmitted direction bit is "1", and set to "1" by the hardware if it is "0". When an acknowledge signal is not returned, the current condition is maintained.

The TRX is cleared to "0" by the hardware after a stop condition on the I<sup>2</sup>C bus is detected.

**(7) Start/stop condition generation**

When the BB (bit 5 in the SBICR2) is "0", the slave address and the direction bit which are set to the SBIDBR are output on a bus after generating a start condition by writing "1" to the MST, TRX, BB, and PIN. It is necessary to set transmitted data to the data buffer register (SBIDBR) and set "1" to ACK beforehand.



Figure 2-33. Start Condition Generation and Slave Address Generation

When the BB is "1", a sequence of generating a stop condition is started by writing "1" to the MST, TRX, and PIN, and "0" to the BB.

Do not modify the contents of MST, TRX, BB and PIN until a stop condition is generated on a bus.



Figure 2-34. Stop Condition Generation

The bus condition can be indicated by reading the contents of the BB (bit 5 in the SBISR). The BB is set to "1" when a start condition on a bus is detected, and is cleared to "0" when a stop condition is detected on a bus.

**(8) Interrupt service request and cancel**

When a serial bus interface interrupt request (INTSBI) occurs, the PIN (bit 4 in the SBISR) is cleared to "0". During the time that the PIN is "0", the SCL pin is pulled down to the low level.

The PIN is cleared to "0" when 1-word of data is transmitted or received. Either writing/reading data to/from the SBIDBR sets the PIN to "1".

The time from the PIN being set to "1" until the SCL pin is released takes  $t_{LOW}$ .

In the address recognition mode (ALS = 0), the PIN is cleared to "0" when the received slave address is the same as the value set at the I2CAR or when a GENERAL CALL is received (all 8-bit data are "0" after a start condition). Although the PIN (bit 4 in the SBICR2) can be set to "1" by the program, the PIN is not set to "0" when "0" is written.

**(9) Serial bus interface operation mode selection**

The SBIM (bit 3, 2 in the SBICR2) is used to specify the serial bus interface operation mode. Set the SBIM to "10" when used in the I<sup>2</sup>C bus mode after confirming that input signal via port is high-level. Switch a mode to port after confirming that a bus is free.

**(10) Slave address match detection monitor**

The AAS (bit 2 in the SBISR) is set to "1" in the slave mode, in the address recognition mode (ALS = 0), when receiving GENERAL CALL or a slave address with the same value that is set to the I2CAR. When the ALS is "1", the AAS is set to "1" after receiving the first 1-word of data. The AAS is cleared to "0" by writing/reading data to/from a data buffer register.

**(11) GENERAL CALL detection monitor**

The AD0 (bit 1 in the SBISR) is set to "1" in the slave mode, when all 8-bit received data is "0", after a start condition (GENERAL CALL). The AD0 is cleared to "0" when a start or stop condition is detected on a bus.

**(12) Last received bit monitor**

The SDA value stored at the rising edge of the SCL is set to the LRB (bit 0 in the SBISR). In the acknowledge mode, immediately after an INTSBI interrupt request is generated an acknowledge signal is read by reading the contents of the LSB.

## 2.8.5 Data Transfer in I<sup>2</sup>C bus Mode

**(1) Device Initialization**

Set the ACK, CHS and SCK in the SBICR1. Clear "0" to bit 7 to 5.

Set a slave address and the ALS (ALS = 0 when an addressing format) to the I2CAR.

After confirming that input signal via port are high-level, for specifying the default setting to a slave receiver mode, clear "0" to the MST, TRX, BB and set "1" to the PIN, "10" to the SBIM, and "0" to bit 0 and 1 in the SBICR.

## (2) Start Condition and Slave Address Generation

Confirm a bus free status (when BB = 0).

Set the ACK to "1" and specify a slave address and a direction bit to be transmitted to the SBIDBR.

When the BB is "0", the start condition are generated and the slave address and the direction bit which are set to the SBIDBR are output on a bus by writing "1" to the MST, TRX, BB and PIN. A slave device receives these data and pulls down the SDA line of the bus to the low level at the acknowledge signal timing. An INTSBI interrupt request occurs at the 9th falling edge of the SCL clock cycle, and the PIN is cleared to "0". The SCL pin is pulled down to the low-level while the PIN is "0". When an interrupt request occurs, the TRX changes by the hardware according to the direction bit only when an acknowledge signal is returned from the slave device.



Figure 2-35. Start Condition Generation and Slave Address Transfer

## (3) 1-word Data Transfer

Check the MST by the INTSBI interrupt process after an 1-word data transfer is concluded, and determine whether the mode is a master or slave.

### a. When the MST is "1" (Master mode)

Check the TRX and determine whether the mode is a transmitter or receiver.

#### ① When the TRX is "1" (Transmitter mode)

Check the LRB. When the LRB is "1", a receiver does not request data. Implement the process to generate a stop condition (Refer to 2.8.5. (4) ) and terminate data transfer.

When the LRB is "0", the receiver requests new data. Write the transmitted data to the SBIDBR. After writing the data, the PIN becomes "1", a serial clock pulse is generated for transferring a new 1-word of data from the SCL pin, and then the 1-word data is transmitted from the SDA pin. After the data is transmitted, an INTSBI interrupt request occurs. The PIN becomes "0" and the SCL pin is pulled down to the low-level. If the data to be transferred is more than one word in length, repeat the procedure from the LRB checking above.



Figure 2-36. Example of Transferring data

## ② When the TRX is "0" (Receiver mode)

Set the ACK to "1" and read the received data from the SBIDBR (data which is read immediately after a slave address is sent is undefined). After the data is read, the PIN becomes "1". The 87CH34B/K34B/M34B outputs a serial clock pulse to the SCL pin to transfer new 1-word of data and sets the SDA pin to "0" at the acknowledge signal timing.

An INTSBI interrupt request then occurs and the PIN becomes "0". Then the 87CH34B/K34B/M34B pulls down the SCL pin to the Low-Level. The 87CH34B/K34B/M34B outputs a clock pulse for 1-word of data transfer and the acknowledge signal each time that received data is read from the SBIDBR.



Figure 2-37. Example of Receiving Data

In order to terminate transmitting data to a transmitter, clear the ACK to "0" before reading data which is 1-word before the last data to be received. Then the 87CH34B/K34B/M34B releases SDA pin with "1" at the acknowledge signal timing of the last data to be received, and informs transmitting end to a transmitter.

After data is received and an interrupt request has occurred, the 87CH34B/K34B/M34B generates a stop condition and terminates data transfer. Even if SBIDBR is read at timing of the last data to be received, serial clock and acknowledge signal are not output. There is a reason value of ACK is "0".



Figure 2-38. Termination of Data Transfer in Master Receiver Mode

b. When the MST is "0" (Slave mode)

In the slave mode, an INTSBI interrupt request occurs when the 87CH34B/K34B/M34B receives a slave address or a GENERAL CALL from the master device, or when a GENERAL CALL is received and data transfer is complete after matching a received slave address. When an INTSBI interrupt request occurs, the PIN (bit 4 in the SBICR2) is cleared, and the SCL pin is pulled down to the low-level. Either reading/writing from/to the SBIDBR or setting the PIN to "1" releases the SCL pin after taking  $t_{LOW}$  time.

In the slave mode, the 87CH34B/K34B/M34B operates either in normal slave mode.

Check the TRX (bit 6 in the SBISR), the AAS (bit 2 in the SBISR), and the AD0 (bit 1 in the SBISR) and implements processes according to conditions listed in the next table.

Table 2-5. Operation in the Slave Mode

| TRX | AAS | AD0 | Conditions                                                                                                                                                      | Process                                                                                                                                                                                                                                                       |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | 1   | 0   | In the slave receiver mode, the 87CH34B/K34B/M34B receives a slave address of which the value of the direction bit sent from the master is "1".                 | Write transmitted data to the SBIDBR.                                                                                                                                                                                                                         |
|     | 0   | 0   | In the slave transmitter mode, 1-word data is transmitted.                                                                                                      | Check the LRB. If the LRB is set to "1", set the PIN to "1" since the receiver does not request further data. Then, clear the TRX to release the bus. If the LRB is set to "0" write transmitted data to the SBIDBR since the receiver requests further data. |
| 0   | 1   | 1/0 | In the slave receiver mode, the 87CH34B/K34B/M34B receives a slave address or general CALL of which the value of the direction bit sent from the master is "0". | Read the SBIDBR for setting the PIN to "1" (reading dummy data) or set the PIN to "1".                                                                                                                                                                        |
|     | 0   | 1/0 | In the slave receiver mode, the 87CH34B/K34B/M34B terminates receiving of 1-word data.                                                                          | Read received data from the SBIDBR.                                                                                                                                                                                                                           |

#### (4) Stop Condition Generation

When the BB is "1", a sequence of generating a stop condition is started by setting "1" to the MST, TRX and PIN, and "0" to the BB. Do not modify the contents of the MST, TRX, BB, PIN until a stop condition is generated on a bus. When a SCL line of bus is pulled down by other devices, the 87CH34B/K34B/M34B does not wait to generate a stop condition. Set the stop condition command after confirming a SCL line is free.



Figure 2-39. Stop Condition Generation

#### (5) Restart

Restart is used to change the direction of data transfer between a master device and a slave device during transferring data. The following explains how to restart when the 87CH34B/K34B/M34B is in the master mode.

Clear "0" to the MST, TRX and, BB and set "1" to the PIN and release the bus. The SDA pin retains the high-level and the SCL pin is released. Since a stop condition is not generated on a bus, a bus is assumed to be in a busy state from other devices. Check the BB until it becomes "0" to check that the SCL pin of the 87CH34B/K34B/M34B is released. Check the LRB until it becomes "1" to check that the SCL line on the bus is not pulled down to the low-level by other devices. After confirming that the bus stays in a free state, generate a start condition with procedure 2.8.5 (2).



Figure 2-40. Timing Diagram when Restarting the 87CH34B/K34B/M34B

## 2.8.6 Clocked-synchronous 8-bit SIO Mode Control

The following registers are used for control and operation status monitoring when using the serial bus interface (SBI) in the clocked-synchronous 8-bit SIO mode.

| Serial Bus Interface Control Register 1                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------|---------|--|--|--|--|--|--|
| SBICR1<br>(0020H)                                                                                                                                                                                                                                                                                                                           | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 6                                             | 5    | 4                                                                                                                                                                                                                                                                                                                            | 3    | 2                                     | 1 0     |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SIOS                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SIOINH                                        | SIOM | CHS                                                                                                                                                                                                                                                                                                                          |      | SCK                                   |         |  |  |  |  |  |  |
| (Initial value 0000 0000)                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SIOS                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Indicate transfer start/stop                  |      | 0 : Stop<br>1 : Start                                                                                                                                                                                                                                                                                                        |      | Write only                            |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SIOINH                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Continue/abort transfer                       |      | 0 : Continue transfer<br>1 : Abort transfer (automatically cleared after abort)                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SIOM                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Transfer mode select                          |      | 00 : 8-bit transmit mode<br>01 : reserved<br>10 : 8-bit transmit/receive mode<br>11 : 8-bit receive mode                                                                                                                                                                                                                     |      |                                       |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | CHS                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Input/Output channel selection                |      | 0 : Channel 0 (SCK0, SO0, SIO)<br>1 : Channel 1 (SCK1, SO1)                                                                                                                                                                                                                                                                  |      |                                       | R/W     |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SCK                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Serial clock select                           |      | 000 : fc/2 <sup>6</sup> ( 125 kHz)<br>001 : fc/2 <sup>7</sup> ( 62.5 kHz)<br>010 : fc/2 <sup>8</sup> ( 31.25 kHz)<br>011 : fc/2 <sup>9</sup> ( 15.62 kHz)<br>100 : fc/2 <sup>10</sup> ( 7.81 kHz)<br>101 : fc/2 <sup>12</sup> ( 1.95 kHz)<br>110 : fc/2 <sup>15</sup> ( 244 Hz)<br>111 : External clock (input from SCK pin) |      | at fc = 8 MHz<br>Output on<br>SCK pin |         |  |  |  |  |  |  |
| <p><i>Note 1 : fc ; high-frequency clock [Hz], * ; don't care</i></p> <p><i>Note 2 : Clear the SIOS to "0" and set the SIOINH to "1" when setting the transfer mode or serial clock.</i></p> <p><i>Note 3 : SBICR1 is a write only register, which cannot access any of in read-modify-write instructions such as bit operate, etc.</i></p> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| Serial Bus Interface Data Buffer Register                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| SBIDBR<br>(0021H)                                                                                                                                                                                                                                                                                                                           | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 6                                             | 5    | 4                                                                                                                                                                                                                                                                                                                            | 3    | 2                                     | 1 0     |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| (Initial value **** ****) Read / Write                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| <p><i>Note 1 : Cannot read the data which was written into SBIDBR, since a write data buffer and a read data buffer are independent in SBIDBR. Therefore, cannot access it any of in read-modify-write instructions such as bit operate, etc.</i></p> <p><i>Note 2 : * ; don't care</i></p>                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| Serial Bus Interface Control Register 2                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| SBICR2<br>(0023H)                                                                                                                                                                                                                                                                                                                           | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 6                                             | 5    | 4                                                                                                                                                                                                                                                                                                                            | 3    | 2                                     | 1 0     |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | "0"                                                                                                                                                                                                                                                                                                                                                                                                                                                             | "0"                                           | "0"  | "1"                                                                                                                                                                                                                                                                                                                          | SBIM | "0"                                   | "0"     |  |  |  |  |  |  |
| (Initial value **** 00**) Read / Write                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SBIM                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Serial bus interface operation mode selection |      | 00 : Port mode (serial bus interface output disable)<br>01 : SIO mode<br>10 : I <sup>2</sup> C bus mode<br>11 : reserved                                                                                                                                                                                                     |      | Write only                            |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | <p><i>Note 1 : * ; don't care</i></p> <p><i>Note 2 : Switch a mode to port after data transfer is complete.</i></p> <p><i>Note 3 : Switch a mode to SIO mode after confirming that input signals via port are high-level.</i></p> <p><i>Note 4 : SBICR2 is a write-only register, which cannot access any of in read-modify-write instructions such as bit operate, etc.</i></p> <p><i>Note 5 : Clear "0" to bit 7 to 5, 1 and 0, and set "1" to bit 4.</i></p> |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| Serial Bus Interface Status Register                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
| SBISR<br>(0023H)                                                                                                                                                                                                                                                                                                                            | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 6                                             | 5    | 4                                                                                                                                                                                                                                                                                                                            | 3    | 2                                     | 1 0     |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | "1"                                                                                                                                                                                                                                                                                                                                                                                                                                                             | "1"                                           | "1"  | "1"                                                                                                                                                                                                                                                                                                                          | SIOF | SEF                                   | "1" "1" |  |  |  |  |  |  |
| (Initial value 1111 1111) Read only                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |      |                                                                                                                                                                                                                                                                                                                              |      |                                       |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SIOF                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Serial transfer operating status monitor      |      | 0 : Transfer terminated<br>1 : Transfer in process                                                                                                                                                                                                                                                                           |      | Read only                             |         |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                             | SEF                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Shift operating status monitor                |      | 0 : Shift operation terminated<br>1 : Shift operation in process                                                                                                                                                                                                                                                             |      |                                       |         |  |  |  |  |  |  |

Figure 2-41. Serial Bus Interface Control Register 1/Serial Bus Interface Data Buffer Register/Serial Bus Interface Control Register 2/Serial Bus Interface Status Register in SIO Mode

## (1) Serial Clock

a. Clock source

The SCK (bit 2 to 0 in the SBICR1) is used to select the following functions.

## ① Internal Clock

In an internal clock mode, any of seven frequencies can be selected. The serial clock is output to the outside on the  $\overline{\text{SCK}}$  pin. The  $\overline{\text{SCK}}$  pin becomes a high-level when data transfer starts. When writing (in the transmit mode) or reading (in the receive mode) data cannot follow the serial clock rate, an automatic-wait function is executed to stop the serial clock automatically and hold the next shift operation until reading or writing is complete.



Figure 2-42. Automatic-wait Function

② External clock ( $\overline{\text{SCK}} = "111"$ )

An external clock supplied to the  $\overline{\text{SCK}}$  pin is used as the serial clock. In order to ensure shift operation, a pulse width of longer than 4 machine cycles is required for both high-level and low-level in the serial clock. The maximum data transfer frequency is 250 kHz (when  $\text{fc}=8$  MHz).



Figure 2-43. External Clock

**b. Shift edge**

The leading edge is used to transmit data, and the trailing edge is used to receive data.

**① Leading edge**

Data is shifted on the leading edge of the serial clock (at a falling edge of the  $\overline{SCK}$  pin input/output).

**② Trailing edge**

Data is shifted on the trailing edge of the serial clock (at a rising edge of the  $\overline{SCK}$  pin input/output).



Figure 2-44. Shift Edge

**(2) Transfer mode**

The SIOM (bit 5 and 4 in the SIO1CR) is used to select a transmit, receive, or transmit/receive mode.

**a. 8-bit transmit mode**

Set a control register to a transmit mode and write data to the SBIDBR.

After the transmit data is written, set the SIOS to "1" to start data transfer. The transmitted data is transferred from the SBIDBR to the shift register and output to the SO pin in synchronous with the serial clock, starting from the least significant bit (LSB). When the transmit data is transferred to the shift register, the SBIDBR becomes empty. The INTSBI (buffer empty) interrupt request is generated to request new data.

When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated if new data is not loaded to the data buffer register after the specified 8-bit data is transmitted. When new transmit data is written, automatic-wait function is canceled.

When the external clock is used, data should be written to the SBIDBR before new data is shifted. The transfer speed is determined by the maximum delay time between the time when an interrupt request is generated and the time when data is written to the SBIDBR by the interrupt service program.

When the transmit is started, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the  $\overline{SCK}$ .

Transmitting data is ended by clearing the SIOS to "0" by the buffer empty interrupt service program or setting the SIOINH to "1". When the SIOS is cleared, the transmitted mode ends when all data is output. In order to confirm if data is surely transmitted by the program, set the SIOF (bit 3 in the SBISR) to be sensed. The SIOF is cleared to "0" when transmitting is complete. When the SIOINH is set, transmitting data stops. The SIOF turns "0".

When the external clock is used, it is also necessary to clear the SIOS to "0" before new data is shifted; otherwise, dummy data is transmitted and operation ends.



Figure 2-45. Transfer Mode

Example: Program to stop transmitting data (when external clock is used)

```

STEST1 : TEST    (SBISR) . SEF           ; If SEF = 1 then loop
        JRS     F, STEST1
STEST2 : TEST    (P5) . 0                 ; If SCK0 = 0 then loop
        JRS     T, STEST2
        LD      (SBICR1), 00000111B        ; SIOS ← 0
  
```



Figure 2-46. Transmitted Data Hold Time at End of Transmit

#### b. 8-bit Receive Mode

Set a control register to a receive mode and the SIOS to "1" for switching to a receive mode. Data is received from the SI pin to the shift register in synchronous with the serial clock, starting from the least significant bit (LSB). When the 8-bit data is received, the data is transferred from the shift register to the SBIDBR. The INTSBI (buffer full) interrupt request is generated to request of reading the received data. The data is then read from the SBIDBR by the interrupt service program.

When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated until the received data is read from the SBIDBR.

When the external clock is used, since shift operation is synchronized with the clock pulse provided externally, the received data should be read from the SBIDBR before next serial clock is input. If the received data is not read, further data to be received is canceled. The maximum transfer speed when the external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when received data is read.

Receiving data is ended by clearing the SIOS to "0" by the buffer full interrupt service program or setting the SIOINH to "1". When the SIOS is cleared, received data is transferred to the SBIDBR in complete blocks. The received mode ends when the transfer is complete. In order to confirm if data is surely received by the program, set the SIOF (bit 3 in the SBIDBR) to be sensed. The SIOF is cleared to "0" when receiving is complete. After confirming that receiving has ended, the last data is read. When the SIOINH is set, receiving data stops. The SIOF turns "0" (the received data becomes invalid, therefore no need to read it).

*Note : When the transfer mode is switched, the SBIDBR contents are lost. In case that the mode needs to be switched, receiving data concluded by clearing the SIOS to "0", read the last data, and then switch the mode.*



Figure 2-47. Receive Mode (Example : Internal clock)

#### c. 8-bit Transmit/Receive Mode

Set a control register to a transmit/receive mode and write data to the SBIDBR. After the data is written, set the SIOS to "1" to start transmitting/receiving. When transmitting, the data is output from the SO pin on the leading edges in synchronous with the serial clock, starting from the least significant bit (LSB). When receiving, the data is input to the SI pin on the trailing edges of the serial clock. 8-bit data is transferred from the shift register to the SBIDBR, and the INTSBI interrupt request occurs. The interrupt service program reads the received data from the data buffer register and writes data to be transmitted. The SBIDBR is used for both transmitting and receiving. Transmitted data should always be written after received data is read.

When the internal clock is used, automatic-wait function is initiated until received data is read and next data is written.

When the external clock is used, since the shift operation is synchronized with the external clock, received data is read and transmitted data is written before new shift operation is executed. The maximum transfer speed when the external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when received data is read and transmitted data is written.

When the transmit is started, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the SCK.

Transmitting/receiving data is ended by clearing the SIOS to "0" by the INTSBI interrupt service program or setting the SIOINH to "1". When the SIOS is cleared, received data is transferred to the SBIDBR in complete blocks. The transmit/receive mode ends when the transfer is complete. In order to confirm if data is surely transmitted/received by the program, set the SIOF (bit3 in the SBISR) to be sensed. The SIOF becomes "0" after transmitting/receiving is complete. When the SIOINH is set, transmitting/receiving data stops. The SIOF turns "0".

*Note : When the transfer mode is switched, the SBIDBR contents are lost. In case that the mode needs to be switched, conclude transmitting/receiving data by clearing the SIOS to "0", read the last data, and then switch the transfer mode.*



Figure 2-48. Transmit/Receive Mode (Example : Internal clock)



Figure 2-49. Transmitted Data Hold Time at end of transmit/receive

## 2.9 Remote Control Signal Preprocessor/External Interrupt 3 Input Pin

The remote control signal waveform can be determined by inputting the remote control signal waveform from which the carrier wave was eliminated by the receive circuit to P30 (INT3/RXIN) pin. When the remote control signal preprocessor/external interrupt 3 pin is also used as the P30 port, set the P30 port output latch to "1". When it is not used as the remote control signal preprocessor/external interrupt 3 input pin, it can be used for normal port.

### 2.9.1 Configuration



Figure 2-50. Remote Control Signal Preprocessor

### 2.9.2 Remote Control Signal Preprocessor Control

When the remote control signal preprocessor is used, operating states are controlled and monitored by the following registers. Interrupt requests also use the remote control signal preprocessor/external interrupt 3 input pin.

- Remote control receive control register 1 (RXCR1)
- Remote control receive control register 2 (RXCR2)
- Remote control receive counter register (RXCTR)
- Remote control receive data buffer register (RXDBR)
- Remote control receive status register (RXSR)

When this pin is used for the external interrupt 3 input, set EINT in RXCR1 to other than "11".

| Remote control receive control register 1                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                     |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|---------|-----|---|-----|--|--|--|--|--|--|--|--|--|--|--|
| RXCR1<br>(0FD0H)                                                                                                                                                                                                                                                                                              | 7                                                                                                                                                                                                                                                                                                                   | 6    | 5    | 4       | 3   | 2 | 1 0 |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | RCKK                                                                                                                                                                                                                                                                                                                | RPOL | EINT | ' RNC ' |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | (Initial value : 0000 0000)                                                                                                                                                                                                                                                                                         |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| RCKK                                                                                                                                                                                                                                                                                                          | 8-bit up-counter source clock select                                                                                                                                                                                                                                                                                |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| RPOL                                                                                                                                                                                                                                                                                                          | Remote control signal polarity select                                                                                                                                                                                                                                                                               |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| EINT                                                                                                                                                                                                                                                                                                          | Interrupt source select                                                                                                                                                                                                                                                                                             |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| RNC                                                                                                                                                                                                                                                                                                           | Noise canceler noise eliminating time select                                                                                                                                                                                                                                                                        |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | 00: fc/2 <sup>6</sup> [Hz]<br>01: fc/2 <sup>8</sup><br>10: fc/2 <sup>10</sup><br>11: fc/2 <sup>12</sup>                                                                                                                                                                                                             |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | 0 : Positive<br>1 : Negative                                                                                                                                                                                                                                                                                        |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | 00: Rising edge<br>01: Falling edge (when RPOL = 0)<br>10: Rising/Falling edge<br>11: 8-bit receive end                                                                                                                                                                                                             |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | 000 : Noise canceler disable<br>001 : 2 <sup>2</sup> /fc × 7 – 1/fc [s]<br>010 : 2 <sup>5</sup> /fc × 7 – 1/fc<br>011 : 2 <sup>6</sup> /fc × 7 – 1/fc<br>100 : 2 <sup>7</sup> /fc × 7 – 1/fc<br>101 : 2 <sup>8</sup> /fc × 7 – 1/fc<br>110 : 2 <sup>10</sup> /fc × 7 – 1/fc<br>111 : 2 <sup>11</sup> /fc × 7 – 1/fc |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| <p><b>Note1 :</b> fc ; High-frequency clock [Hz]<br/> <b>Note2 :</b> After reset, RPOL do not change the set value in the receiving remote control signal. For setting interrupt edge and measurement data, use EINT and RMM.</p>                                                                             |                                                                                                                                                                                                                                                                                                                     |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| Remote control receive control register 2                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                     |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| RXCR2<br>(0FD1H)                                                                                                                                                                                                                                                                                              | 7                                                                                                                                                                                                                                                                                                                   | 6    | 5    | 4       | 3   | 2 | 1 0 |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | CREGA                                                                                                                                                                                                                                                                                                               |      |      | RCS     | RMM |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | (Initial value : 0000 0×00)                                                                                                                                                                                                                                                                                         |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| CREGA                                                                                                                                                                                                                                                                                                         | Setting of detect time for match with 8-bit up-counter upper 4 bits                                                                                                                                                                                                                                                 |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| RCS                                                                                                                                                                                                                                                                                                           | 8-bit up-counter start control                                                                                                                                                                                                                                                                                      |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| RMM                                                                                                                                                                                                                                                                                                           | Measurement mode select (invalid when EINT = "10")                                                                                                                                                                                                                                                                  |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | Match detect time (Tth) = 16 × CREGA/RCKK [s]<br>CREGA = 0 <sub>H</sub> to F <sub>H</sub><br>Example : CREGA = 2 <sub>H</sub> , RCKK = fc/2 <sup>6</sup> [Hz], at fc = 8 MHz<br>Tth = 256 [μs]                                                                                                                      |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | 0 : Stop and counter clear<br>1 : Start                                                                                                                                                                                                                                                                             |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                               | 00:<br>01:<br>10: Refer to table 2-6<br>11:                                                                                                                                                                                                                                                                         |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |
| <p><b>Note1 :</b> fc ; High-frequency clock [Hz], * ; don't care<br/> <b>Note2 :</b> When an interrupt source is set for rising/falling edge, low and high widths are forcibly measured separately.<br/> <b>Note3 :</b> Set CREGA (0<sub>H</sub> to F<sub>H</sub>) before EINT sets to 8-bit receive end.</p> |                                                                                                                                                                                                                                                                                                                     |      |      |         |     |   |     |  |  |  |  |  |  |  |  |  |  |  |

Figure 2-51. Remote Control Receive Control Register 1, 2

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                   |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-----------|---|---|---|------------------------------------------|-----------------------------------|--|-----------|------|--------------------------------|---------------------------------|-----|------------------------------------|---------------------------------------------------------------------------------------------------|------|--------------------------------------------------------------------|--|
| Remote control receive counter register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                    |                                                                                                   |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| RXCTR<br>(0FD2 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 7                                                                  | 6                                                                                                 | 5         | 4 | 3 | 2 | 1 0                                      |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                   |           |   |   |   | Read Only<br>(Initial value : 0000 0000) |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| Remote control receive data buffer register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                    |                                                                                                   |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| RXDDBR<br>(0FD3 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 7                                                                  | 6                                                                                                 | 5         | 4 | 3 | 2 | 1 0                                      |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                   |           |   |   |   | Read Only<br>(Initial value : 0000 0000) |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| Remote control receive status register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                    |                                                                                                   |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| RXSR<br>(0FD4 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 7                                                                  | 6                                                                                                 | 5         | 4 | 3 | 2 | 1 0                                      |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                   |           |   |   |   | (Initial value : 0000 * 000)             |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| <table border="1"> <tr> <td>RBCTM</td><td>Receive bit counter value monitor</td><td></td><td rowspan="5">Read Only</td></tr> <tr> <td>OVFF</td><td>8-bit up-counter overflow flag</td><td>0 : No overflow<br/>1 : Overflow</td></tr> <tr> <td>SRM</td><td>Data buffer register input monitor</td><td>0 : Upper 4 bits of 8-bit up-counter &lt; CREGA<br/>1 : Upper 4 bits of 8-bit up-counter <math>\geq</math> CREGA</td></tr> <tr> <td>RNCM</td><td>Remote control signal monitor after passing through noise canceler</td><td></td></tr> </table> |                                                                    |                                                                                                   |           |   |   |   | RBCTM                                    | Receive bit counter value monitor |  | Read Only | OVFF | 8-bit up-counter overflow flag | 0 : No overflow<br>1 : Overflow | SRM | Data buffer register input monitor | 0 : Upper 4 bits of 8-bit up-counter < CREGA<br>1 : Upper 4 bits of 8-bit up-counter $\geq$ CREGA | RNCM | Remote control signal monitor after passing through noise canceler |  |
| RBCTM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Receive bit counter value monitor                                  |                                                                                                   | Read Only |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| OVFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8-bit up-counter overflow flag                                     | 0 : No overflow<br>1 : Overflow                                                                   |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| SRM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Data buffer register input monitor                                 | 0 : Upper 4 bits of 8-bit up-counter < CREGA<br>1 : Upper 4 bits of 8-bit up-counter $\geq$ CREGA |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| RNCM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Remote control signal monitor after passing through noise canceler |                                                                                                   |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |
| <p><i>Note : * ; don't care</i></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                    |                                                                                                   |           |   |   |   |                                          |                                   |  |           |      |                                |                                 |     |                                    |                                                                                                   |      |                                                                    |  |

Figure 2-52. Remote Control Receive Counter Register, Data Buffer Register, Status Register

Table 2-6. Combination of Interrupt Source and Measurement Mode

| RPOLs | EINT | RMM | Interrupt source                                                                    | Measurement mode                                                                                                                                                                                                                                                     |
|-------|------|-----|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | 00   | 00  |                                                                                     |                                                                                                                                                                                    |
|       |      | 10  |    | <br>                                                                                             |
|       |      | 11  |    | <br>                                                                                             |
|       | 01   | 01  |                                                                                     | <br>                                                                                             |
|       |      | 10  |    | <br>                                                                                             |
|       |      | 11  |    | <br>                                                                                             |
|       | 10   | —   |    | <br><br>       |
|       | 11   | 00  |                                                                                     | <br>                                                                                             |
|       |      | 10  | Receive end                                                                         | <br>                                                                                            |
| 1     | 00   | 00  |                                                                                     | <br><br> |
|       |      | 10  |  | <br>                                                                                         |
|       |      | 11  |  | <br>                                                                                         |
|       | 01   | 01  |                                                                                     | <br>                                                                                         |
|       |      | 10  |  | <br>                                                                                         |
|       |      | 11  |  | <br>                                                                                         |
|       | 10   | —   |  | <br><br> |
|       | 11   | 00  |                                                                                     | <br>                                                                                         |
|       |      | 10  | Receive end                                                                         | <br>                                                                                         |

### 2.9.3 Noise Elimination Time Setting

The remote control receive circuit has a noise canceler. By setting RNC in RXCR1, input signals shorter than the fixed time can be eliminated as noise.

Table 2-7. Noise Elimination Time Setting

| RNC | Minimum signal pulse width | at fc = 8 MHz  | Maximum noise width to be eliminated | at fc = 8 MHz  |
|-----|----------------------------|----------------|--------------------------------------|----------------|
| 000 | —                          | —              | —                                    | —              |
| 001 | $(2^5 + 5) / fc$ [s]       | 4.63 $[\mu s]$ | $(2^2 \times 7 - 1) / fc$ [s]        | 3.38 $[\mu s]$ |
| 010 | $(2^8 + 5) / fc$           | 32.63          | $(2^5 \times 7 - 1) / fc$            | 27.88          |
| 011 | $(2^9 + 5) / fc$           | 64.63          | $(2^6 \times 7 - 1) / fc$            | 55.88          |
| 100 | $(2^{10} + 5) / fc$        | 128.63         | $(2^7 \times 7 - 1) / fc$            | 111.88         |
| 101 | $(2^{11} + 5) / fc$        | 256.63         | $(2^8 \times 7 - 1) / fc$            | 223.88         |
| 110 | $(2^{13} + 5) / fc$        | 1.025 [ms]     | $(2^{10} \times 7 - 1) / fc$         | 895.88         |
| 111 | $(2^{14} + 5) / fc$        | 2.049          | $(2^{11} \times 7 - 1) / fc$         | 1.792 [ms]     |

### 2.9.4 Operation

(1) interrupts at rising, falling, or rising/falling edge, and measurement modes

First set EINT and RMM. Next, set RCS to "1" ; the 8-bit up-counter is counted up by the internal clock. After measurement, the 8-bit up-counter value is saved in RXCTR. Then, the 8-bit up-counter is cleared, an INT3 request is generated, and the 8-bit up-counter resumes counting.

If the 8-bit up-counter overflows (FFH) before measurement is completed, an INT3 request is generated and the overflow flag (OVFF) is set to "1". Then, the 8-bit up-counter is cleared. An overflow can be detected by reading OVFF by the interrupt processing. To restart the 8-bit up-counter, set RCS to "1".

Setting RCS to "1" zero-clears OVFF.



Figure 2-53. Rising Edge Interrupt Timing Chart (RPOLS = 0)



Figure 2-54. Falling Edge Interrupt Timing Chart (RPOLS = 0)



Figure 2-55. Rising/Falling Edge Interrupt Timing Chart  
(a) High and low width measurement

## (2) 8-bit receive end interrupts and measurement modes

By determining one-cycle remote control signal or one-pulse width as one-bit data "0" or "1" an INT3 request is generated after 8-bit data is received. When "0" is determined, this means the upper four bits in the 8-bit up-counter have not reached the CREGA value. When "1" is determined, this means the upper four bits in the 8-bit up-counter have reached or exceeded the CREGA value. The 8-bit up-counter value is saved in RXCTR after one bit is determined. The determined data is saved, bit by bit, in RXDBR at the rising edge of the remote control signal (when RPOLS = 1, falling edge). The number of bits saved in RXDBR is counted by the receive bit counter and saved in RBCTM. RBCTM is set to "0001B" at the rising edge of the input (when RPOLS = 1, falling edge) after the INT3 request is generated.



Figure 2-56. Overflow Interrupt Timing Chart



Figure 2-57. 8-bit Receive End Interrupt Timing Chart (RPOLS = 0)

Table 2-8. Count Clock for Remote Control Preprocessor Circuit

| Count clock (RCCK) | at $f_C = 8 \text{ MHz}$ |                      |
|--------------------|--------------------------|----------------------|
|                    | Resolution               | Maximum setting time |
| $f_C/2^6$ [Hz]     | 8 $\mu\text{s}$          | 2.048 ms             |
| $f_C/2^8$          | 32 $\mu\text{s}$         | 8.192 ms             |
| $f_C/2^{10}$       | 128 $\mu\text{s}$        | 32.768 ms            |
| $f_C/2^{12}$       | 512 $\mu\text{s}$        | 131.072 ms           |

## 2.10 6-bit A/D Conversion (Comparator) Inputs

The comparator input is an analog input to discriminate key input or AFC (Auto Frequency Control) signal input, etc. The analog input voltage level (pins CIN3 to CIN0) can be detected as 64-stage by setting reference voltage.

The comparator input pins CIN3 to CIN0 can also be used as ports P57 to P54.

When used as a comparator input, the output latch should be set to "1".

### 2.10.1 Configuration



Figure 2-58. 6-bit A/D Conversion (Comparator) Input

## 2.10.2 Control

A/D conversion (comparator) inputs are controlled by a comparator input control register (CMPCR) and a comparator input data register (CMPDR). The CMPDR contains a reference voltage setting register (write-only) and a comparison result register (read-only).

| Comparator Input Control Register                                                                                                                                                                                                                                                                                                                                                                                                               |                                               |                                                                                                                                          |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|---|---|-------|-------|-------------|--------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------|--|--|--|--|------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|--|--|--|
| <b>CMPCR</b><br>(000E <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                            | 7                                             | 6                                                                                                                                        | 5 | 4 | 3     | 2     | 1 0         |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ECMP                                          | SCIN                                                                                                                                     |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               | (Initial value : 0*** *000)                                                                                                              |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| <table border="1"> <tr> <td>ECMP</td><td>Comparator input control</td><td>0 : Disable Comparator input<br/>1 : Enable Comparator input</td><td colspan="5"></td></tr> <tr> <td>SCIN</td><td>Number of Comparator input channels select</td><td>000 : 1 channel (CIN0)<br/>001 : 2 channels (CIN0 to 1)<br/>010 : 3 channels (CIN0 to 2)<br/>011 : 4 channels (CIN0 to 3)<br/>1** : Reserved</td><td colspan="5" rowspan="3"></td></tr> </table> |                                               |                                                                                                                                          |   |   |       |       | ECMP        | Comparator input control | 0 : Disable Comparator input<br>1 : Enable Comparator input |                                                                             |  |  |  |  | SCIN | Number of Comparator input channels select | 000 : 1 channel (CIN0)<br>001 : 2 channels (CIN0 to 1)<br>010 : 3 channels (CIN0 to 2)<br>011 : 4 channels (CIN0 to 3)<br>1** : Reserved |                                                                                           |  |  |  |  |  |
| ECMP                                                                                                                                                                                                                                                                                                                                                                                                                                            | Comparator input control                      | 0 : Disable Comparator input<br>1 : Enable Comparator input                                                                              |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| SCIN                                                                                                                                                                                                                                                                                                                                                                                                                                            | Number of Comparator input channels select    | 000 : 1 channel (CIN0)<br>001 : 2 channels (CIN0 to 1)<br>010 : 3 channels (CIN0 to 2)<br>011 : 4 channels (CIN0 to 3)<br>1** : Reserved |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| <p><i>Note1</i> : * ; don't care</p> <p><i>Note2</i> : The CMPCR is a write-only register and must not be used with any of the read-modify-write instructions such as bit operate, etc.</p>                                                                                                                                                                                                                                                     |                                               |                                                                                                                                          |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| Comparator Input Data Register                                                                                                                                                                                                                                                                                                                                                                                                                  |                                               |                                                                                                                                          |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| <b>CMPDR</b><br>(000F <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                            | 7                                             | 6                                                                                                                                        | 5 | 4 | 3     | 2     | 1 0         |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               | SVREF                                                                                                                                    |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               | (Initial value : **00 0000)                                                                                                              |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |                                                                                                                                          |   |   | COUT3 | COUT2 | COUT1 COUT0 |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| <table border="1"> <tr> <td>SVREF</td><td>Reference voltage (V<sub>REF</sub>) setting</td><td>V<sub>REF</sub> = V<sub>DD</sub> × (SVREF + 1) / 64 [V] (SVREF = 0 to 63)</td><td colspan="5"></td></tr> <tr> <td>COUT3 to COUT0</td><td>Comparison result</td><td>Result of comparing the CIN3 to CIN0 pin analog input voltage with the reference voltage.</td><td colspan="5" rowspan="2"></td></tr> </table>                                  |                                               |                                                                                                                                          |   |   |       |       |             | SVREF                    | Reference voltage (V <sub>REF</sub> ) setting               | V <sub>REF</sub> = V <sub>DD</sub> × (SVREF + 1) / 64 [V] (SVREF = 0 to 63) |  |  |  |  |      | COUT3 to COUT0                             | Comparison result                                                                                                                        | Result of comparing the CIN3 to CIN0 pin analog input voltage with the reference voltage. |  |  |  |  |  |
| SVREF                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reference voltage (V <sub>REF</sub> ) setting | V <sub>REF</sub> = V <sub>DD</sub> × (SVREF + 1) / 64 [V] (SVREF = 0 to 63)                                                              |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| COUT3 to COUT0                                                                                                                                                                                                                                                                                                                                                                                                                                  | Comparison result                             | Result of comparing the CIN3 to CIN0 pin analog input voltage with the reference voltage.                                                |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |
| <p><i>Note1</i> : * ; don't care</p> <p><i>Note2</i> : The SVREF as write-only bits and must not be used with any of the read-modify-write instructions such as bit operate, etc.</p> <p><i>Note3</i> : When a read instruction for CMPDR, bits 7 to 4 are read in undefined data.</p>                                                                                                                                                          |                                               |                                                                                                                                          |   |   |       |       |             |                          |                                                             |                                                                             |  |  |  |  |      |                                            |                                                                                                                                          |                                                                                           |  |  |  |  |  |

Figure 2-59. Comparator Input Control Register and Data Register

### 2.10.3 Function

Reference voltage ( $V_{REF}$ ) is set with SVREF (bits 5 to 0 in CMPDR).

$$V_{REF} = V_{DDX} (SVREF + 1) / 64[V] \quad (SVREF = 0 \text{ to } 63)$$

The number of comparator input channels is selected with SCIN (bits 2 to 0 in CMPCR). Sequential comparison of the selected number of channels is started by setting ECMP (bit 7 in CMPCR) to "1".

The comparison of one channel requires two machine cycles; therefore, the comparison result register (COUT3 to COUT0) should be read out at an interval equal to [number of channels  $\times$  2 machine cycles] after setting the reference voltage ( $V_{REF}$ ). COUT3 to COUT0 are set to "1" if the input voltage (pins CIN3 to CIN0) is higher than the reference voltage ( $V_{REF}$ ) ; otherwise those are cleared to "0".

*Note 1 : When entering STOP mode, ECMP is automatically cleared and SCIN/SVREF are held. And, COUT3 to COUT0 are always set to "1".*

*Note 2 : Any pins specified for comparator input with SCIN can no longer be used for normal digital input and, are read out as "0".*

*Note 3 : COUT3 to COUT0 are read out as "1" when not used as a comparator input. For example, bit 3 in CMPDR is always read out as "1" when SCIN = 010<sub>B</sub>.*

Example : Compares the CIN3 to CIN0 inputs with  $V_{REF} = 2.5$  V (at  $V_{DD} = 5$  V).

|    |                    |                                                                |
|----|--------------------|----------------------------------------------------------------|
| LD | (P5), 1111111B     | ; Set port P5 output latches to "1".                           |
| LD | (CMPDR), 0001111B  | ; Set $V_{REF} = 2.5$ V                                        |
| LD | (CMPCR), 10000011B | ; Set SCIN to 4 channels and Enables comparator input          |
|    |                    | ⋮                                                              |
|    |                    | ; 4ch $\times$ 2 machine cycles -2<br>= 6 machine cycles wait. |

|    |            |                                |
|----|------------|--------------------------------|
| LD | A, (CMPDR) | ; Read CMPDR (COUT0 to COUT3). |
|----|------------|--------------------------------|

Table 2-9. Reference Voltage (at  $V_{DD} = 5$  V)

| SVREF |   |   |   |   |   | $V_{REF}$ [V] |
|-------|---|---|---|---|---|---------------|
| 5     | 4 | 3 | 2 | 1 | 0 |               |
| 0     | 0 | 0 | 0 | 0 | 0 | 0.078         |
| 0     | 0 | 0 | 0 | 0 | 1 | 0.156         |
| 0     | 0 | 0 | 0 | 1 | 0 | 0.234         |
| ⋮     |   |   |   |   |   |               |
| 1     | 1 | 1 | 1 | 0 | 1 | 4.844         |
| 1     | 1 | 1 | 1 | 1 | 0 | 4.922         |
| 1     | 1 | 1 | 1 | 1 | 1 | 5.000         |

## 2.11 Pulse Width Modulation Circuit Output

87CH34B/K34B/M34B has a 14-bit resolution pulse width modulation (PWM) channels and 9 7-bit resolution PWM channels. D/A converter output can easily be obtained by connecting an external low-pass filter. PWM outputs are multiplexed with general purpose I/O ports as; P40 (**PWM0**) to P47 (**PWM7**), P50 (**PWM8**), P51 (**PWM9**). When these ports are used PWM outputs, the corresponding bits of P4, P5 output latches and input/output control latches should be set to "1".

### 2.11.1 Configuration



Figure 2-60. Pulse Width Modulation Circuit

## 2.11.2 PWM Output Wave Form

### (1) $\overline{\text{PWM}0}$ output

This is 14-bit resolution PWM output and one period is  $T_M = 215/\text{fc}$  [s].

The 8 high-order bits of the PWM data latch control the pulse width of the pulse output with a period of  $T_S$  ( $T_S = T_M/64$ ), which is the sub-period of the  $\overline{\text{PWM}0}$ . When the 8-bit data are decimal  $n$  ( $0 \leq n \leq 255$ ), this pulse width becomes  $n \times t_0$ , where  $t_0 = 2/\text{fc}$ .

The lower 6-bit of 14 bit data are used to control the generation of additional to wide pulse in each  $T_S$  period. When the 6-bit data are decimal  $m$  ( $0 \leq m \leq 63$ ), the additional pulse is generated in each of  $m$  periods out of 64 periods contained in a  $T_M$  period. The relationship between the 6 bits data and the position of  $T_S$  period where the additional pulse is generated is shown in Table 2-10.

Table 2-10. Correspondence between 6 Bits Data and the Additional Pulse Generated  $T_S$  Period

| Bit position of 6 bits data | Relative position of $T_S$ where the output pulse is generated.<br>(Number $i$ of $T_S$ is listed) |
|-----------------------------|----------------------------------------------------------------------------------------------------|
| Bit 0                       | 32                                                                                                 |
| Bit 1                       | 16, 48                                                                                             |
| Bit 2                       | 8, 24, 40, 56                                                                                      |
| Bit 3                       | 4, 12, 20, 28, 36, 44, 52, 60                                                                      |
| Bit 4                       | 2, 6, 10, 14, 18, 22, 26, 30, ..., 58, 62                                                          |
| Bit 5                       | 1, 3, 5, 7, 9, 11, 13, 15, 17, ..., 59, 61, 63                                                     |

*Note : When the corresponding bit is "1", it is output.*

### (2) $\overline{\text{PWM}1}$ - $\overline{\text{PWM}9}$ outputs

These are 7-bit resolution PWM outputs and one period is  $T_N = 28/\text{fc}$  [s]. When the 7-bit data are decimal  $k$  ( $0 \leq k \leq 127$ ), the pulse width becomes  $k \times t_0$ . The wave form is illustrated in Figure 2-61.



Figure 2-61. PWM Output Wave Form

### 2.11.3 Control

PWM output is controlled by PWM Control Register (PWMCR) and PWM Data Buffer Register (PWMDBR). The status of transfer PWM data from PWMDBR to PWM data latch is read by PWMEOT of PWM status register (PWMSR).

| PWM Control Register         |                                                                                                                                                                                                                                                                                                    |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-------------------------------------------|---|---|------------|--|--|--|--|--|--|--|
| PWMCR<br>(0025H)             | 7                                                                                                                                                                                                                                                                                                  | 6 | 5 | 4                                         | 3 | 2 | 1 0        |  |  |  |  |  |  |  |
|                              | PWMDLS                                                                                                                                                                                                                                                                                             |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
|                              | (Initial value **** 0000)                                                                                                                                                                                                                                                                          |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
| PWMDLS                       | Selection of PWM data latch and request of data transfer                                                                                                                                                                                                                                           |   |   |                                           |   |   | write only |  |  |  |  |  |  |  |
|                              | 0000 : Lower 6-bit of PWM0<br>0001 : 8 High-order bits of PWM0<br>0010 : PWM1<br>0011 : PWM2<br>0100 : PWM3<br>0101 : PWM4<br>0110 : PWM5<br>0111 : PWM6<br>1000 : PWM7<br>1001 : PWM8<br>1010 : PWM9<br>1011 : reserved<br>1100 : PWM Data Transfer Request<br>1101 : reserved<br>111* : reserved |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
| <i>Note : * : don't care</i> |                                                                                                                                                                                                                                                                                                    |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
| PWM Status Register          |                                                                                                                                                                                                                                                                                                    |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
| PWMSR<br>(0025H)             | 7                                                                                                                                                                                                                                                                                                  | 6 | 5 | 4                                         | 3 | 2 | 1 0        |  |  |  |  |  |  |  |
|                              | PWMEOT "1" "1" "1" "1" "1" "1" "1"                                                                                                                                                                                                                                                                 |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
|                              | (Initial value 0111 1111)                                                                                                                                                                                                                                                                          |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
| PWMEOT                       | PWM data                                                                                                                                                                                                                                                                                           |   |   | 0 : End of Transfer<br>1 : Under Transfer |   |   |            |  |  |  |  |  |  |  |
|                              | read only                                                                                                                                                                                                                                                                                          |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
| PWM Data Buffer Register     |                                                                                                                                                                                                                                                                                                    |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
| PWMDBR<br>(0026H)            | 7                                                                                                                                                                                                                                                                                                  | 6 | 5 | 4                                         | 3 | 2 | 1 0        |  |  |  |  |  |  |  |
|                              | .....                                                                                                                                                                                                                                                                                              |   |   |                                           |   |   |            |  |  |  |  |  |  |  |
|                              | write only                                                                                                                                                                                                                                                                                         |   |   |                                           |   |   |            |  |  |  |  |  |  |  |

Figure 2-62. PWM Control Register / PWM Status Register / PWM Data Buffer Register

## (1) Programing of PWM Data

PWM output is controlled by writing the output data to data latches.

The sequence of write the output data to data latch is shown as follows;

1. Write the channel number of PWM data latch to the PWMDLS.
2. Write PWM output data to the PWMDBR.
3. Write "0CH" to the PWMCR.

When transferring of the output data is completed, the PWMEOT becomes "0", indicating that the next data can be written. Do not write PWM data when the PWMEOT is "1" because write errors can occur in this case.

*Note : When writing the output data to PWM0 data latch, write "0CH" to the PWMCR after writing of the 14-bits output data is completed.*

While the output data are being written to the data latch, the previously written data are being output. The maximum time from the point at which "0CH" is written to the data latch until PWM output is switched is  $215/fc$  [s] (4.096 ms, at  $fc = 8$  MHz) for PWM0 output and  $29/fc$  [s] ( $64 \mu s$ , at  $fc = 8$  MHz) for PWM1 to PWM9 output.

Example : PWM0 pin outputs a PWM wave form with a low-level of  $32 \mu s$  width and no additional pulse.

PWM1 pin outputs a PWM wave form with a low-level of  $16 \mu s$  width.

PWM2 pin outputs a PWM wave form with a low-level of  $8 \mu s$  width.

*Note : at  $fc = 8$  MHz*

|         |                  |                                    |
|---------|------------------|------------------------------------|
| LD      | (PWMCR), 00H     | ; Select lower 6-bit of PWM0       |
| LD      | (PWMDBR), 00H    | ; No additional pulse              |
| LD      | (PWMCR), 01H     | ; Select 8 high-order bits of PWM0 |
| LD      | (PWMDBR), 80H    | ; $32 \mu s \div 2/fc = 80H$       |
| LD      | (PWMCR), 0CH     | ; Request PWM Data Transfer        |
| WAIT0 : | TEST (PWMSR). 7  | ; PWMEOT = 0?                      |
|         | JRS F, WAIT0     |                                    |
|         | LD (PWMCR), 02H  | ; Select PWM1                      |
|         | LD (PWMDBR), 40H | ; $16 \mu s \div 2/fc = 40H$       |
|         | LD (PWMCR), 0CH  | ; Request PWM Data Transfer        |
| WAIT1 : | TEST (PWMSR). 7  | ; PWMEOT = 0?                      |
|         | JRS F, WAIT1     |                                    |
|         | LD (PWMCR), 03H  | ; Select PWM2                      |
|         | LD (PWMDBR), 20H | ; $8 \mu s \div 2/fc = 20H$        |
|         | LD (PWMCR), 0CH  | ; Request PWM Data Transfer        |
| WAIT2 : | TEST (PWMSR). 7  | ; PWMEOT = 0?                      |
|         | JRS F, WAIT2     |                                    |

## 2.12 Pulse Output Circuit (PULSE)

Pulse output circuit generates the pulse clock of duty 50% by dividing the High-frequency clock.

The pulse output is used for the basic clock for the PLL IC or peripheral ICs. When P52 port is used as the pulse output, set P52 output latch to "1".



Figure 2-63. Pulse Output Circuit

## 2.13 On-Screen Display (OSD) Circuit

The TMP87CH34B/K34B/M34B features a built-in on-screen display circuit used to display characters and symbols on the TV screen. There are 256 characters and any characters can be displayed in an area of 32 columns  $\times$  8 lines. With an OSD interrupt, additional lines can be displayed. The functions of the OSD circuit meet the requirements of on-screen display functions of closed caption decoders based on FCC standards.

OSD circuit functions are as follows:

- ① Number of characters : 256
- ② Number of display characters : 256 (32 columns  $\times$  8 lines). With OSD interrupt, nine or more lines can be displayed.
- ③ Character matrix : 8 x 9 dots (8 x 13 dots including space around character)
- ④ Character sizes : 3 (specified by line)
- ⑤ Display colors:
  - Character colors : 7 colors (specified character by character)
  - Fringe colors : 8 colors
  - Background colors : 8 colors
- ⑥ Fringing and smoothing functions (for large, middle, and small characters)
- ⑦ Display position : 128 horizontal steps and 256 vertical steps
- ⑧ Full-raster blanking function
- ⑨ Blinking function
- ⑩ Underline
- ⑪ Solid space
- ⑫ Slant function (italics)
- ⑬ Window function

### 2.13.1 Configuration



Figure 2-64. OSD Circuit

### 2.13.2 Memories for OSD

#### (1) Character ROM

The character ROM contains 256 character patterns. It is possible to design any patterns as below. The character ROM consists of 256 characters stored as  $8 \times 9$  dots (character codes  $00_H$  to  $FF_H$ ). Each bit in the character ROM corresponds to one dot. When a bit in the character ROM is set to 1, the corresponding dot is displayed; if set to 0, the dot is not displayed. The start address in the character ROM for each characters can be calculated as follows :

$$\text{Start address in character ROM} = \text{CRA} \times 10_H + 4000_H$$

*Note: CRA: Character code ( $00_H$  to  $FF_H$ )*

Character code  $00_H$  is used as blank character and cannot be changed.

Write  $00_H$  in the data of character code  $00_H$ .

Figure 2-65 shows an example of the character pattern configuration for an  $8 \times 9$  bit character (character code  $01_H$ ), with the ROM addresses and data.

In case of using SLANT function, the character data should be fixed in  $6 \times 9$  dots area on the left side as below. If the character data is not fixed in  $6 \times 9$  dot area, the SLANT character font is overlapped to a character on the right side of itself.

Figure 2-66 shows the character ROM dump list for the above character pattern.

When ordering a mask, load the data to character ROM at address  $4000_H$  to  $4FFF_H$  in the 256K-bit EPROM. Write  $00H$  to character ROM at address  $4000_H$  to  $4008_H$  and write  $FF_H$  for all the data which has  $**9_H$  to  $**F_H$  as an address in character ROM.



Figure 2-65.  $8 \times 9$  Dot Pattern Configuration

4010/ 78 84 04 18 04 04 84 78 00 FF FF FF FF FF FF FF FF FF

Figure 2-66. Character ROM Dump List

#### (2) Display memory

Each character of the 256 characters displayed in 32 columns x 8 lines consists of 14 bits in the display memory. Five data items are written to the display memory: character code, color data, blinking specification, underline enable, and slant enable. The display memory is in an unknown state at reset.

There are two modes for writing display data to the display memory. One mode is used for writing all display data (character code, color data, blinking specification, underline enable, and slant enable) simultaneously. The other mode is used for changing either character codes or the remaining data items (color data, blinking specification, underline enable, and slant enable). How to write display data to the display memory is described in section 2.13.3 (22).

## Display memory configuration

- Character code specification register (8 bits) ... CRA7 to CRA0
- Color data specification register (3 bits) ..... RDT / GDT / BDT
- Blinking specification flag (1 bit) ..... BLF
- Underline enable flag (1 bit) ..... EUL
- Slant enable flag (1 bit) ..... SLNT



Figure 2-66. Display Memory Bit Configuration

| COLUMN<br>LINE \ | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 |
|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 1                | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0A | 0B | 0C | 0D | 0E | 0F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1C | 1D | 1E | 1F |
| 2                | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 2A | 2B | 2C | 2D | 2E | 2F | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 3A | 3B | 3C | 3D | 3E | 3F |
| 3                | 40 | 41 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 5F |    |
| 4                | 60 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7F |    |
| 5                | 80 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 9F |    |
| 6                | A0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BF |    |
| 7                | C0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DF |    |
| 8                | E0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FE | FF |

*Note: Numerals in the table indicate (hexadecimal) addresses in the display memory.*

Figure 2-68. Display Memory Address Configuration

## 2.13.3 OSD circuit control

The OSD circuit performs control functions using the OSD control registers which reside in addresses  $0F80_H$  to  $0F98_H$  in the data buffer register (DBR). Section 2.13.3 (27) shows the OSD control registers. To write data to the OSD control registers, use the normal data buffer register access method. The OSD control registers are used to set display start position, display character designs (that is, fringing, smoothing, color data, character size, and etc.), display memory addresses, and character codes.

Setting the display on-off control bit, DON, (bit 0 in ORDON) to 1 enables display (starts display). Setting DON to 0 disables display (halts display).

How to write to or read from the OSD control registers refer to section 2.13.3 (28).

## (1) Display position

The horizontal display start position can be set to any value by the 128 steps. The vertical display start position can be set to any value by the 256 steps. The horizontal display start position is specified by OSD control registers HS16 to HS10 (ORHS1). The vertical display start position for the first line is specified using VS17 to VS10 (ORVS1). The vertical display start position for the second line to the eighth line are specified by setting VS27 to VS20 (ORVS2) ... VS87 to VS80 (ORVS8).

## Horizontal display start position

Specified Page by Page.

Specification steps : 128

## Vertical display start position

Specified Line by Line.

Specification steps : 256

## Horizontal display start position register (7 bits)

Lines 1 to 8 HS16 to HS10 (ORHS1)

## Vertical display start position registers (8 bits x 8)

Line 1: VS17 to VS10 (ORVS1)

Line 2: VS27 to VS20 (ORVS2)

:

Line 8: VS87 to VS80 (ORVS8)

## Horizontal display start position

When FORS = 0, normal frequency mode

$$HS1 = \{(HS16 to HS14) \times 16^1 + (HS13 to HS10) \times 16^0\} \times 2T_{osc} + 10T_{osc}$$

When FORS = 1, double frequency mode

$$HS1 = \{(HS16 to HS14) \times 16^1 + (HS13 to HS10) \times 16^0\} \times 2T_{osc} + 5T_{osc}$$

## Vertical display start position

When VDSMD = 0, normal mode

$$\text{Line } n: VS_n = \{(VS_n7 to VS_n4) \times 16^1 + (VS_n3 to VS_n0) \times 16^0\} \times 1THD$$

When VDSMD = 1, double scan mode

$$\text{Line } n: VS_n = \{(VS_n7 to VS_n4) \times 16^1 + (VS_n3 to VS_n0) \times 16^0\} \times 2THD$$

Tosc : One cycle of OSC oscillation

THD : One cycle of HD signal



Figure 2-69. TV Screen Display Image

- Notices for setting vertical display start position

Lines of OSD (VS1 to VS8) are fixed priority levels as follows:

VS1>VS2>VS3>VS4>VS5>VS6>VS7>VS8

① When vertical display start positions are set as follows:

$(ORVS1) \leq ORVS2 \leq ORVS3 \leq ORVS4 \leq ORVS5 \leq ORVS6 \leq ORVS7 \leq ORVS8$ ,

if higher priority level line overlaps lower one, lower one is not displayed.



Figure 2-70. Occasion of Overlapping ( $VS1 \leq VS2$ )



Figure 2-71. Occasion of Overlapping ( $VS1 \leq VS2 \leq VS3$ )

Then the display line counter (refer to section 2.13.3 (16)) does not count up canceled lines.

② When vertical display start position is set as follows:

$ORVS1 > ORVS2 > ORVS3 > ORVS4 > ORVS5 > ORVS6 > ORVS7 > ORVS8$ ,

if higher priority level line overlaps lower one, lower one is changed to higher one in the middle of lower one.



Figure 2-72. Occasion of Overlapping ( $VS1 > VS2$ )

Then the display line counter counts up only one.

If higher priority level line is filled with space character, under side of lower one is broken off.

**Note1 :** *(ORVS<sub>n</sub>) means the value of the vertical display start position register VS<sub>n7</sub> to VS<sub>n0</sub>.*

**Note2 :** *If display lines are overlapped each other a display line is canceled as above. Set a space line for not overlapping display lines, or set vertical display start position to the out of display area.*

**Note3 :** *When the display line is also set to the display off by character size (CS<sub>n1</sub>, 0 = 00), overlapped display line is canceled as above.*

*The width of the display off line is the same as that of the small character line.*

### (2) Double scan mode

The OSD circuit has a double scan mode. This enables counting by double steps in the vertical direction to handle non-interlaced scanning TVs. This mode also enables vertical display position to be set for the whole screen. Setting the OSD control register VDSMD (bit 4 in ORETC) to "1" sets double scan mode. after releasing the reset mode, the initial mode is the normal mode.

Double scan mode select register (1 bit) ..... VDSMD (bit 4 in ORETC)

"0" ..... Normal mode

"1" ..... Double scan mode

### (3) Character sizes and display on/off

There are three character sizes: large, middle and small. One character size can be specified for each line. Display on/off can also be specified for each line. Character size and display on/off are specified using OSD control registers CS11, CS10...CS81, CS80 (ORCS4 and ORCS8).

Character sizes : Large, middle, small

Character size and display on/off specification unit: Line

Character size select/display on/off register (2 bits x 8)

For line 1: CS11 and CS10 (bits 1 and 0 in ORCS4)

For line 2: CS21 and CS20 (bits 3 and 2 in ORCS4)

: :

For line 8: CS81 and CS80 (bits 7 and 6 in ORCS8)

Table 2-11. Character Size and Display On/Off Specifications (n : 1 to 8)

| CSn1 | CSn0 | Character size | Display on/off |
|------|------|----------------|----------------|
| 1    | 1    | Small          | On             |
| 1    | 0    | Middle         | On             |
| 0    | 1    | Large          | On             |
| 0    | 0    | -(Note)        | Off            |

Table 2-12. Dot and Character Sizes

|                                     |        | VDSMD = 0,<br>(normal mode)            |                                          | VDSMD = 1,<br>(double scan mode)       |                                          |
|-------------------------------------|--------|----------------------------------------|------------------------------------------|----------------------------------------|------------------------------------------|
|                                     |        | Dot size                               | Character size                           | Dot size                               | Character size                           |
| FORS = 0<br>(normal mode)           | Small  | 2 T <sub>OSC</sub> × 1 T <sub>HD</sub> | 16 T <sub>OSC</sub> × 9 T <sub>HD</sub>  | 2 T <sub>OSC</sub> × 2 T <sub>HD</sub> | 16 T <sub>OSC</sub> × 18 T <sub>HD</sub> |
|                                     | Middle | 4 T <sub>OSC</sub> × 2 T <sub>HD</sub> | 32 T <sub>OSC</sub> × 18 T <sub>HD</sub> | 4 T <sub>OSC</sub> × 4 T <sub>HD</sub> | 32 T <sub>OSC</sub> × 36 T <sub>HD</sub> |
|                                     | Large  | 8 T <sub>OSC</sub> × 4 T <sub>HD</sub> | 64 T <sub>OSC</sub> × 36 T <sub>HD</sub> | 8 T <sub>OSC</sub> × 8 T <sub>HD</sub> | 64 T <sub>OSC</sub> × 72 T <sub>HD</sub> |
| FORS = 1<br>(double frequency mode) | Small  | 1 T <sub>OSC</sub> × 1 T <sub>HD</sub> | 8 T <sub>OSC</sub> × 9 T <sub>HD</sub>   | 1 T <sub>OSC</sub> × 2 T <sub>HD</sub> | 8 T <sub>OSC</sub> × 18 T <sub>HD</sub>  |
|                                     | Middle | 2 T <sub>OSC</sub> × 2 T <sub>HD</sub> | 16 T <sub>OSC</sub> × 18 T <sub>HD</sub> | 2 T <sub>OSC</sub> × 4 T <sub>HD</sub> | 16 T <sub>OSC</sub> × 36 T <sub>HD</sub> |
|                                     | Large  | 4 T <sub>OSC</sub> × 4 T <sub>HD</sub> | 32 T <sub>OSC</sub> × 36 T <sub>HD</sub> | 4 T <sub>OSC</sub> × 8 T <sub>HD</sub> | 32 T <sub>OSC</sub> × 72 T <sub>HD</sub> |

T<sub>OSC</sub> : One cycle of OSC oscillation

T<sub>HD</sub>: One cycle of HD signal

*Note; The display off line operates like the width of a small character size line though the character is not displayed.*

### (4) Character configuration

The area for a character consists of 8 x 13 dots: character display area, underline display area, and space area. A display character is specified by a character code; underline display is enabled or disabled by the underline enable flag. Figure 2-73 shows a display character image.



Figure 2-73. Display Character Image

#### (5) Smoothing function

The smoothing function is used to make characters look smooth. Enabling smoothing displays 1/4 of a dot between two dots which are connected corner to corner within a character as shown in the figure 2-74. Smoothing is enabled by setting ESMZ (bit 5 in ORETC) in the OSD control register.

Smoothing specification unit: Page

Smoothing specification register (1 bit) ..... ESMZ (bit 5 in ORETC)

"0" ..... No smoothing

"1" ..... Smoothing enabled

*Note: When smallsize character is enabled smoothing set the value as follows into jitter elimination circuit registers.*

HJRM (bit2 in JRMCR) ... "1"

AFLD (bit3 in JRMCR) ... "1"

#### (6) Fringing function

The fringing function is used to display a character with a fringe (width is 1/2 dot) which has a different color from that of the character. A character as shown in the figure 2-75. When a character has dots which are active on the edge of the 8x9 character area, the fringe exceeds the boundaries of the character area by 1/2 a dot. This occurs on the left, and right of the character area is displayed with the maximum of 8 horizontal dots and 9 vertical dots, the fringe exceeds right and left, of the character display area. If there is an adjacent character whose outer dot is active, then this dot will overrule the fringe in the horizontal direction. Underlines are not fringed.

Fringing is enabled for each line by setting EFR1 to EFR8 (OREFR) in the OSD control register to "1".

A fringe color, which is common to all lines, is specified using OSD control registers, RFDT, GFDT, and BFDT, (bits 2 to 0 in ORBK). Do not enable both fringing and solid space simultaneously.

Specified Line by line

Fringe color specification unit: Common to all lines (1 color can be selected in 8 colors.)

Fringing enable register (1 bit x 8)

line 1 EFR1 (bit 0 in OREFR)

line 2 EFR2 (bit 1 in OREFR)

⋮ ⋮

line 8 EFR8 (bit 7 in OREFR)

## Fringing specification

EFRn (n: 1 to 8)

"0" ..... No fringing

"1" ..... Fringing enable

Fringe color register (3 bits)



Figure 2-74. Smoothing

RFDT, GFDT, BFDT (bits 2 to 0 in ORBK)



Figure 2-75. Figure Fringing



Figure 2-76. Priority of Smoothing and Fringing

## (7) Background function

The background function is able to display with a background color in the color of 8 x 13 dots areas except the character. (Except for areas whose character code is blank data)

This function is specified for each display page by setting the OSD control register EBKGD (bit 7 in ORBK) to "1".

A background color is specified for each display page by setting the OSD control registers, RBDT, GBDT, and BBDT (bits 5 to 3 in ORBK).

Background specification unit: display page (1 color can be selected in 8 colors.)

Background enable register (1 bit) : EBKGD (bit 7 in ORBK)

"0" ..... No background function

"1" ..... Background function enable

Background color specification registers (3 bits): RBDT, GBDT, BBDT (bits 5 to 3 in ORBK)

## (8) Full-raster blanking function

The full-raster blanking function deletes the display of the video signal and is able to color on the whole screen with the background color. Display page video signal is used to first delete by BL signal. In case of using the full-raster blanking function, it is necessary to select BL signal by setting YBLES (bit 7 in ORETC) to "1", because it is impossible to remove display page video signal by Y signal.

This function is specified for each display page by setting OSD control register EXBL (bit 6 in ORBK) to "1".

Color specification: Same as that for background.

Full-raster blanking specified display page by display page.

Full-raster blanking enable register: ... EXBL (bit 6 in ORBK)

"0" ..... No full-raster blanking

"1" ..... Full-raster blanking

Full-raster blanking color specification registers (3 bits) ... RBDT, GBDT, BBDT (same as background color)

## (9) fosc frequency select

fosc frequency mode select: This function is to select fosc frequency mode. By setting FORS (bit 6 in ORIV) to "1", the OSD circuit is operated with clock ( $2 \times fosc$ ).

fosc frequency mode select register (1 bit) ... FORS (bit 6 in ORIV)

- "0" ... Normal frequency mode
- "1" ... Double frequency mode

## (10) Character

Characters: 256 (including blank data).

Character specification register (8 bits) ... CRA7 to CRA0 (bits 7 to 0 in ORCRA)

CRA7 to CRA0 (in the display memory)

- "00" ... Blank data
- "01" to "FF" ... User programmable by character ROM

## (11) Character color

Character colors: 7

Character color specification unit: character

Character color specification register (3 bits) ... RDT, GDT, BDT (bits 2 to 0 in ORDSN)  
RDT, GDT, BDT (in the display memory)

Table 2-13. Character Color

| RDT | GDT | BDT | Character color |
|-----|-----|-----|-----------------|
| 0   | 0   | 1   | Blue            |
| 0   | 1   | 0   | Green           |
| 0   | 1   | 1   | Cyan            |
| 1   | 0   | 0   | Red             |
| 1   | 0   | 1   | Magenta         |
| 1   | 1   | 0   | Yellow          |
| 1   | 1   | 1   | White           |

## (12) Solid space control

Solid space control is used to display one column of solid space to the left and right of 32 columns.

Solid space control is used to delete the Video signal in the areas where solid spaces are located in the original display page, then add color to them.

Solid space specification unit: line

Solid space specification register (16 bits)

For line 1 ... SOL11 and SOL10 (bits 1 and 0 in ORSOL4)

For line 2 ... SOL21 and SOL20 (bits 3 and 2 in ORSOL4)

: :

For line 8 ... SOL81 and SOL80 (bits 7 and 6 in ORSOL8)

Solid space specification

The solid space control functions as follows:

SOL\*1/SOL\*0

- "00" ... No solid space display
- "01" ... Solid space display left for 32 columns
- "10" ... Solid space display right for 32 columns
- "11" ... Solid space display left and right for 32 columns

Solid space color specification registers (3 bits) ... RBDT, GBDT, BBDT (bits 5 to 3 in ORBK)  
(same color as that of background)

## (13) Underline function

Underline function is used to add a line under a display character. The underline is same color as that of character.

Underline specification unit: Character

Underline enable register (1 bit) ... EUL (bit 4 in ORDSN) (this resides in the display memory)

|     |     |              |
|-----|-----|--------------|
| "0" | ... | No underline |
| "1" | ... | Underline    |

Underline color specification registers (3 bits) ... RDT, GDT, BDT (bit 2 to 0 in ORDSN)  
(this resides in the display memory, same color as that of character)



Figure 2-77. Underline



Figure 2-78. Solid Space

#### (14) Blinking function

Blinking function is used to blink any display character.

When BKMF = 1, characters specified to blink by BLF are not displayed. Blinking display is able to be set BKMF by software. (Space is displayed. That is, if the background color function is used, the background color is not disappeared.)

Blinking specification unit:

Character

Blinking specification register (1 bit) ... BLF (bit 3 in ORDSN) (in the display memory)

"0" ... No blinking

"1" ... Blinking

Blinking master flag (1 bit) ... BKMF (bit 6 in ORETC)

"0" ... Blinking function disable

"1" ... Blinking function enable

(Characters whose BLF

is set to "1" are not displayed.)



#### (15) Slant function

Slant function is used to slant characters for italics.

Slant specification unit:

Character

Slant enable register (1 bits) ... SLNT (bit 5 in ORDSN)

(in the display memory)

"0" ... No slant

"1" ... Slant

Figure 2-79. Slant

**Note :** *SLANT function is enabled each characters, and therefore, in case of using background function, this color of the Background is enable as slant. Regarding the extra dots of the left and / or right character by fringing function, it is not enabled as slant.*

#### (16) Multiple line display by OSD interrupt

Nine or more lines can be displayed using OSD interrupts. By changing the display start position and display data after the display of each line has been finished, the additional line is able to appear on screen.

Interrupt source select register (1 bit) ... SVD (bit 7 in ORIRC)

"0" ... An interrupt request is generated when scanning of a line specified by the value set in ISDC is finished (falling edge of  $\overline{HD}$  signal).

"1" ... An interrupt request is generated at falling edge of  $\overline{VD}$  signal

Display line counter

4-bit counter used to indicate a line being displayed.

This counter is cleared to "0000" at the falling edge of the  $\overline{VD}$  signal, and is incremented after the scanning of one displayline. (falling edge of the  $\overline{HD}$  signal).

The counter is incremented even when a line with all blank data or a line specified as display off. (The display line specified as display off by character size register is incremented by the same width of small character.)

The counter is necessary to be read twice, because it does not synchronize with CPU.

Display line counter register (4 bits) … DCTR (bits 3 to 0 in ORIRC)

“0000” … No display line is completed.

“0001” … 1’st display line is completed.

“0010” … 2’nd display line is completed.

to

“1111” … 15’th display line is completed.

Interrupt generation line specification register (3 bits) … ISDC (bits 6 to 4 in ORIRC)

When the lower 3 bits in DCTR are set as follows:

“000” … Interrupt request generated when the display line counter is cleared.

“001” … Interrupt request generated at end points of the last scanning line of the first display line

“010” … Interrupt request generated at end points of the last scanning line of the 2’nd display line

to

“111” … Interrupt request generated at end points of the last scanning line of the 7’th display line

(17) P6 port output select

P67 to P64 are able to be selected as P67 to P64 port or R/G/B/Y/BL output port by P67S to P64S.

P6 port output select registers (4 bits) … P67S to P64S (bits 7 to 4 in ORP6S)

“0” … R, G, B, Y/BL signal output

“1” … P6 port input/output

(18) OSD pin output polarity control

Output polarity control

Output polarity control registers (3 bits)

For BL … BLIV (bit 4 in ORIV)

For Y … YIV (bit 3 in ORIV)

For R, G, and B … RGBIV (bit 2 in ORIV)

Output polarity control

\*\*IV

“0” … Active high

“1” … Active low

(19) OSD pin input polarity control

Input polarity control

Input polarity control register (2 bits)

For Y/BLIN … YBLII (bit 1 in ORIV)

For RIN, GIN, and BIN … RGBII (bit 0 in ORIV)

Input polarity control

\*\*II

“0” … Active high

“1” … Active low

(20) Y/BL signal select

Y signal     ... Logical OR for R, G, B, character pattern, and fringing

BL signal     ...     EXBL (bit 6 in ORBK)

When EXBL = 0 (no full-raster blanking) :

Output in all areas where characters can be displayed.

Output in all areas where characters can be displayed.  
(except for character code 00H: blank data)

when FXBL = 1 (full-raster blanking):

Output in the whole screen

Output in the whole screen

Selects of either Y or BL signal output from the Y/BL pin

Y/BL signal select register (1 bit) ... YBLCS (bit 7 in ORETC)

“0” ... Y signal output

“1” ... BL signal output

## (21) R,G, B, Y/BL signal select

Selects either R, G, B, and Y/BL signals from the internal OSD circuit, or RIN, GIN, BIN, and Y/BLIN signals externally input.

R,G,B, Y/BL signal select registers (2 bits) ... MPXS1/MPXS0 (bits 3 and 2 in ORETC)

“00” … Simultaneous output (Signal from the OSD circuit has higher priority.)

"01" ... Output of signal from internal OSD circuit

“10” ... Output of signal from externally input

"11" ... Simultaneous output (Externally input signal has higher priority.)

## (22) Display memory access

There are two types of access: write data to the display memory and read data from the display memory.

The display memory is accessed using the following registers: DMA7 to DMA0, CRA7 to CRA0, RDT, GDT, BDT, BIF, FUI, SI NT, MBK, MFYWR, RDWRV.

- Display memory read mode specification register (1 bit)    ... MFYWR (bit 0 in ORP6S)
  - “0” ... Normal mode
  - “1” ... Read-modify-write-mode
- Read/write mode select register at normal mode (MFYWR = 0)
  - “0” ... Data write mode
  - “1” ... Data read mode
- Display memory bank switching register (1 bit)    ... MBK (bit 0 in ORETC)
  - “0” ... Access to either character code or character display options
  - “1” ... Access to both character code and character display options

Display memory auto increment depends on MBK setting.

Table 2-14. Address Increment

|           |         | RD         |                | WR         |                |
|-----------|---------|------------|----------------|------------|----------------|
|           |         | Color data | Character data | Color data | Character data |
| MFYWR = 0 | MBK = 0 | INC        | INC            | INC        | INC            |
|           | MBK = 1 | –          | INC            | –          | INC            |
| MFYWR = 1 | MBK = 0 | –          | –              | INC        | INC            |
|           | MBK = 1 | –          | –              | –          | INC            |

INC : Automatic address increment at read or write

– : No address change at data read or write

- Display memory address specification register (8 bits) … DMA7 to DMA0 (bits 7 to 0 in ORDMA)
- Display memory data access register
  - ① For character code access (8 bits) … CRA 7 to CRA0 (bits 7 to 0 in ORCRA)
  - ② For character ornamentation access (6 bits) … SLNT, EUL, BLF, RDT, GDT, and BDT (bits 5 to 0 in ORDSN)

There are two types of display memory access: normal mode and read-modify-write mode.

**Note1 :** *Don't use the 2 bytes transfer operation such as 「LDW (HL), mn 」 when accessing display memory.*

**Note2 :** *Can not access the display memory any of in read-modify-write instruction such as bit operate, etc.*

## 1. Normal mode

In normal mode, display memory addresses are automatically incremented for every read or write. Since addresses are automatically incremented, this mode is used for simultaneously reading data from multiple consecutive addresses and for simultaneously writing data to multiple consecutive addresses.

### - Display memory read sequence -

|                                                                                                                 |                          |
|-----------------------------------------------------------------------------------------------------------------|--------------------------|
| ① Set MFYWR to "0". (Set to normal mode.)                                                                       | EX.                      |
|                                                                                                                 | LD (ORP6S), 00H          |
| ② Set MBK to "0" or "1".                                                                                        | LD (ORETC), 00H or 01H   |
|                                                                                                                 | LD (ORP6S), 02H          |
| ③ Set RDWRV to "1". (Set to data read mode.)                                                                    | LD (ORDMA), n            |
|                                                                                                                 | LD A, (ORDSN) or (ORCRA) |
| ④ Set the display memory address to DMA7 to DMA0.                                                               |                          |
| ⑤ Read data from CRA7 to CRA0, SLNT, EUL, BLF, BDT, GDT, and RDT. (DMA7 to DMA0 are automatically incremented.) |                          |
| ⑥ For continuous read, repeat ④ and ⑤. (For data read from continuous addresses, repeat ⑤.)                     |                          |

### - Display memory write sequence -

|                                                                                                                |                          |
|----------------------------------------------------------------------------------------------------------------|--------------------------|
| ① Set MFYWR to "0". (Set to normal mode.)                                                                      | EX.                      |
|                                                                                                                | LD (ORP6S), 00H          |
| ② Set MBK to "0" or "1".                                                                                       | LD (ORETC), 00H or 01H   |
|                                                                                                                | LD (ORP6S), 00H          |
| ③ Set RDWRV to "0". (Set to data write mode.)                                                                  | LD (ORDMA), n            |
|                                                                                                                | LD (ORDSN) or (ORCRA), n |
| ④ Set the display memory address to DMA7 to DMA0.                                                              |                          |
| ⑤ Write data to CRA7 to CRA0, SLNT, EUL, BLF, BDT, GDT, and RDT. (DMA7 to DMA0 are automatically incremented.) |                          |
| ⑥ For continuous write, repeat ④ and ⑤. (For data write from continuous addresses, repeat ⑤.)                  |                          |

## 2. Read-modify-write mode

In read-modify-write mode, display memory addresses are automatically incremented during a write; not incremented during a read. Thus, immediately after data is read from a display memory address, data can be written to the same address. After a write, the display memory address is automatically incremented.

### - Read-modify-write sequence -

|                                                                                                       |                          |
|-------------------------------------------------------------------------------------------------------|--------------------------|
| ① Set MFYWR to 1.                                                                                     | EX.                      |
|                                                                                                       | LD (ORP6S), 01H          |
| ② Set MBK to 0 or 1.                                                                                  | LD (ORETC), 00H or 01H   |
|                                                                                                       | LD (ORDMA), n            |
| ③ Set display memory address to DMA7 to DMA0.                                                         | LD A, (ORDSN) or (ORCRA) |
|                                                                                                       | LD (ORDSN) or (ORCRA), n |
| ④ Read data from CRA7 to CRA0, SLNT, EUL, BLF, BDT, GDT, and RDT. (DMA7 to DMA0 are not incremented.) |                          |

- ⑤ Write data to CRA7 to CRA0, SLNT, EUL, BLF, BDT, GDT, and RDT. (DMA7 to DMA0 are automatically incremented.)
- ⑥ For continuous read-modify-write, repeat ③, ④, and ⑤.  
(For read-modify-write at consecutive addresses, repeat ④ and ⑤).

*Note: In read-modify-write mode, reading only or writing only can be executed.*

(23) Display on/off

Function used to display a line specified for on/off display.

Display on/off specified page by page

Display on/off specification register (1 bit) ... DON (bit 0 in ORDON)

|     |                     |
|-----|---------------------|
| "0" | ... Display disable |
| "1" | ... Display enable  |

*Note : Don't start STOP mode during display enable. When starting STOP mode, it is necessary that DON is specified as display off. If starting STOP mode during display, the contents of the display memory are broken.*

(24) Window

Function used to set upper and lower limit of page. Window upper limit is specified by WVSH7 to WVSH0 (ORWVSH). Window lower limit is specified by WVL7 to WVL0 (ORWVSL). This function is specified by setting EWDW (bit 1 in ORDON) to "1".

Window upper limit specification register (8bit) ... WVSH7 to WVSH0 (ORWVSH)

Window lower limit specification register (8bit) ... WVL7 to WVL0 (ORWVSL)

Window upper and lower limit position

|      |                                                         |
|------|---------------------------------------------------------|
| When | VDSMD = 0 (normal mode) :                               |
|      | WVSH = (WVSH7 to WVSH0) <sub>H</sub> × 1T <sub>HD</sub> |
|      | WVL = (WVL7 to WVL0) <sub>H</sub> × 1T <sub>HD</sub>    |
| When | VDSMD = 1 (double scan mode) :                          |
|      | WVSH = (WVSH7 to WVSH0) <sub>H</sub> × 2T <sub>HD</sub> |
|      | WVL = (WVL7 to WVL0) <sub>H</sub> × 2T <sub>HD</sub>    |

T<sub>HD</sub> : One cycle of HD signal

*Note : Modify value of window limit registers, at the timing from the end position of display all line to the start position of first display line, or the timing until the position of window upper limit.*

Window enable flag (1bit) ... EWDW (bit 1 in ORDON)

"0" ... window specification off

"1" ... window specification on



Figure 2-80. Window

## &lt;Usage example&gt;

The following can be displayed by combining the window and full-raster blanking functions.

Table 2-15. Window/full-raster Blanking

| EXBL | EWDW | Internal OSD BL output                                                                                             |
|------|------|--------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | Vertical direction : Character area is only displayed.<br>Horizontal direction : Character area is only displayed. |
| 0    | 1    | Vertical direction : Window area is displayed.<br>Horizontal direction : Character area is only displayed.         |
| 1    | 0    | Vertical direction : Whole page is displayed.<br>Horizontal direction : Whole page is displayed.                   |
| 1    | 1    | Vertical direction : Window area is displayed.<br>Horizontal direction : Window area is displayed.                 |



Figure 2-81. TV screen Image Using Window Function

## (25) OSD interrupt control

Interrupt latch of the both OSD interrupt and SLICER interrupt is the same. OSD and SLCR of ORIRC register are interrupt enable registers and interrupt source detection register. When OSD interrupt is enabled, set the OSD of the OSD interrupt enable register (bit 3 in ORIRC) to "1", and when SLICER interrupt is enabled, set the SLCR of the SLICER interrupt enable register (bit 2 in ORIRC) to "1". OSD and SLICER interrupts can be enabled at the same time.

OSD interrupt enable register … OSD (bit 3 in ORIRC)

"0" … OSD interrupt is disabled

"1" … OSD interrupt is enabled

SLICER interrupt enable register … SLCR (bit 2 in ORIRC)

"0" … SLICER interrupt is disabled

"1" … SLICER interrupt is enabled

When OSD and SLICER are enabled at the same time, the interrupt source can be detected by OSD (bit 5 in ORIRC) and SLCR (bit 4 in ORIRC) of the interrupt source monitor register whether it is OSD interrupt or it is SLICER interrupt.

These OSD and SLCR bits of the interrupt source monitor register are cleared by executing the read instruction for this register.

*Note : OSD and SLCR bits of the interrupt enable register is different from those of the interrupt source monitor register.*

## (26) OSD control register write/read

The addresses of the OSD control registers are assigned to the DBR register.

For writing data to or reading data from the OSD control registers, access the DBR register in the normal way.

If RGWR register is set to "1" the written data is transferred to the OSD circuit and become valid.

However, while the display line is being scanned, the data written after the line is scanned is transferred to the OSD circuit and becomes valid.

The registers for writing data to display memory become valid, when its data is written. (DMA7 to DMA0, CRA7 to CRA0, RDT, GDT, BDT, BLF, EUL, SLNT, YBLCS, BKMF, ESMZ, VDSMD, MPX, MBK, P67S to P64S, RDWRV, and MFYWR)

OSD control register are initialized in STOP mode.

- Written data transfer register (1 bit) … RGWR (bit 2 in ORDON)

"0" … Initialized state

"1" … Transfers written data to OSD circuit. (After transfer, RGWR is cleared to "0".)

<RGWR timing>

1). RGWR system



Figure 2-82. RGWR System

2). Transfer timing

① No display area (except any lines specified as display off by character size)

When having set RGWR to "1" during no display area, the timing of OSD register data transferred to OSD circuit is at the falling edge of  $\overline{HD}$  signal.



Figure 2-83. Data Transfer Timing in No Display Area

② Display area

When having set RGWR to "1" during display area, the timing of OSD register data transferred to OSD circuit is at the falling edge of  $\overline{HD}$  signal when the display line has been finished.



Figure 2-84. Data Transfer Timing in Display Area

3). Flag

RGWR flag is set to "1" during the period from the timing having sett RGWR to "1" to the timing register transfer pulse is generated.

When RGWR flag becomes "0", the data of OSD register can be available. After setting RGWR to "1", it is possible to write OSD registers even RGWR flag is "1".

## (27) OSD control registers

|                                      | 7    | 6                                          | 5    | 4    | 3    | 2    | 1    | 0    |                           |
|--------------------------------------|------|--------------------------------------------|------|------|------|------|------|------|---------------------------|
| <b>ORVS1</b><br>(OF81 <sub>H</sub> ) | VS17 | VS16                                       | VS15 | VS14 | VS13 | VS12 | VS11 | VS10 | (Initial value 0000 0000) |
| <b>ORVS2</b><br>(OF82 <sub>H</sub> ) | VS27 | VS26                                       | VS25 | VS24 | VS23 | VS22 | VS21 | VS20 | (Initial value 0000 0000) |
| <b>ORVS3</b><br>(OF83 <sub>H</sub> ) | VS37 | VS36                                       | VS35 | VS34 | VS33 | VS32 | VS31 | VS30 | (Initial value 0000 0000) |
| <b>ORVS4</b><br>(OF84 <sub>H</sub> ) | VS47 | VS46                                       | VS45 | VS44 | VS43 | VS42 | VS41 | VS40 | (Initial value 0000 0000) |
| <b>ORVS5</b><br>(OF85 <sub>H</sub> ) | VS57 | VS56                                       | VS55 | VS54 | VS53 | VS52 | VS51 | VS50 | (Initial value 0000 0000) |
| <b>ORVS6</b><br>(OF86 <sub>H</sub> ) | VS67 | VS66                                       | VS65 | VS64 | VS63 | VS62 | VS61 | VS60 | (Initial value 0000 0000) |
| <b>ORVS7</b><br>(OF87 <sub>H</sub> ) | VS77 | VS76                                       | VS75 | VS74 | VS73 | VS72 | VS71 | VS70 | (Initial value 0000 0000) |
| <b>ORVS8</b><br>(OF88 <sub>H</sub> ) | VS87 | VS86                                       | VS85 | VS84 | VS83 | VS82 | VS81 | VS80 | (Initial value 0000 0000) |
| VSn8 to 0                            |      | Vertical display start position for line n |      |      |      |      |      |      | write only                |

| ORCS4<br>(0F89H) | 7   | 6                                          | 5               | 4 | 3               | 2 | 1                | 0 | (n = 1 to 8)              |            |
|------------------|-----|--------------------------------------------|-----------------|---|-----------------|---|------------------|---|---------------------------|------------|
|                  | CS4 |                                            | CS3             |   | CS2             |   | CS1              |   | (Initial value 0000 0000) |            |
| ORCS8<br>(0F8AH) | CS8 |                                            | CS7             |   | CS6             |   | CS5              |   | (Initial value 0000 0000) |            |
| CSn              | n   | Character size and display on/off for line | 00: Display off |   | 01 : Large size |   | 10 : Middle size |   | 11 : Small size           | write only |

| OREFR<br>(0F8B <sub>H</sub> ) | 7                          | 6    | 5    | 4    | 3    | 2              | 1                  | 0          | (n = 1 to 8)              |
|-------------------------------|----------------------------|------|------|------|------|----------------|--------------------|------------|---------------------------|
|                               | EFR8                       | EFR7 | EFR6 | EFR5 | EFR4 | EFR3           | EFR2               | EFR1       | (Initial value 0000 0000) |
| EFRn                          | Fringing enable for line n |      |      |      |      | 0: No fringing | 1: Fringing enable | write only |                           |

| ORSOL4 (0F8C <sub>H</sub> ) |                               |                            |                                             |                                              |                                                       |  |            | (n = 1 to 8)              |
|-----------------------------|-------------------------------|----------------------------|---------------------------------------------|----------------------------------------------|-------------------------------------------------------|--|------------|---------------------------|
|                             |                               |                            |                                             |                                              |                                                       |  |            | (Initial value 0000 0000) |
| ORSOL8 (0F8D <sub>H</sub> ) |                               |                            |                                             |                                              |                                                       |  |            | (Initial value 0000 0000) |
|                             |                               |                            |                                             |                                              |                                                       |  |            |                           |
| SOLn                        | Solid space enable for line n | 00: No solid space display | 01 :Solid space display left for 32 columns | 10 :Solid space display right for 32 columns | 11 :Solid space display left and right for 32 columns |  | write only | (n = 1 to 8)              |

ORBK  
(0F8EH)

|       |      |      |      |      |      |      |      |
|-------|------|------|------|------|------|------|------|
| 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| EBKGD | EXBL | RBDT | GBDT | BBDT | RFDT | GFDT | BFDT |

 (Initial value 0000 0000)

|                        |                             |                                                                                                             |            |
|------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------|------------|
| EBKGD                  | Background function enable  | 0: No background function<br>1: Background function enable                                                  | write only |
| EXBL                   | Full-raster blanking enable | 0: No Full-raster blanking<br>1: Full-raster blanking                                                       |            |
| RBDT/<br>GBDT/<br>BBDT | Background color select     | 000: Black<br>001: Blue<br>010: Green<br>011: Cyan<br>100: Red<br>101: Magenta<br>110: Yellow<br>111: White |            |
| RFDT/<br>GFDT/<br>BFDT | Fringing color select       | 001: Blue<br>010: Green<br>011: Cyan<br>100: Red<br>101: Magenta<br>110: Yellow<br>111: White               |            |
|                        |                             |                                                                                                             |            |
|                        |                             |                                                                                                             |            |

ORETC  
(0F8FH)

|       |      |      |       |      |     |     |                           |
|-------|------|------|-------|------|-----|-----|---------------------------|
| 7     | 6    | 5    | 4     | 3    | 2   | 1   | 0                         |
| YBLCS | BKMF | ESMZ | VDSMD | MPXS | "0" | MBK | (Initial value 0000 0000) |

|       |                               |                                                                                                                                                                                                                                                      |            |
|-------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| YBLCS | Y/BL signal select            | 0: Y signal output<br>1: BL signal output                                                                                                                                                                                                            | write only |
| BKMF  | Blinking master flag          | 0: Blinking function disable<br>1: Blinking function enable                                                                                                                                                                                          |            |
| ESMZ  | Smoothing enable              | 0: No smoothing<br>1: Smoothing enable                                                                                                                                                                                                               |            |
| VDSMD | Double scan mode select       | 0: Normal mode<br>1: Double scan mode                                                                                                                                                                                                                |            |
| MPXS  | R, G, B, Y/BL signal select   | 00: Simultaneous output (Signal from the OSD circuit has higher priority.)<br>01: Output of signal from internal OSD circuit<br>10: Output of signal from externally input<br>11: Simultaneous output (Externally input signal has higher priority.) |            |
| MBK   | Display memory bank switching | 0: Access to either character code or character display options<br>1: Access to both character code and character display options                                                                                                                    |            |

ORIRC  
(0F90H)

|     |      |     |      |       |       |       |                           |
|-----|------|-----|------|-------|-------|-------|---------------------------|
| 7   | 6    | 5   | 4    | 3     | 2     | 1     | 0                         |
| SVD | ISDC | OSD | SLCR | ..... | ..... | ..... | (initial value 0000 0000) |

|      |                                  |                                                                                                    |            |
|------|----------------------------------|----------------------------------------------------------------------------------------------------|------------|
| SVD  | Interrupt source select          | 0: Interrupt request by the value of ISDC<br>1: Interrupt request by the falling edge of VD signal | write only |
| ISDC | Interrupt generation line select |                                                                                                    |            |
| OSD  | OSD interrupt enable select      | 0: OSD interrupt disable<br>1: OSD interrupt enable                                                |            |
| SLCR | SLICER interrupt enable select   | 0: SLICER interrupt disable<br>1: SLICER interrupt enable                                          |            |

| ORIRC<br>(0F90H) | 7 | 6 | 5   | 4    | 3 | 2    | 1 | 0 |  | (initial value 0000 0000) |
|------------------|---|---|-----|------|---|------|---|---|--|---------------------------|
|                  |   |   | OSD | SLCR |   | DCTR |   |   |  |                           |

|      |                          |                                                                    |            |
|------|--------------------------|--------------------------------------------------------------------|------------|
| OSD  | OSD interrupt monitor    | 0: OSD interrupt no generated<br>1: OSD interrupt generated        | write only |
| SLCR | SLICER interrupt monitor | 0: SLICER interrupt not generated<br>1: SLICER interrupt generated |            |
| DCTR | Display line counter     |                                                                    |            |

| ORP6S<br>(0F91H) | 7    | 6    | 5    | 4    | 3 | 2 | 1     | 0     |  | (Initial value 0000 **00) |
|------------------|------|------|------|------|---|---|-------|-------|--|---------------------------|
|                  | P67S | P66S | P65S | P64S |   |   | RDWRV | MFYWR |  |                           |

|              |                                       |                                                           |            |
|--------------|---------------------------------------|-----------------------------------------------------------|------------|
| P67S to P64S | P6 port output select                 | 0: R, G, B, Y/BL signal output<br>1: Port contents output | write only |
| RDWRV        | Read/write mode select at normal mode | 0: Data write mode<br>1: Data read mode                   |            |
| MFYWR        | Display memory read mode              | 0: Normal mode<br>1: Read-modify-write-mode               |            |

| ORIV<br>(0F92H) | 7   | 6    | 5   | 4    | 3   | 2     | 1     | 0     |  | (Initial value 0000 0000) |
|-----------------|-----|------|-----|------|-----|-------|-------|-------|--|---------------------------|
|                 | "0" | FORS | "1" | BLIV | YIV | RGBIV | YBLII | RGBII |  |                           |

|       |                                     |                                                      |            |
|-------|-------------------------------------|------------------------------------------------------|------------|
| FORS  | fosc frequency select               | 0: Normal frequency mode<br>1: Double frequency mode | write only |
| BLIV  | BL output polarity select           | 0: Active high<br>1: Active low                      |            |
| YIV   | Y output polarity select            | 0: Active high<br>1: Active low                      |            |
| RGBIV | R, G, B output polarity select      | 0: Active high<br>1: Active low                      |            |
| YBLII | Y/BLIN input polarity select        | 0: Active high<br>1: Active low                      |            |
| RGBII | RIN, GIN, BIN input polarity select | 0: Active high<br>1: Active low                      |            |

| ORDMA<br>(0F93H) | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  | (Initial value 0000 0000) |
|------------------|------|------|------|------|------|------|------|------|--|---------------------------|
|                  | DMA7 | DMA6 | DMA5 | DMA4 | DMA3 | DMA2 | DMA1 | DMA0 |  |                           |

|           |                        |            |
|-----------|------------------------|------------|
| DMA7 to 0 | Display memory address | write only |
|-----------|------------------------|------------|

| ORDSN<br>(0F94H) | 7 | 6    | 5   | 4   | 3   | 2   | 1   | 0 |  | (Initial value **** ****) |
|------------------|---|------|-----|-----|-----|-----|-----|---|--|---------------------------|
|                  |   | SLNT | EUL | BLF | RDT | GDT | BDT |   |  |                           |

|                     |                        |                                                                                               |     |
|---------------------|------------------------|-----------------------------------------------------------------------------------------------|-----|
| SLNT                | Slant enable           | 0: No slant<br>1: Slant                                                                       | R/W |
| EUL                 | Underline enable       | 0: No underline<br>1: Underline                                                               |     |
| BLF                 | Blinking enable        | 0: No blinking<br>1: Blinking                                                                 |     |
| RDT/<br>GDT/<br>BDT | Character color select | 001: Blue<br>010: Green<br>011: Cyan<br>100: Red<br>101: Magenta<br>110: Yellow<br>111: White |     |
|                     |                        |                                                                                               |     |

| ORCRA<br>(0F95H) | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  | (Initial value **** ****) |
|------------------|------|------|------|------|------|------|------|------|--|---------------------------|
|                  | CRA7 | CRA6 | CRA5 | CRA4 | CRA3 | CRA2 | CRA1 | CRA0 |  |                           |

|           |                |     |
|-----------|----------------|-----|
| CRA7 to 0 | Character code | R/W |
|-----------|----------------|-----|

**ORDON** 7 6 5 4 3 2 1 0  
 (0F96<sub>H</sub>) 

|  |  |  |  |  |     |      |      |     |
|--|--|--|--|--|-----|------|------|-----|
|  |  |  |  |  |     |      |      |     |
|  |  |  |  |  | "1" | RGWR | EWDW | DON |

 (Initial value \*\*\*\* 0000)

|      |                               |                                                                                                         |     |
|------|-------------------------------|---------------------------------------------------------------------------------------------------------|-----|
| RGWR | Written data transfer control | 0: (Initial state)<br>1: Transfers written data to OSD circuit. (After transfer, RGWR is reset to "0".) | R/W |
| EWDW | Window enable                 | 0: Window specification off<br>1: Window specification on                                               |     |
| DON  | Display on/off select         | 0: Display disable<br>1: Display enable                                                                 |     |

**ORWVSH** 7 6 5 4 3 2 1 0  
 (0F97<sub>H</sub>) 

|       |       |       |       |       |       |       |       |
|-------|-------|-------|-------|-------|-------|-------|-------|
| WVSH7 | WVSH6 | WVSH5 | WVSH4 | WVSH3 | WVSH2 | WVSH1 | WVSH0 |
|-------|-------|-------|-------|-------|-------|-------|-------|

 (Initial value 0000 0000)

|            |                             |            |
|------------|-----------------------------|------------|
| WVSH7 to 0 | Window upper limit position | Write only |
|------------|-----------------------------|------------|

**ORWVSL** 7 6 5 4 3 2 1 0  
 (0F98<sub>H</sub>) 

|       |       |       |       |       |       |       |       |
|-------|-------|-------|-------|-------|-------|-------|-------|
| WVSL7 | WVSL6 | WVSL5 | WVSL4 | WVSL3 | WVSL2 | WVSL1 | WVSL0 |
|-------|-------|-------|-------|-------|-------|-------|-------|

 (Initial value 0000 0000)

|            |                             |            |
|------------|-----------------------------|------------|
| WVSL7 to 0 | Window lower limit position | Write only |
|------------|-----------------------------|------------|

*Note 1: \*; don't care*

*Note 2: All OSD control registers cannot use the read-modify-write instructions (bit manipulation instructions such as SET, CLR, etc. and logical operation such as AND, OR, etc.)*

*Note 3: Write "0" to bit 1 of ORETC when writing to ORETC.*

*Note 4: Write "1" to bit 3 of ORDON when writing to ORDON.*

*Note 5: The registers of ORHS1, ORVS1 to ORVS8, ORCS4, ORCS8, OREFR, ORSOL4, ORSOL8, ORBK, ORIRC, ORIV, ORWVSH, and ORWVSL are changed by RGWR. Bits 2 to 1 in ORDON are also changed by RGWR.*

*Note 6: Write "0" to bit 7, "1" to bit5 of ORIV when writing to ORIV.*

## (28) OSD command register list (DBR register)

| Address         | 7                                                                                                                                                       | 6     | 5            | 4             | 3            | 2             | 1     | 0     |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------|---------------|--------------|---------------|-------|-------|
| ORHS1<br>★ 0F80 | Horizontal display start position<br>HS16                                                                                                               | HS15  |              | HS14          | HS13         | HS12          | HS11  | HS10  |
| ORVS1<br>★ 81   | Vertical display start position for line 1<br>VS17                                                                                                      | VS16  | VS15         | VS14          | VS13         | VS12          | VS11  | VS10  |
| ORVS2<br>★ 82   | Vertical display start position for line 2<br>VS27                                                                                                      | VS26  | VS25         | VS24          | VS23         | VS22          | VS21  | VS20  |
| ORVS3<br>★ 83   | Vertical display start position for line 3<br>VS37                                                                                                      | VS36  | VS35         | VS34          | VS33         | VS32          | VS31  | VS30  |
| ORVS4<br>★ 84   | Vertical display start position for line 4<br>VS47                                                                                                      | VS46  | VS45         | VS44          | VS43         | VS42          | VS41  | VS40  |
| ORVS5<br>★ 85   | Vertical display start position for line 5<br>VS57                                                                                                      | VS56  | VS55         | VS54          | VS53         | VS52          | VS51  | VS50  |
| ORVS6<br>★ 86   | Vertical display start position for line 6<br>VS67                                                                                                      | VS66  | VS65         | VS64          | VS63         | VS62          | VS61  | VS60  |
| ORVS7<br>★ 87   | Vertical display start position for line 7<br>VS77                                                                                                      | VS76  | VS75         | VS74          | VS73         | VS72          | VS71  | VS70  |
| ORVS8<br>★ 88   | Vertical display start position for line 8<br>VS87                                                                                                      | VS86  | VS85         | VS84          | VS83         | VS82          | VS81  | VS80  |
| ORCS4<br>★ 89   | Character size and display on/off for line 1, 2, 3 and 4<br>CS41                                                                                        | CS40  | CS31         | CS30          | CS21         | CS20          | CS11  | CS10  |
| ORCS8<br>★ 8A   | Character size and display on/off for line 5, 6, 7 and 8<br>CS81                                                                                        | CS80  | CS71         | CS70          | CS61         | CS60          | CS51  | CS50  |
| OREFR<br>★ 8B   | Fringing enable for line<br>EFR8                                                                                                                        | EFR7  | EFR6         | EFR5          | EFR4         | EFR3          | EFR2  | EFR1  |
| ORSOL4<br>★ 8C  | Solid space enable for line 1, 2, 3 and 4<br>SOL41                                                                                                      | SOL40 | SOL31        | SOL30         | SOL21        | SOL20         | SOL11 | SOL10 |
| ORSOL8<br>★ 8D  | Solid space enable for line 5, 6, 7 and 8<br>SOL81                                                                                                      | SOL80 | SOL71        | SOL70         | SOL61        | SOL60         | SOL51 | SOL50 |
| ORBK<br>★ 8E    | Background function enable, Full-raster blanking enable, Background color select, Fringing color select<br>EBKGD                                        | EXBL  | RBDT         | GBDT          | BBDT         | RFDT          | GFDT  | BFDT  |
| ORETC<br>8F     | Y/BL signal select, Blinking master flag, Smoothing enable, Double scan mode select, R, G, B, Y/BL signal select, Display memory bank switching<br>YBLS | BKMF  | ESMZ         | VDSMD         | MPXS1        | MPXS0         | "0"   | MBK   |
| ORIRC<br>★ 90   | OSD interrupt control, Display line counter<br>SVD                                                                                                      | ISDC2 | ISDC1<br>OSD | ISDC0<br>SLCR | OSD<br>DCTR3 | SLCR<br>DCTR2 | DCTR1 | DCTR0 |
| ORP6S<br>91     | P6 port output select. Read/write mode select at normal mode, Display memory read mode<br>P67S                                                          | P66S  | P65S         | P64S          |              | RDWRV         |       | MFYWR |
| ORIV<br>★ 92    | fosc frequency select, OSD pin output polarity control, OSD pin input polarity control.<br>"0"                                                          | FORS  | "1"          | BLIV          | YIV          | RGBIV         | YBLII | RGBII |
| ORDMA<br>93     | Display memory address<br>DMA7                                                                                                                          | DMA6  | DMA5         | SMA4          | DMA3         | DMA2          | DMA1  | DMA0  |
| ORDSN<br>94     | Character ornamentation<br>*                                                                                                                            |       |              | SENT          | EUL          | BLF           | RDT   | GDT   |
| ORCRA<br>95     | Character code<br>CRA7                                                                                                                                  | CRA6  | CRA5         | CRA4          | CRA3         | CRA2          | CRA1  | CRA0  |
| ORDON<br>★ 96   | Write data transfer control. Window enable. Display on/off select.<br>"1"                                                                               |       |              |               | RGWR         | EWDW          | DON   |       |
| ORWVSH<br>★ 97  | Window upper limit position<br>WVSH7                                                                                                                    | WVSH6 | WVSH5        | WVSH4         | WVSH3        | WVSH2         | WVSH1 | WVSH0 |
| ORWVSL<br>★ 98  | Window lower limit position<br>WVSL7                                                                                                                    | WVSL6 | WVSL5        | WVSL4         | WVSL3        | WVSL2         | WVSL1 | WVSL0 |

Note 1; ★ : These OSD registers are changed by RGWR.

★★ : Only lower 2 bits are changed by RGWR.

Read only,  R/W

(Can not access ORDON any of read-modify-write instruction such as bit operate etc.)

## 2.14 Jitter Elimination Circuit

The 87CH34B/CK34B/M34B has a built-in jitter elimination circuit which maintains the vertical stability of the OSD even when input of the vertical sync signal fluctuates.

Using the hardware jitter elimination mode enables smoothing for lower-case characters on the OSD.

### 2.14.1 Configuration



Figure 2-85. Jitter Elimination Circuit

### 2.14.2 Control

Jitter elimination circuit is controlled by the jitter elimination control register (JECR).

#### Jitter elimination control register

| JEGR (0FAB <sub>H</sub> ) |                          |   |   |   |      |      |     |                            |
|---------------------------|--------------------------|---|---|---|------|------|-----|----------------------------|
|                           | 7                        | 6 | 5 | 4 | 3    | 2    | 1 0 |                            |
| AFLD                      | Automatic Field Decision |   |   |   | AFLD | HJRM | "0" | SJRMCK                     |
| HJRM                      | jitter elimination mode  |   |   |   | 0    | 1    |     | (initial value: **** 0000) |
| SJRMCK                    |                          |   |   |   | 0    | 1    |     |                            |

**AFLD** Automatic Field Decision  
0: Automatic Field Decision disable  
1: Automatic Field Decision enable

**HJRM** jitter elimination mode  
0: jitter elimination disable  
1: jitter elimination enable

**SJRMCK**  
0: source clock: 2/fc in 8MHz mode  
1: source clock: 1/fc in 4MHz mode

**Note 1:** Clears the AFLD to zero in other than jitter elimination mode.

**Note 2:** Always write "0" to bit 1 in JEGR.

**Note 3:** When using jitter elimination circuit, SJRMCK must be set, using the CPU clock of 4 MHz or 8 MHz. Otherwise, misoperation may result.

**Note 4:** In a non-interlace TV, the jitter elimination circuit must be disabled  
(If not disabled, OSD display is disarranged.)

**Note 5:** \* ; don't care

#### Jitter elimination status register

| JRMSR (0FAC <sub>H</sub> ) |   |   |   |   |   |   |     |                             |
|----------------------------|---|---|---|---|---|---|-----|-----------------------------|
|                            | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 |                             |
| FDSF                       |   |   |   |   |   |   |     | (initial value: 0**** ****) |

**FDSF** Field Detect Status Flag  
0: A position of a scanning line exists in the field which has a second display dot of character on an interlaced TV screen  
1: A position of a scanning line exists in the field which has a first display dot of character on an interlaced TV screen

**Note 1:** FDSF is different from the 1st and the 2nd field. It is a unique field decided for OSD display.

**Note 2:** \* ; don't care

#### Jitter Elimination Control Register, Jitter Elimination Status Register

### 2.14.3 Jitter Elimination Mode

The jitter elimination mode is to identify the phase of the falling edges of the external  $\overline{VD}$  signal and  $\overline{HD}$  signal. When  $\overline{VD}$  signal is falling within  $\overline{HD}$  signal falling  $+/-1/4HD$ , the jitter is automatically eliminated and internal VD signal is set to the stable location.

When the jitter elimination control register, HJRM (bit 2 in JEGR) is set to 1, the mode is turned to the jitter elimination mode. When the jitter elimination mode is used, CPU clock is used at 8 MHz or 4 MHz. SJRMCK is set to 0 at 8 MHz and SJRMCK is set to 1 at 4 MHz. When AFLD (bit 3 in JEGR) is set to 1, the smoothing function is realized with on-screen display in lower-case characters on the OSD.

## **2.15 Data Slicer**

The 87CH34B/K34B/M34B contains the data slicer to decode the caption data multiplied during vertical flyback time of the composite video signal. The composite video signal is input to the data slicer circuit through P32 (VIN1) and P33 (VIN0). The caption data is decoded from the video signal and the caption is displayed. The sync signal inputs negative composite video signal to VIN0 and VIN1 pins. This can comply with the copy guard signal and special signals and receive accurately the caption data under the condition of a weak electrical field or a ghost.

### 2.15.1 Configuration



Figure 2-89. Data Slicer

## 2.15.2 Functions

- (1) **Video signal input**  
A low pass filter ( $f_T = 503$  kHz), a voltage amplifier (twice as much) and a condenser of about  $0.1 \mu\text{F}$  are connected between the video signal and the video signal input pin of VIN1 and VIN0 pins, that is shown as Figure 2.91. The low pass filter functions to reduce noise and color burst from the video signal, passes the amplifier and inputs the video signal to both VIN1 and VIN0 pins.
- (2) **Synchronous separator**  
This circuit is to separate the synchronous signal from the video signal. When DACL 7 to 0 of DACLCR are set for the synchronous separation, the sync slice level is capable of setting. Refer to "2.15.5 Clamp and Data slicer" in detail.)
- (3) **Data separator**  
The data separator replaces the caption data piled on the video signal with the digital signal. When SLVL 5 to 0 of SLVLCR are set to get the digital signal, the initial value of the caption data slice level is capable of setting.
- (4) **Sync-chip clamp circuit**  
The sync-chip level is clamped to the specified value.
- (5) **Pedestal clamp circuit**  
The video signal is set to the specified voltage with the clamp pulse generated from the H/V timing part, which is called as a pedestal clamp.
- (6) **D/A converter**  
This converter gets the clamp level to the clamp circuit and slice level to the comparator.
- (7) **Comparator**  
This comparator compares the voltage of the slice level and the clamped video signal.
- (8) **H timing circuit**  
This circuit detects the horizontal synchronous signal from C.Sync signal separated synchronously from the video signal, and generates the clamp pulse to clamp the video signal and provides it to the pedestal clamp circuit. In addition, the circuit detects the change of H frequency and provides the data to the sampling clock generation part.
- (9) **V timing circuit**  
This circuit detects the vertical synchronous signal from C.Sync signal separated synchronously from the video signal, and provides the caption line detection signal to take out caption signal to the slice level control part. CLINE (bits 3 to 0 in SIFSMSI) sets the caption line. (Line 21 is usually set.)
- (10) **Slice level control circuit**  
This circuit detects CRI (clock run in) signal from VIDEO signal with the caption line detection signal generated at H/V timing part after slicing, and controls to the most suitable slice level and takes out the caption data.

(11) Sampling clock generation circuit

This circuit generates the sampling clock which is phase-locked to CRI signal with CRI signal detected at the slice level control part. In addition, the circuit corrects the location where the sampling clock generates with H frequency variable data generated at H timing generation part.

(12) Slicer interface circuit

This is a 16-bit serial interface to receive the serial data.

(13) Interrupt generation circuit

The interrupt generates at the rising of the caption line detection signal.



Figure 2-90. Interrupt Generation Timing

The interrupt vector is referred to the interrupt vector item in the on-screen display circuit.

(14) C.Sync external input mode

Setting EXSYNC (bit 5 in SIFSMS1) to "1" can use external C.Sync signal internally.

The polarity of C.Sync signal is selectable depending on SYNCINV (bit 6 in SIFSMS1).

### 2.15.3 Video Signal Connection



Figure 2-91. Video Signal Connection

### 2.15.4 Control

Interrupt control (Initial value : 0000 00\*\*)



| Bit name | Function | Bit definition                                                               |            |
|----------|----------|------------------------------------------------------------------------------|------------|
| SLCR     |          | 0 : Slicer interrupt disable<br>1 : Select the slicer as an interrupt factor | write only |

Interrupt control



| Bit Name | Function | Bit definition                                                     |           |
|----------|----------|--------------------------------------------------------------------|-----------|
| SLCR     |          | Interrupt request monitor from the slicer<br>1 : Interrupt request | read only |

\* OSD / SLCR bits are set to "1" with interrupt request and it is cleared to "0" when the flag is read.

Figure 2-92-1. Interrupt Control

| SIF data register 1 (Caption data 1st byte read register)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                             |                                                             |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------------------------------------------------------|-----------|-------|-------|-------|-------|----------|----------|----------------|----------------|-------|------------------------|-------------------------------------------------------------|-----------|-----------|---------------|--|-------|----------------------|--------------------------------|------|-------------------------------|-------------------------|------|---------------------------------------------|-----------------------------|
| SIFDR0<br>(0F98H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 7                                           | 6                                                           | 5         | 4     | 3     | 2     | 1     | 0        |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| <table border="1"> <tr> <td>D1ST7</td><td>D1ST6</td><td>D1ST5</td><td>D1ST4</td><td>D1ST3</td><td>D1ST2</td><td>D1ST1</td><td>D1ST0</td><td></td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                             |                                                             |           |       |       |       |       |          | D1ST7    | D1ST6          | D1ST5          | D1ST4 | D1ST3                  | D1ST2                                                       | D1ST1     | D1ST0     |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| D1ST7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | D1ST6                                       | D1ST5                                                       | D1ST4     | D1ST3 | D1ST2 | D1ST1 | D1ST0 |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| <table border="1"> <thead> <tr> <th>Bit name</th><th>Function</th><th>Bit definition</th><th></th></tr> </thead> <tbody> <tr> <td>DIST7-0</td><td>Caption data 1st byte read register</td><td></td><td>read only</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                                                             |                                             |                                                             |           |       |       |       |       |          | Bit name | Function       | Bit definition |       | DIST7-0                | Caption data 1st byte read register                         |           | read only |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| Bit name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Function                                    | Bit definition                                              |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| DIST7-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Caption data 1st byte read register         |                                                             | read only |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| SIF data register 2 (Caption data 2nd byte read register)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                             |                                                             |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| SIFDR1<br>(0F99H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 7                                           | 6                                                           | 5         | 4     | 3     | 2     | 1     | 0        |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| <table border="1"> <tr> <td>D2ND7</td><td>D2ND6</td><td>D2ND5</td><td>D2ND4</td><td>D2ND3</td><td>D2ND2</td><td>D2ND1</td><td>D2ND0</td><td></td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                             |                                                             |           |       |       |       |       |          | D2ND7    | D2ND6          | D2ND5          | D2ND4 | D2ND3                  | D2ND2                                                       | D2ND1     | D2ND0     |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| D2ND7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | D2ND6                                       | D2ND5                                                       | D2ND4     | D2ND3 | D2ND2 | D2ND1 | D2ND0 |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| <table border="1"> <thead> <tr> <th>Bit name</th><th>Function</th><th>Bit definition</th><th></th></tr> </thead> <tbody> <tr> <td>D2ND/-0</td><td>Caption data 2nd byte read register</td><td></td><td>read only</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                                                             |                                             |                                                             |           |       |       |       |       |          | Bit name | Function       | Bit definition |       | D2ND/-0                | Caption data 2nd byte read register                         |           | read only |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| Bit name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Function                                    | Bit definition                                              |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| D2ND/-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Caption data 2nd byte read register         |                                                             | read only |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| SIF status register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                             |                                                             |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| SIFSR<br>(0F9AH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 7                                           | 6                                                           | 5         | 4     | 3     | 2     | 1     | 0        |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| <table border="1"> <tr> <td>STCRI</td><td>CRIN3</td><td>CRIN2</td><td>CRIN1</td><td>CRIN0</td><td>STFLD</td><td>STS8</td><td>STDE</td><td></td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                             |                                                             |           |       |       |       |       |          | STCRI    | CRIN3          | CRIN2          | CRIN1 | CRIN0                  | STFLD                                                       | STS8      | STDE      |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| STCRI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | CRIN3                                       | CRIN2                                                       | CRIN1     | CRIN0 | STFLD | STS8  | STDE  |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| <table border="1"> <thead> <tr> <th>Bit name</th><th>Function</th><th>Bit definition</th><th></th></tr> </thead> <tbody> <tr> <td>STCRI</td><td>Clock run in detection</td><td>1 : Clock run in detection<br/>0 : No clock run in detection</td><td rowspan="5">read only</td></tr> <tr> <td>CRIN</td><td>CRI number -1</td><td></td></tr> <tr> <td>STFLD</td><td>Field identification</td><td>1 : 2nd field<br/>0 : 1st field</td></tr> <tr> <td>STS8</td><td>Start bit identification flag</td><td>1 : Start bit detection</td></tr> <tr> <td>STDE</td><td>16 bit data receive end identification flag</td><td>1 : 16 bit data receive end</td></tr> </tbody> </table> |                                             |                                                             |           |       |       |       |       | Bit name | Function | Bit definition |                | STCRI | Clock run in detection | 1 : Clock run in detection<br>0 : No clock run in detection | read only | CRIN      | CRI number -1 |  | STFLD | Field identification | 1 : 2nd field<br>0 : 1st field | STS8 | Start bit identification flag | 1 : Start bit detection | STDE | 16 bit data receive end identification flag | 1 : 16 bit data receive end |
| Bit name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Function                                    | Bit definition                                              |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| STCRI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Clock run in detection                      | 1 : Clock run in detection<br>0 : No clock run in detection | read only |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| CRIN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CRI number -1                               |                                                             |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| STFLD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Field identification                        | 1 : 2nd field<br>0 : 1st field                              |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| STS8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Start bit identification flag               | 1 : Start bit detection                                     |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |
| STDE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 16 bit data receive end identification flag | 1 : 16 bit data receive end                                 |           |       |       |       |       |          |          |                |                |       |                        |                                                             |           |           |               |  |       |                      |                                |      |                               |                         |      |                                             |                             |

Figure 2-92-2. SIF Data Register, SIF Status Register

Slicer mode setting register 1 (Initial value : 0001 1011)

SIFSMS1 (0FA0H)

| 7   | 6       | 5      | 4   | 3      | 2      | 1      | 0      |
|-----|---------|--------|-----|--------|--------|--------|--------|
| "0" | SYNCINV | EXSYNC | "1" | CLINE3 | CLINE2 | CLINE1 | CLINE0 |

  

| Bit name | Function                            | Bit definition                                                                                                                                                                                                                                                                               |            |
|----------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| SYNCINV  |                                     | 0 : Non-invert external <u>C.Sync</u> signal<br>1 : Invert external <u>C.Sync</u> signal                                                                                                                                                                                                     |            |
| EXSYNC   |                                     | 0 : Internally Synchronous separator mode<br>1 : External <u>C.Sync</u> signal mode                                                                                                                                                                                                          |            |
| CLINE    | Setting lines piled on caption data | 0000 : 10 line<br>0001 : 11 line<br>0010 : 12 line<br>0011 : 13 line<br>0100 : 14 line<br>0101 : 15 line<br>0110 : 16 line<br>0111 : 17 line<br>1000 : 18 line<br>1001 : 19 line<br>1010 : 20 line<br>1011 : 21 line<br>1100 : 22 line<br>1101 : 23 line<br>1110 : 24 line<br>1111 : 25 line | write only |

Figure 2-92-3. Slicer Mode Setting Register

Slicer status read register 2

| SIFS1R<br>(0FA0H) |                                                                 | 7                                                                      | 6 | 5     | 4      | 3      | 2      | 1      | 0      |           |
|-------------------|-----------------------------------------------------------------|------------------------------------------------------------------------|---|-------|--------|--------|--------|--------|--------|-----------|
| GOODV             |                                                                 |                                                                        |   | GOODV | FLINE4 | FLINE3 | FLINE2 | FLINE1 | FLINE0 |           |
|                   |                                                                 |                                                                        |   |       |        |        |        |        |        |           |
| Bit name          | Function                                                        | Bit definition                                                         |   |       |        |        |        |        |        |           |
| GOODV             |                                                                 | 0 : out of synchronization (one or more)<br>1 : V timing synchronizing |   |       |        |        |        |        |        |           |
| FLINE             | Field scanning line<br>(standard 262.5 = -1)<br>twos complement | 00000 : 0 263.5                                                        |   |       |        |        |        |        |        | read only |
|                   |                                                                 | 00001 : 1 264.5                                                        |   |       |        |        |        |        |        |           |
|                   |                                                                 | 00010 : 2                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 00011 : 3                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 00100 : 4                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 00101 : 5                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 00110 : 6                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 00111 : 7                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01000 : 8                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01001 : 9                                                              |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01010 : 10                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01011 : 11                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01100 : 12                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01101 : 13                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01110 : 14                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 01111 : 15 278.5                                                       |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10000 : V synchronizing adjustment                                     |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10001 : -15 248.5                                                      |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10010 : -14                                                            |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10011 : -13                                                            |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10100 : -12                                                            |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10101 : -11                                                            |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10110 : -10                                                            |   |       |        |        |        |        |        |           |
|                   |                                                                 | 10111 : -9                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11000 : -8                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11001 : -7                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11010 : -6                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11011 : -5                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11100 : -4                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11101 : -3                                                             |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11110 : -2 261.5                                                       |   |       |        |        |        |        |        |           |
|                   |                                                                 | 11111 : -1 262.5                                                       |   |       |        |        |        |        |        |           |

Figure 2-92-4. Slicer Status Read Register

Caption data slice level control register (Initial value : \*\*00 1010)



| Bit name | Function                                                   | Bit definition                                                                                                                                                                                                                                                                   |       |
|----------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| SLVL     | Slice level (Initial value) setting<br>Slice level setting | 00000 : VPCLAMP + (1/256) VDD<br>00001 : VPCLAMP + (2/256) VDD<br>00010 : VPCLAMP + (3/256) VDD<br>00011 : VPCLAMP + (4/256) VDD<br>00100 : VPCLAMP + (5/256) VDD<br>.....<br>11101 : VPCLAMP + (62/256) VDD<br>11110 : VPCLAMP + (63/256) VDD<br>11111 : VPCLAMP + (64/256) VDD | write |
| SLVL     | Slice level (Final value)                                  |                                                                                                                                                                                                                                                                                  | read  |

\* VPCLAMP (Pedestal clamp) = (1/2) VDD

Sync-chip slice level setting register (Initial value : 0011 0110)



| Bit name | Function                                                                                     | Bit definition                                                                                                                                                                                                                                   |            |
|----------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| DACL     | DACL7 to 4 : Slice level Lower limit setting<br>DACL3 to 0 : Slice level Upper limit setting | 00000 : VSCLAMP + (3/512) VDD<br>00001 : VSCLAMP + (6/512) VDD<br>00010 : VSCLAMP + (9/512) VDD<br>00011 : VSCLAMP + (12/512) VDD<br>.....<br>11101 : VSCLAMP + (42/512) VDD<br>11110 : VSCLAMP + (45/512) VDD<br>11111 : VSCLAMP + (48/512) VDD | write only |

\* VSCLAMP (Sync-chip clamp) = (204/512) VDD

Figure 2-92-5. Caption Data Slice Level Control Register, Sync-chip Slice Level Setting Register

## 2.15.5 Clamp and Data slicer

The slicer fetches caption signal in the following sequence.



The data slicer has two separators as follows.

- Synchronous signal (sync chip clamp + synchronous signal slice) separation
- Caption data (pedestal clamp + data slice) separation

The following explains the overviews of the separators.

## a. synchronous signal (sync-chip clamp + synchronous signal slice)

a-1. Sync-chip clamp (pin 40) : sync-chip clamped at (204/512) VDD [V] shown as Figure 2-93.



Figure 2-93. Synchronous Signal Slice

## a-2. Synchronous signal slice method

The synchronous signal is separated as Figure 2-93.

The synchronous signal is separated with comparing the voltage of the sync-chip clamped video signal and the sync-chip slice level. When the video signal changes from 1 to 2 and the synchronous signal is "H" after separation, A is selected as a slice level. When the synchronous signal is "L", B is selected.

(Sync-chip slice level)

$$\text{Slice level} = \text{VSCLAMP} + \{ (3 + 3X) / 512 \} \text{ VDD}$$

VDD : Supply voltage

VSCLAMP : Sync-chip clamp = (204 / 512) VDD

X : Specified data (4 bits)

b. Caption data (pedestal clamp + data slice)

b-1. Pedestal clamp (41 PIN) : clamped (1/2) VDD [V] shown as Figure 2-94.



Figure 2-94. Pedestal Clamp

b-2. Data slice method

The data slice level is a standard level to output CCD data.

The specified value of the slice level is shown as follows.

$$\text{Slice level} = \text{VPCLAMP} + (X / 256) \text{ VDD [V]}$$

VDD : Supply voltage

VPCLAMP : Pedestal clamp = (1 / 2) VDD

X : Specified data (6 bits)

b-3. Automatic slice level correct circuit

This circuit corrects the slice level within CRI.

The correct of the slice level is always started from the specified value of SLVL (bits 5 to 0 in SLVCR).

When a final value is an initial value of the next slice level, set the value to SLVL (bits 5 to 0 in SLVLCR).

## 2.16 TEST Video signal output for adjusting TV screen

TMP87CH34B/K34B/M34B have a built-in video signal output circuit to output necessary signal for TV screen adjustment.

Mode : NTSC

Picture pattern : Total eight types, Monochromatic inversion possible

Output format : Three states (H, L, Hi-Z) output

Comp.Sync duration time L output

Black level / Pedestal duration time Hi-Z output

White level duration time H output

### 2.16.1 Configuration



Figure 2-95. TEST Video Signal Output Circuit

## 2.16.2 Control

The TEST video signal output circuit can be controlled with the signal control register.

| TEST video signal control register |                                 |                                                                                                                                                                                                                                 |         |   |   |         |            |        |
|------------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---|---|---------|------------|--------|
| TVSCR<br>(0FA1H)                   | 7                               | 6                                                                                                                                                                                                                               | 5       | 4 | 3 | 2       | 1          | 0      |
|                                    | *                               | CSOUTM3                                                                                                                                                                                                                         | OSOUTM2 | * | * | CSOUTM1 | CSOUTM0    | HVFREE |
| Bit name                           | Function                        | Bit definition                                                                                                                                                                                                                  |         |   |   |         |            |        |
| CSOUTM3                            | Pattern monochromatic inversion | 0 : No Inversion<br>1 : Inversion                                                                                                                                                                                               |         |   |   |         |            |        |
| CSOUTM2 to 0                       | Display pattern                 | 000 : White on the whole screen<br>001 : Horizontal hatch<br>010 : Vertical hatch<br>011 : Cross hatch<br>100 : White on the upper side /<br>Black on the lower side<br>101 : Cross bar<br>110 : Dot<br>111 : Cross dot pattern |         |   |   |         | write only |        |
| HVFREE                             | TEST video signal mode          | 0 : disable<br>1 : enable                                                                                                                                                                                                       |         |   |   |         |            |        |

*Note : \* ; don't care*

Figure 2-96. TEST Video Signal Control Register

### 2.16.3 Functions

Test video signal output is to generate monochromatic video signal output to take easily the necessary tests such as TV screen white adjustment and screen distortion/amplitude adjustment implemented on the final manufacturing process of a TV receiver set.

| Display pattern                                            | TV screen                                                                            |
|------------------------------------------------------------|--------------------------------------------------------------------------------------|
| 000<br>(White on the whole screen)                         |    |
| 001<br>(Horizontal hatch)                                  |    |
| 010<br>(Vertical hatch)                                    |    |
| 011<br>(Cross hatch)                                       |   |
| 100<br>(White on the upper side / Black on the lower side) |  |
| 101<br>(Cross bar)                                         |  |
| 110<br>(Dot)                                               |  |
| 111<br>(Cross dot pattern)                                 |  |

Figure 2-97. Display Pattern and TV Screen (When CSOUTM3 is "0")

It is necessary to connect with the external circuit of the resistance divived voltage for generation of video signal becaus this port is a tri-state port.



Figure 2-98. Example of Test Video Output Generation

## INPUT/OUTPUT CIRCUITRY

## (1) Control pins

The input/output circuitries of the 87CH34B/K34B/M34B control pins are shown below.

| CONTROL PIN        | I/O             | INPUT/OUTPUT CIRCUITRY                                                              | REMARKS                                                                                                                                   |
|--------------------|-----------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| XIN<br>XOUT        | Input<br>Output |    | Resonator connecting pins (high-frequency)<br>$R_f = 1.2 \text{ M}\Omega$ (typ.)<br>$R_O = 1.5 \text{ k}\Omega$ (typ.)                    |
| RESET              | I/O             |   | Sink open drain output<br>Hysteresis input<br>Pull-up resistor<br>$R_{IN} = 220 \text{ k}\Omega$ (typ.)<br>$R = 1 \text{ k}\Omega$ (typ.) |
| STOP/INT5<br>(P20) | Input           |   | Hysteresis input<br>$R = 1 \text{ k}\Omega$ (typ.)                                                                                        |
| TEST               | Input           |  | Pull-down resistor<br>$R_{IN} = 70 \text{ k}\Omega$ (typ.)<br>$R = 1 \text{ k}\Omega$ (typ.)                                              |
| OSC1<br>OSC2       | Input<br>Output |  | Osc. connecting pin for on-screen display<br>$R_f = 1.2 \text{ M}\Omega$ (typ.)<br>$R_O = 1.5 \text{ k}\Omega$ (typ.)                     |

## (2) Input/Output Ports

The input/output circuitries of the 87CH34B/K34B/M34B I/O ports are shown below.

| PORT             | I/O | INPUT/OUTPUT CIRCUITRY                                                                                | REMARKS                                                                                                            |
|------------------|-----|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| P20              | I/O | initial "Hi-Z"<br>   | Sink open drain output<br>$R = 1 \text{ k}\Omega$ (typ.)                                                           |
| P3               | I/O | initial "Hi-Z"<br>   | Sink open drain output<br>Hysteresis input<br>$R = 1 \text{ k}\Omega$ (typ.)                                       |
| P4               | I/O | initial "Hi-Z"                                                                                        | Tri-state I/O                                                                                                      |
| P64<br>to<br>P67 | I/O |                     | $R = 1 \text{ k}\Omega$ (typ.)                                                                                     |
| P50<br>to<br>P53 | I/O | initial "Hi-Z"<br> | Sink open drain output<br>Hysteresis input<br>$R = 1 \text{ k}\Omega$ (typ.)                                       |
| P54<br>to<br>P57 | I/O | initial "Hi-Z"<br> | Tri-state I/O<br>Hysteresis input<br>$R = 1 \text{ k}\Omega$ (typ.)                                                |
| P60<br>to<br>P63 | I/O | initial "Hi-Z"<br> | Sink open drain output<br>High current output<br>$I_{OL} = 20 \text{ mA}$ (typ.)<br>$R = 1 \text{ k}\Omega$ (typ.) |
| P70<br>P71       | I/O | initial "Hi-Z"<br> | Sink open drain output<br>Hysteresis input<br>$R = 1 \text{ k}\Omega$ (typ.)                                       |

## ELECTRICAL CHARACTERISTICS

| ABSOLUTE MAXIMUM RATINGS         |                   | $(V_{SS} = 0 \text{ V})$             |                         |      |
|----------------------------------|-------------------|--------------------------------------|-------------------------|------|
| PARAMETER                        | SYMBOL            | CONDITION                            | RATINGS                 | UNIT |
| Supply Voltage                   | $V_{DD}$          |                                      | - 0.3 to 6.5            | V    |
| Input Voltage                    | $V_{IN}$          |                                      | - 0.3 to $V_{DD} + 0.3$ | V    |
| Output Voltage                   | $V_{OUT1}$        |                                      | - 0.3 to $V_{DD} + 0.3$ | V    |
| Output Current (Per 1 pin)       | $I_{OUT1}$        | Ports P2, P3, P4, P5, P64 to P67, P7 | 3.2                     | mA   |
|                                  | $I_{OUT2}$        | Ports P60 to P63                     | 30                      |      |
| Output Current (Total)           | $\Sigma I_{OUT1}$ | Ports P2, P3, P4, P5, P64 to P67, P7 | 120                     | mA   |
|                                  | $\Sigma I_{OUT2}$ | Ports P60 to P63                     | 120                     |      |
| Power Dissipation [Topr = 70 °C] | PD                |                                      | 600                     | mW   |
| Soldering Temperature (time)     | Tsld              |                                      | 260 (10 s)              | °C   |
| Storage Temperature              | Tstg              |                                      | - 55 to 125             | °C   |
| Operating Temperature            | Topr              |                                      | - 30 to 70              | °C   |

| RECOMMENDED OPERATING CONDITIONS $(V_{SS} = 0 \text{ V}, \text{Topr} = - 30 \text{ to } 70 \text{ °C})$ |           |                         |                                                                             |                      |                                         |      |
|---------------------------------------------------------------------------------------------------------|-----------|-------------------------|-----------------------------------------------------------------------------|----------------------|-----------------------------------------|------|
| PARAMETER                                                                                               | SYMBOL    | PINS                    | CONDITIONS                                                                  | Min.                 | Max.                                    | UNIT |
| Supply Voltage                                                                                          | $V_{DD}$  |                         | $f_c = 8 \text{ MHz}$                                                       | $V_{DD}$ NORMAL mode | 4.5                                     | V    |
|                                                                                                         |           |                         |                                                                             | IDLE mode            |                                         |      |
|                                                                                                         |           |                         |                                                                             | STOP mode            | 2.0                                     |      |
| Input High Voltage                                                                                      | $V_{IH1}$ | Except hysteresis input | $V_{DD} \geq 4.5 \text{ V}$                                                 | $V_{DD} \times 0.70$ | $V_{DD}$                                | V    |
|                                                                                                         | $V_{IH2}$ | Hysteresis input        |                                                                             | $V_{DD} \times 0.75$ |                                         |      |
|                                                                                                         | $V_{IH3}$ |                         | $V_{DD} < 4.5 \text{ V}$                                                    | $V_{DD} \times 0.90$ |                                         |      |
| Input Low Voltage                                                                                       | $V_{IL1}$ | Except hysteresis input | $V_{DD} \geq 4.5 \text{ V}$                                                 | 0                    | $V_{DD} \times 0.30$                    | V    |
|                                                                                                         | $V_{IL2}$ | Hysteresis input        |                                                                             |                      | $V_{DD} \times 0.25$                    |      |
|                                                                                                         | $V_{IL3}$ |                         | $V_{DD} < 4.5 \text{ V}$                                                    |                      | $V_{DD} \times 0.10$                    |      |
| Clock Frequency                                                                                         | $f_c$     | XIN, XOUT               | $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$                                    | 4.0                  | 8.0                                     | MHz  |
|                                                                                                         | $f_{OSC}$ | OSC1, OSC2              | Double frequency mode (FORS = 1, $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$ ) | 2.0                  | $f_{OSC} \leq f_c \times 1.4 \leq 6.0$  |      |
|                                                                                                         |           |                         | Normal frequency mode (FORS = 0, $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$ ) | 4.0                  | $f_{OSC} \leq f_c \times 2.8 \leq 12.0$ |      |

Note1 : Clock Frequency  $f_c$  ; The condition of supply voltage range is the value in NORMAL and IDLE mode.

Note2 : When using test video signal circuit and data slicer circuit, high frequency must be 8 MHz.

## D.C. CHARACTERISTICS

(V<sub>SS</sub> = 0 V, T<sub>opr</sub> = -30 to 70 °C)

| PARAMETER                     | SYMBOL           | PINS                             | CONDITIONS                                                 | Min. | Typ. | Max. | UNIT |
|-------------------------------|------------------|----------------------------------|------------------------------------------------------------|------|------|------|------|
| Hysteresis Voltage            | V <sub>HS</sub>  | Hysteresis inputs                |                                                            | -    | 0.9  | -    | V    |
| Input Current                 | I <sub>IN1</sub> | TEST                             | V <sub>DD</sub> = 5.5 V, V <sub>IN</sub> = 5.5 V / 0 V     | -    | -    | ± 2  | μA   |
|                               | I <sub>IN2</sub> | Open drain ports                 | V <sub>DD</sub> = 5.5 V, V <sub>IN</sub> = 5.5 V           | -    | -    | 2    |      |
|                               | I <sub>IN3</sub> | Tri-state ports                  |                                                            |      |      | ± 2  |      |
|                               | I <sub>IN4</sub> | RESET, STOP                      | V <sub>DD</sub> = 5.5 V, V <sub>IN</sub> = 5.5 V / 0 V     | -    | -    | ± 2  |      |
| Input Resistance              | R <sub>IN2</sub> | RESET                            |                                                            | 100  | 220  | 450  | kΩ   |
| Output Leakage Current        | I <sub>LO1</sub> | Sink open drain ports            | V <sub>DD</sub> = 5.5 V, V <sub>OUT</sub> = 5.5 V          | -    | -    | 2    | μA   |
|                               | I <sub>LO2</sub> | Tri-state ports                  | V <sub>DD</sub> = 5.5 V, V <sub>OUT</sub> = 5.5 V / 0 V    | -    | -    | ± 2  |      |
| Output High Voltage           | V <sub>OH2</sub> | Tri-state ports                  | V <sub>DD</sub> = 4.5 V, I <sub>OH</sub> = -0.7 mA         | 4.1  | -    | -    | V    |
| Output Low Voltage            | V <sub>OL</sub>  | Except XOUT and ports P60 to P63 | V <sub>DD</sub> = 4.5 V, I <sub>OL</sub> = 1.6 mA          | -    | -    | 0.4  | V    |
| Output Low Current            | I <sub>OL3</sub> | Ports P60 to P63                 | V <sub>DD</sub> = 4.5 V, V <sub>OL</sub> = 1.0 V           | -    | 20   | -    | mA   |
| Supply Current in NORMAL mode | I <sub>DD</sub>  |                                  | V <sub>DD</sub> = 5.5 V                                    | -    | 15   | 25   | mA   |
| Supply Current in IDLE mode   |                  |                                  | f <sub>C</sub> = 8 MHz<br>V <sub>IN</sub> = 5.3 V / 0.2 V  | -    | 10   | 18   | mA   |
| Supply Current in STOP mode   |                  |                                  | V <sub>DD</sub> = 5.5 V<br>V <sub>IN</sub> = 5.3 V / 0.2 V | -    | 0.5  | 10   | μA   |

Note 1 : Typical values show those at T<sub>opr</sub> = 25 °C, V<sub>DD</sub> = 5 V.Note 2 : Input Current I<sub>IN1</sub> I<sub>IN4</sub> ; The current through pull-up or pull-down resistor is not included.

Note 3 : Typical current consumption during A/D conversion is 1.2 mA.

## A/D CONVERSION CHARACTERISTICS

(V<sub>SS</sub> = 0 V, V<sub>DD</sub> = 4.5 to 5.5 V, T<sub>opr</sub> = -30 to 70 °C)

| PARAMETER                  | SYMBOL           | PINS         | CONDITIONS              | Min.            | Typ. | Max.            | UNIT |
|----------------------------|------------------|--------------|-------------------------|-----------------|------|-----------------|------|
| Analog Input Voltage Range | V <sub>A1N</sub> | CIN3 to CIN0 |                         | V <sub>SS</sub> | -    | V <sub>DD</sub> | V    |
| Conversion Error           |                  |              | V <sub>DD</sub> = 5.0 V | -               | -    | ± 1.5           | LSB  |

## A.C. CHARACTERISTICS

(V<sub>SS</sub> = 0 V, V<sub>DD</sub> = 4.5 to 5.5 V, T<sub>opr</sub> = -30 to 70 °C)

| PARAMETER                    | SYMBOL           | CONDITIONS                                                          | Min. | Typ. | Max. | UNIT |
|------------------------------|------------------|---------------------------------------------------------------------|------|------|------|------|
| Machine Cycle Time           | t <sub>cy</sub>  | In NORMAL mode                                                      | 0.5  | -    | 1.0  | μs   |
|                              |                  | In IDLE mode                                                        |      |      |      |      |
| High-Level Clock Pulse Width | t <sub>WCH</sub> | For external clock operation<br>(XIN input), f <sub>c</sub> = 8 MHz | 62.5 | -    | -    | ns   |
|                              |                  |                                                                     |      |      |      |      |

## RECOMMENDED OSCILLATING CONDITION

(V<sub>SS</sub> = 0 V, V<sub>DD</sub> = 4.5 to 5.5 V, T<sub>opr</sub> = -30 to 70 °C)

| PARAMETER                     | OSCILLATOR         | FREQUENCY | RECOMMENDED<br>OSCILLATOR            | RECOMMENDED<br>CONDITIONS |                |
|-------------------------------|--------------------|-----------|--------------------------------------|---------------------------|----------------|
|                               |                    |           |                                      | C <sub>1</sub>            | C <sub>2</sub> |
| High-frequency<br>Oscillation | Ceramic Resonator  | 8 MHz     | KYOCERA KBR8.0M                      | 30 pF                     | 30 pF          |
|                               |                    | 4 MHz     | KYOCERA KBR4.0MS<br>MURATA CSA4.00MG |                           |                |
|                               | Crystal Oscillator | 8 MHz     | TOYOCOM 210B 8.0000                  | 20 pF                     | 20 pF          |
|                               |                    | 4 MHz     | TOYOCOM 204B 4.0000                  |                           |                |
| OSD                           | LC Resonator       | 6 MHz     | TOKO A285HCIS-13319                  | -                         | -              |
|                               |                    | 12 MHz    | TOKO TA285HCIS-13306                 |                           |                |



Note : To keep reliable operation, shield the device electrically with the metal plate on its package mold surface against the high electric field, for example, by CRT (Cathode Ray Tube).

