# CMOS 8-Bit Microcontroller TMP88CS38NG/FG, TMP88CM38ANG/F, TMP88CP38ANG/F The TMP88CS38/CM38A/CP38A is the high speed and high performance 8-bit single chip microcomputers. This MCU contain CPU core, ROM, RAM, input/output ports, four multi-function timer/counters, serial bus interface, on-screen display, PWM output, 8-bit AD converter, and remote control signal preprocessor on chip. | Product No. | ROM | RAM | Package | OTP MCU | |----------------|---------------|----------------|-----------------------------------------|----------------| | TMP88CS38NG/FG | 64 K × 8 bits | 2 K × 8 bits | D CDID42 600 4 79 | TMP88PS38NG/FG | | TMP88CM38ANG/F | 32 K × 8 bits | 1.5 K × 8 bits | P-SDIP42-600-1.78<br>P-QFP44-1414-0.80K | | | TMP88CP38ANG/F | 48 K × 8 bits | 1.5 K × 0 DIIS | F-QFF44-1414-0.00K | | #### **Features** - ♦ 8-bit single chip microcomputer TLCS-870/X series - ♦ Instruction execution time: 0.25 µs (at 16 MHz) - ♦ 842 basic instructions - Multiplication and division (8 bits × 8 bits, 16 bits × 8 bits, 16 bits/8 bits) - Bit manipulations (Set/clear/complement/move/test/exclusive or) - 16-bit data and 20-bit data operations - 1-byte jump/subroutine call (Short relative jump/vector call) - I/O ports: Maximum 33 (High current output: 4) - ♦ 17 interrupt sources: External 6, internal 11 - All sources have independent latches each, and nested interrupt control is available. - Edge-selectable external interrupts with noise reject - High-speed task switching by register bank changeover - ♦ ROM corrective function - ♦ Two 16-bit timer/counters: TC1, TC2 - Timer, event counter, pulse width measurement, external trigger timer, window modes 030619EBP1 - The information contained herein is subject to change without notice. - The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of TOSHIBA or others. TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general - TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property. - In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc. - The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunctionor failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. - The products described in this document are subject to the foreign exchange and foreign trade laws. - TOSHIBA products should not be embedded to the downstream products which are prohibited to be produced and sold, under any law and regulations. - For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions. 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. - ◆ Two 8-bit timer/counters: TC3, TC4 - Timer, event counter, capture (Pulse width/duty measurement) mode - ♦ Time base timer (Interrupt frequency: 0.95 Hz to 31250 Hz) - ♦ Watchdog timer - Interrupt sourse/reset output - ♦ Serial bus interface - I<sup>2</sup>C bus, 8-bit SIO mode (Selectable two I/O channels) - ♦ On-screen display circuit - Font ROM characters: 384 characters - Characters display: 32 columns × 12 lines - Composition: $16 \times 18$ dots - Size of character: 3 kinds (Line by line) - Color of character: 8 or 15 kinds (Character by character) - Variable display position: Horizontal 256 steps, vertical 512 steps - Fringing, smoothing, slant, underline, blinking function - ♦ Jitter elimination - ♦ Data slicer circuit 1 channel - ♦ DA conversion (Pulse width modulation) outputs - 14- or 12-bit resolution (2 channels) - 12-bit resolution (2 channels) - 7-bit resolution (6 channels) - ♦ 8-bit successive approximate type AD converter with sample and hold - Remote control signal preprocessor - ♦ Two power saving operating modes - STOP mode: Oscillation stops. Battery/capacitor backup. Port output hold/high impedance. - IDLE mode: CPU stops, and peripherals operate using high-frequency clock. Release by interrupts. - ♦ Operating voltage: 4.5 to 5.5 V at 16 MHz - ♦ Emulation POD: BM88CS38N0A-M15 # Pin Assignments # Pin Functions (1/2) | Pin Name | I/O | Function | | | |------------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--| | P20 (INT5 / STOP) | I/O (Input) | 1-bit input/output port with latch. When used as an input port, the latch must be set to "1". | External interrupt input 5 or STOP mode release signal input | | | P35 (SDA0) | I/O (Input/Output) | | I <sup>2</sup> C bus serial data input/output 0 | | | P34 (SCL0) | I/O (Input/Output) | 6-bit programmable input/output port. | I <sup>2</sup> C bus serial clock input/output 0 | | | P33 (TC4/VIN0) | I/O (Input) | Each bit of these ports can be individually configured as an input or | Timer counter input 4 or video signal Input 0 | | | P32 (VIN1/CSIN) | I/O (Input) | an output under software control. During reset, all bits are configured as | Video signal input 1 or composite sync input | | | P31 (INT4/TC3) | I/O (Input) | inputs. When used as a serial bus interface input/output, the latch must be set to "1". | External interrupt input 4 or timer counter input 3 | | | P30 (INT3/RXIN) | I/O (Input) | be set to 1. | External interrupt input 3 or remote control signal preprocessor input | | | P47 ( PWM7 ) | I/O (Output) | | | | | P46 ( PWM6 ) | I/O (Output) | 8-bit programmable input/output port. | 7-bit DA conversion (PWM) outputs | | | P45 ( PWM5 ) | I/O (Output) | Each bit of these ports can be | 7 bit bit conversion (1 vvvi) outputs | | | P44 ( PWM4 ) | I/O (Output) | individually configured as an input or an output under software control. | | | | P43 ( PWM3 ) | I/O (Output) | During reset, all bits are configured as | 12-bit DA conversion (PWM) outputs | | | P42 (PWM2) | I/O (Output) | inputs. When used as a PWM output, | 12 Sit Sit Convolcion (1 11m) caspate | | | P41 ( PWM1 ) | I/O (Output) | the latch must be set to "1". | 14/12-bit DA conversion (PWM) | | | P40 (PWM0) | I/O (Output) | | outputs | | | P57 (I) | I/O (Output) | | Translucent signal output | | | P56 ( KWU3 /AIN3) | I/O (Input) | | Key-on wakeup inputs or AD converter | | | P55 ( KWU2 /AIN2) | I/O (Input) | | analog inputs | | | P54 (KWU1/AIN1) | I/O (Input) | | | | | P53 ( KWU0 /AIN0/TC1 /INT2/ SCK1 ) | I/O (Input /Input/Input<br>/Input/Output) | 8-bit programmable input/output port. Each bit of these ports can be individually configured as an input or an output under software control. | Key-on wakeup input or AD converter<br>analog input or timer counter input 1 or<br>external interrupt input 2 or SIO serial<br>clock input/output 1 | | | P52 (SDA1/SO1) | I/O (Input/Output<br>/Output) | During reset, all bits are configured as inputs. When used as a PWM output, a serial bus interface input/output, the | I <sup>2</sup> C bus serial data input/output 1 or SIO serial data output 1 | | | P51 (PWM9 /SCL1/SI1) | I/O (Output/Input/Output<br>/Input) | latch must be set to "1". | 7-bit DA conversion (PWM) output or I <sup>2</sup> C bus serial data input/output 1 or SIO serial data input 1 | | | P50 (PWM8 /TC2/INT0) | I/O<br>(Output/Input /Input) | | 7-bit DA conversion (PWM) output or<br>timer counter input 2 or external<br>interrupt input 0 | | | P67 (Y/BL) | I/O (Output) | | Y or BL output | | | P66 (B) | I/O (Output) | 8-bit programmable input/output port. (P67 to P64: Tri-State, P63 to P60: | | | | P65 (G) | I/O (Output) | High current output) Each bit of these | R/G/B outputs | | | P64 (R) | I/O (Output) | ports can be individually configured as | | | | P63 (RIN) | I/O (Input) | an input or an output under software | R input | | | P62 (GIN/CSOUT) | I/O (Input/Output) | control. During reset, all bits are configured as inputs. When used P64 | G input or TEST video signal output | | | P61 (KWU5 /BIN/AIN5) | I/O (Input) | to P67 as port, each bit of the P6 port data selection register (Bit7 to 4 in | Key-on wakeup input 5 or B input or AD converter analog input 5 | | | P60<br>(KWU4/YBLIN/AIN4) | I/O (Input) | ORP6S) must be set to "1". | Key-on wakeup input 4 or Y/BL input or<br>AD converter analog input 4 | | # Pin Functions (2/2) | Pin Name | I/O | Function | | | | |----------------|---------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--| | P71 ( VD ) | I/O (Input) | 2-bit programmable input/output port. Each bit of these ports can be individually configured as an input or | | | | | P70 (HD) | I/O (Input) | an output under software control. During reset, all bits are configured as inputs. Horizontal synchronous signal input | | | | | XIN, XOUT | Input, Output | Resonator connecting pins. For inputting external clock, 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. | | | | | OVDD, OVSS | Power supply | +5 V, 0 V (GND) for OSD oscillator circuit. | | | | | VDD, VSS, VVSS | Power supply | +5 V, 0 V (GND) | | | | # **Block Diagram** # Operational Description # 1. CPU Core Functions The CPU core consists of a CPU, a system clock controller, and an interrupt controller. This section provides a description of the CPU core, the program memory, the data memory, the external memory interface, and the reset circuit. #### 1.1 Memory Address Map The TMP88CS38/CM38A/CP38A memory consists of four blocks: ROM, RAM, SFR (Special function register), and DBR (Data buffer register). They are all mapped to a 1-Mbyte address space. Figure 1.1.1 shows the TMP88CS38/CM38A/CP38A memory address map. There are 16 banks of the general-purpose register. The register banks are also assigned to the RAM address space. Figure 1.1.1 Memory Address Map # 1.2 Program Memory (ROM) The TMP88CS38 contains a 64-Kbyte program memory (Mask ROM) at addresses from 04000H to 13EFFH and FFF00H to FFFFFH. The TMP88CM38A contains a 32-Kbyte program memory (Mask ROM) at address from 04000H to 0BEFFH and FFF00H to FFFFFH. The TMP88CP38A contains a 48-Kbyte program memory (Mask ROM) at address from 04000H to 0FEFFH and FFF00H to FFFFFH. Addresses FFF00H through FFFFFH in the program memory are also used for a particular purpose. # 1.3 Data Memory (RAM) The TMP88CS38 has a 2-Kbyte data memory (Static RAM) address from 0040H to 08BFH. The TMP88CM38A/P38A has a 1.5-Kbyte data memory (Static RAM) (Address from 0040H to 06BFH. The first 128 bytes (Addresses 00040H through 000BFH) in the built-in RAM are also available as general-purpose register banks. 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 (TMP88CS38/CM38A/CP38A): HL, 0048H LD Sets start address to HL register pair LD Sets initial data (00H) to A register A, H LD BC, 0877H Sets number of byte to BC register pair SRAMCLR: LD (HL+), A DFC BC **JRS** F, SRAMCLR Note: 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 that the general-purpose registers are mapped in the RAM; therefore, do not clear RAM at the current bank addresses. #### 1.4 System Clock Controller The system clock controller consists of a clock generator, a timing generator, and a standby controller. Figure 1.4.1 System Clock Controller #### 1.4.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 oscillation circuit: one for the high-frequency clock. The high-frequency (fc) clock can be easily obtained by connecting a resonator between the XIN/XOUT pin, respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to the XIN/XTIN pin not connected. The TMP88CS38/CM38A/CP38A is not provided an LC oscillation. Figure 1.4.2 Examples of Resonator Connection Note: Accurate adjustment of the oscillation frequency: Although hardware to externally and directly monitor the basic clock pulse is not provided, the oscillation frequency can be adjusted by making the 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.4.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: - 1. Generation of main system clock - 2. Generation of source clocks for time base timer - 3. Generation of source clocks for watchdog timer - 4. Generation of internal source clocks for timer/counters TC1 to TC4 - 5. Generation of warm-up clocks for releasing STOP mode - 6. 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 3 prescaler, a main system clock generator, and machine cycle counters. During reset and at releasing STOP mode, the prescaler and the divider are cleared to "0", however, the prescaler is not cleared. An input clock to the 7th stage of the divider depends on the operating mode. A divided by 256 of high-frequency clock (fc/28) is input to the 7th stage of the divider. Figure 1.4.3 Configuration of Timing Generator Figure 1.4.4 Divider Control Register Figure 1.4.5 FC8 Control Register #### (2) Machine cycle Instruction execution and peripheral hardware operation are synchronized with the main system clock. The minimum instruction execution unit is called a "machine cycle". There are a total of 15 different types of instructions for the TLCS-870/X series: Ranging from 1-cycle instructions which require one machine cycle for execution to 15-cycle instructions which require 15 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.4.6 Machine Cycle #### 1.4.3 Standby Controller The standby controller starts and stops the switches the main system clock. These modes are controlled by the system control registers (SYSCR1, SYSCR2). Figure 1.4.7 shows the operating mode transition diagram and Figure 1.4.8 shows the system control registers. #### (1) Single-clock mode In the single-clock mode, the machine cycle time is 4/fc [s] (0.25 µs at fc = 16 MHz). #### 1. NORMAL mode In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock. #### 2. 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 (Operate using the high-frequency clock). IDLE mode is started by setting IDLE bit in the system control register 2 (SYSCR2), and IDLE1 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 instruction which follows IDLE mode start instruction. #### 3. 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. 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 warm-up period is completed, the execution resumes with the next instruction which follows the STOP mode start instruction. Figure 1.4.7 Operating Mode Transition Diagram Figure 1.4.8 System Control Registers #### 1.4.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 (Bit7 in SYSCR1) to "1". During STOP mode, the following status is maintained. - 1. Oscillations are turned off, and all internal operations are halted. - 2. The data memory, registers and port output latches are all held in the status in effect before STOP mode was entered. - 3. The prescaler and the divider of the timing generator are cleared to "0". - 4. The program counter holds the address of the instruction following the instruction which started the STOP mode. STOP mode includes a level-sensitive release mode and an edge-sensitive release mode, either of which can be selected with RELM (Bit6 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 backup when the main power supply is cut off and long term battery backup. 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 method can be used for confirmation: Using an external interrupt input $\overline{\text{INT5}}$ ( $\overline{\text{INT5}}$ is a falling edge-sensitive input). Example: Starting STOP mode with an INT5 interrupt. PINT5: **TEST** (P2).0To reject noise, the STOP mode does not start if port P20 is at high **JRS** F, SINT5 LD (SYSCR1), 01010000B Sets up the level-sensitive release mode SET (SYSCR1). 7 Starts STOP mode $IL_{12, 11, 7, 5, 3} \leftarrow 0$ (Clears interrupt latches) LDW (IL), 1110011101010111B SINT5: RETI Figure 1.4.9 Level-sensitive Release Mode b. Edge-sensitive release mode (RELM = 0) In this mode, STOP mode is released by a rising edge of the 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 STOP pin. In the edge-sensitive release mode, STOP mode is started even when the STOP pin input is high. Example: Starting STOP mode from NORMAL mode LD (SYSCR1), 10010000B ; Starts after specified to the edge-sensitive mode Figure 1.4.10 Edge-sensitive Release Mode STOP mode is released by the following sequence: - 1. When returning to NORMAL, clock oscillator is turned on. - 2. A warm-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Two different warm-up times can be selected with WUT (Bits2 and 3 in SYSCR1) as determined by the resonator characteristics. - 3. When the warm-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". | | Warm-up Time [ms] | | | | | |-----|-----------------------|-----------|-----------------------|-----------|--| | WUT | Return to NORMAL mode | | | | | | | DV1CK = 0 | | DV1CK = 1 | | | | 00 | $3 \times 2^{16}$ /fc | (12.29 m) | $3 \times 2^{17}$ /fc | (24.58 m) | | | 01 | 2 <sup>16</sup> /fc | (4.10 m) | 2 <sup>17</sup> /fc | (8.20 m) | | | 10 | $3 \times 2^{14}$ /fc | (3.07 m) | $3 \times 2^{15}$ /fc | (6.14 m) | | | 11 | 2 <sup>14</sup> /fc | (1.02 m) | 2 <sup>15</sup> /fc | (2.05 m) | | Table 1.4.1 Warm-up Time Example Note: The warm-up time is obtained by dividing the basic clock by the divider: therefore, the warm-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 warm-up time must be considered an approximate value. Figure 1.4.11 STOP Mode Start/Release 88CS38-16 2004-8-18 STOP mode can also be released by setting the $\overline{\text{RESET}}$ pin low, which immediately performs the normal reset operation. 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 STOP mode. The 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 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 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. - 1. Operation of the CPU and watchdog timer is halted. On-chip peripherals continue to operate. - 2. The data memory, CPU registers and port output latches are all held in the status in effect before IDLE mode was entered. - 3. The program counter holds the address of the instruction following the instruction which started IDLE mode. Example: Starting IDLE mode. $SET \quad (SYSCR2). \ 4 \qquad ; \quad IDLE \leftarrow 1$ Figure 1.4.12 IDLE Mode 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 from IDLE to NORMAL. a. Normal release mode (IMF = "0") IDLE mode is released by any interrupt source enabled by the individual interrupt enable flag (EF) or an external interrupt 0 ( $\overline{\text{INT0}}$ pin) request. 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) or an external interrupt 0 (INTO pin) request. After the interrupt is processed, the execution resumes from the instruction following the instruction which started IDLE mode. Note: When a watchdog timer interrupt is generated immediately before the IDLE mode is started, the watchdog timer interrupt will be processed but IDLE mode will not be started. Figure 1.4.13 IDLE Mode Start/Release IDLE mode can also be released by setting the $\overline{\rm RESET}$ pin low, which immediately performs the reset operation. After reset, the TMP88CS38/CM38A/CP38A is placed in NORMAL mode. # 1.5 Interrupt Controller The TMP88CS38/CM38A/CP38A has a total of 17 interrupt sources; 6 externals and 11 internals. Multiple interrupts with priorities are also possible. Two of the internal sources are pseudo non-maskable interrupts; the remainder are all maskable interrupts. Table 1.5.1 Interrupt Sources | Interrupt Source | | | Enable Condition | Interrupt<br>Latch | Vector Table<br>Address | Priority | |-----------------------|---------|-----------------------------|-------------------------------------|--------------------|-------------------------|----------| | Internal/E<br>xternal | (Reset) | | Non maskable | ı | FFFFCH | High 0 | | Internal | INTSW | (Software interrupt) | Decude non meekeble | _ | FFFF8H | 1 | | Internal | INTWDT | (Watchdog timer interrupt) | Pseudo non maskable | IL <sub>2</sub> | FFFF4H | 2 | | External | INT0 | (External interrupt 0) | $IMF \cdot EF_3 = 1$ , $INT0EN = 1$ | IL <sub>3</sub> | FFFF0H | 3 | | Internal | INTTC1 | (16-bit TC1 interrupt) | IMF ⋅EF <sub>4</sub> = 1 | IL <sub>4</sub> | FFFECH | 4 | | External | INTKWU | (Key-on wakeup) | IMF ⋅EF <sub>5</sub> = 1 | IL <sub>5</sub> | FFFE8H | 5 | | Internal | INTTBT | (Time base timer interrupt) | IMF ·EF <sub>6</sub> = 1 | IL <sub>6</sub> | FFFE4H | 6 | | External | INT2 | (External interrupt 2) | IMF ⋅EF <sub>7</sub> = 1 | IL <sub>7</sub> | FFFE0H | 7 | | Internal | INTTC3 | (8-bit TC3 interrupt) | IMF ⋅EF <sub>8</sub> = 1 | IL <sub>8</sub> | FFFDCH | 8 | | Internal | INTTSBI | (SBI interrupt) | IMF ⋅EF <sub>9</sub> = 1 | IL <sub>9</sub> | FFFD8H | 9 | | Internal | INTTC4 | (8-bit TC4 interrupt) | IMF ⋅EF <sub>10</sub> = 1 | IL <sub>10</sub> | FFFD4H | 10 | | External | INT3 | (External interrupt 3) | IMF ⋅EF <sub>11</sub> = 1 | IL <sub>11</sub> | FFFD0H | 11 | | External | INT4 | (External interrupt 4) | IMF ⋅EF <sub>12</sub> = 1 | IL <sub>12</sub> | FFFCCH | 12 | | Internal | INTADC | (AD converter interrupt) | IMF ⋅EF <sub>13</sub> = 1 | IL <sub>13</sub> | FFFC8H | 13 | | Internal | INTTC2 | (16-bit TC2 interrupt) | IMF ⋅EF <sub>14</sub> = 1 | IL <sub>14</sub> | FFFC4H | 14 | | External | INT5 | (External interrupt 5) | IMF ⋅EF <sub>15</sub> = 1 | IL <sub>15</sub> | FFFC0H | 15 | | Internal | INTOSD | (OSD interrupt) | IMF ⋅EF <sub>16</sub> = 1 | IL <sub>16</sub> | FFFBCH | 16 | | Internal | INTSLI | (Slicer interrupt) | IMF ⋅EF <sub>17</sub> = 1 | IL <sub>17</sub> | FFFB8H | 17 | | | | Reserved | IMF ⋅EF <sub>18</sub> = 1 | IL <sub>18</sub> | FFFB4H | 18 | | | | Reserved | IMF ⋅EF <sub>19</sub> = 1 | IL <sub>19</sub> | FFFB0H | 19 | | | | Reserved | IMF ⋅EF <sub>20</sub> = 1 | IL <sub>20</sub> | FFFACH | 20 | | | | Reserved | IMF ⋅EF <sub>21</sub> = 1 | IL <sub>21</sub> | FFFA8H | 21 | | | | Reserved | IMF ⋅EF <sub>22</sub> = 1 | IL <sub>22</sub> | FFFA4H | 22 | | | | Reserved | IMF ⋅EF <sub>23</sub> = 1 | IL <sub>23</sub> | FFFA0H | 23 | | | | Reserved | IMF ⋅EF <sub>24</sub> = 1 | IL <sub>24</sub> | FFF9CH | 24 | | | | Reserved | IMF ⋅EF <sub>25</sub> = 1 | IL <sub>25</sub> | FFF98H | 25 | | | | Reserved | IMF ·EF <sub>26</sub> = 1 | IL <sub>26</sub> | FFF94H | 26 | | | | Reserved | IMF ⋅EF <sub>27</sub> = 1 | IL <sub>27</sub> | FFF90H | 27 | | | | Reserved | IMF ⋅EF <sub>28</sub> = 1 | IL <sub>28</sub> | FFF8CH | 28 | | | | Reserved | IMF ⋅EF <sub>29</sub> = 1 | IL <sub>29</sub> | FFF88H | 29 | | | | Reserved | IMF ⋅EF <sub>30</sub> = 1 | IL <sub>30</sub> | FFF84H | 30 | | | | Reserved | IMF ⋅EF <sub>31</sub> = 1 | IL <sub>31</sub> | FFF80H | Low 31 | Note: Before you change each enable flag (EF) and/or each interrupt latch (IL), be sure to clear the interrupt master enable flag (IMF) to "0" (to disable interrupts). If the individual enable flags (EF) and interrupt latches (IL) are set under conditions other than the above, the proper operation cannot be guaranteed. a. After a DI instruction is executed. b. When an interrupt is accepted, IMF is automatically cleared to "0". However to enable nested interrupts, change EF and/or IL before setting IMF to "1" (to enable interrupts). Figure 1.5.1 Interrupt Controller Block Diagram 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 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.5.1 shows the interrupt controller. #### (1) Interrupt latches (IL<sub>31</sub> to IL<sub>2</sub>) 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 0003CH, 0003DH, 0002EH and 0002FH in the SFR. Except for IL2, 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. When interrupt occurred during order execution, the reason is because interrupt request is cleared. Thus, interrupt requests can be canceled and initialized by the program. Note that request the interrupt latches cannot be set to "1" by an instruction. For example, it may be that each latch is cleared even if an interrupt request is generated during instruction exection. The contents of interrupt latches can be read out by an instruction. Therefore, testing interrupt request by software is possible. #### Example 1: Clears interrupt latches DI ; Disable interrupt LDW (ILL), 1110100000111111B ; $IL_{12}$ , $IL_{10}$ to $IL_{6} \leftarrow 0$ Example 2: Reads interrupt latches LD WA, (ILL) ; $W \leftarrow ILH$ , $A \leftarrow ILL$ Example 3: Tests an interrupt latch TEST (ILL). 7 ; if $IL_7 = 1$ then jump JR F, SSET #### (2) Interrupt enable register (EIR) The interrupt enable register (EIR) enables and disables 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 interrupt cannot be nested more than once at the same time. The EIR consists of an interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). These registers are assigned to addresses 0003AH, 0003BH, 0002CH and 0002DH in the SFR, and can be read and written by an instruction (including read-modify-write instruction such as bit manipulation instructions). Note: Do not use the read-modify-write instruction for the EIRL (Address 0003AH) during pseudo non-maskable interrupt service task. If the read-modify-write instruction is used, the IMF is not set to "1" after RETN. #### 1. Interrupt master enable flag (IMF) The interrupt master enable flag (IMF) enables and disables the acceptance of all maskable interrupts. Clearing this flag to "0" disables the 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 other 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 bit0 at address 0003AH 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. #### 2. Individual interrupt enable flags (EF<sub>17</sub> to EF<sub>3</sub>) These flags enable and disable the acceptance of individual maskable interrupts, except for an external interrupt 0. 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". ``` DI ; Disable interrupt LD (EIRE), 00000001B ; $EF_{16} \leftarrow 1$ LDW (EIRL), 1110100010100001B EF<sub>15</sub> to EF<sub>13</sub>, EF<sub>11</sub>, EF<sub>7</sub>, EF<sub>5</sub>, IMF $\leftarrow$ 1 Example 2: Sets an individual interrupt enable flag to "1". SET (EIRH). 4 ; $EF_{12} \leftarrow 1$ Figure 1.5.2 Interrupt Latches (IL) and Interrupt Enable Registers (EIR) #### 1.5.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 12 machine cycles (3 $\mu$ s at fc = 16 MHz in the 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). Figure 1.5.3 shows the timing chart of interrupt acceptance processing. #### (1) Interrupt acceptance Interrupt acceptance processing is as follows. - 1. 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. - 2. The interrupt latch (IL) for the interrupt source accepted is cleared to "0". - 3. The contents of the program counter (PC) and the program status word (PSW) are saved (Pushed) on the stack in sequence of PSWH, PSWL, PCE, PCH, PCL. The stack pointer (SP) is decremented five times. - 4. The entry address of the interrupt service program is read from the vector table, and set to the program counter. - 5. The RBS control code is read from the vector table. The lower 4-bit of this code is added to the RBS. - 6. The instruction stored at the entry address of the interrupt service program is executed. 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 the maskable interrupt higher than the level of current servicing interrupt is occurred. 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. Note: Do not use the read-modify-write instruction for the EIRL (Address 0003AH) during pseudo non-maskable interrupt service task. Figure 1.5.3 Timing Chart of Interrupt Acceptance and Interrupt Return Instruction #### (2) Saving/restoring general-purpose registers During interrupt acceptance processing, the program counter (PC) and the program status word (PSW) 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. # 1. General-purpose register save/restore by automatic register bank changeover The general-purpose registers can be saved at high speed by switching to a register bank that is not in use. Normally, the bank0 is used for the main task and the 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. #### 2. General-purpose register save/restore by register bank changeover The general-purpose registers can be saved at high speed by switching to a register bank that is not in use. Normally, the bank0 is used for the main tank and the banks 1 to 15 are assigned to interrupt service tasks. Figure 1.5.4 Saving/Restoring General-purpose Registers 3. General-purpose registers 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 the push/pop instructions. Example: Register save/restore using push and pop instructions PINTxx: PUSH WA ; Save WA register pair Interrupt processing POP WA ; Restore WA register pair RETI ; Return 4. General-purpose registers save/restore using data transfer instructions Data transfer instruction can be used to save only a specific general-purpose register during processing of 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) Interrupt return The interrupt return instructions [RETI]/[RETN] perform the following operations. | [RETI] Maskable Interrupt Return | [RETN] Non-maskable Interrupt Return | | | |----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | The contents of the program counter an<br>the program status word are restored<br>from the stack. | The contents of the program counter and program status word are restored from the stack. | | | | 2. The stack pointer is incremented 5 time | 2. The stack pointer is incremented 5 times. | | | | 3. The interrupt master enable flag is set t "1". | 3. 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. | | | | <ol> <li>The interrupt nesting counter is<br/>decremented, and the interrupt nesting<br/>flag is changed.</li> </ol> | The interrupt nesting counter is decremented, and the interrupt nesting flag is changed. | | | 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.5.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. Use the [SWI] instruction only for detection of the address error or for debugging. #### 1. Address error detection FFH is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address. Code FFH 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 FFH to unused areas of the program memory. Address-trap reset is generated in case that an instruction is fetched from RAM, SFR or DBR areas. #### 2. Debugging Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address. #### 1.5.3 External Interrupts The TMP88CS38/CM38A/CP38A each have five external interrupt inputs ( $\overline{\text{INT0}}$ , INT2, INT3, INT4, and $\overline{\text{INT5}}$ ). Three of these are equipped with digital noise rejection circuits (Pulse inputs of less than a certain time are eliminated as noise). Edge selection is also possible with INT2, INT3 and INT4. The INTO /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 rejection control except INT3 pin input and $\overline{\text{INT0}}$ /P50 pin function selection are performed by the external interrupt control register (EINTCR). Edge selecting and noise rejection control for INT3 pin input are preformed by the remote control signal preprocessor control registers. (Refer to the section of the remote control signal preprocessor.) When INT0EN = 0, the IL3 will not be set even if the falling edge of $\overline{\text{INT0}}$ pin input is detected. Table 1.5.2 External Interrupts | Source | Pin | Secondary<br>Function Pin | Enable Conditions | Edge | Digital Noise Rejection | |--------|------|------------------------------|------------------------------------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------| | INTO | ĪNT0 | P50/TC2/ PWM8 | IMF = 1, INT0EN = 1, EF <sub>3</sub> = 1 | Falling edge | Any pulse shorter than 2/fc [s] is regarded as noise and removed. Pulses not shorter than 7/fc [s] are definitely regarded as signals. | | INT2 | INT2 | P53/TC1/ SCK1/<br>AIN0/ KWU0 | IMF-EF <sub>7</sub> = 1 | Falling edge or rising edge | Pulses of less than 7/fc [s] are<br>eliminated as noise. Pulses<br>equal to or more than 25/fc [s]<br>are regarded as signals. | | INT3 | INT3 | P30/RXIN | IMF-EF <sub>11</sub> = 1 | Falling edge,<br>rising edge or<br>falling/rising edge | Refer to the section of the remote control preprocessor | | INT4 | INT4 | P31/TC3 | IMF-EF <sub>12</sub> = 1 | Falling edge or rising edge | Pulses of less than 7/fc [s] are<br>eliminated as noise. Pulses of<br>25/fc [s] or more are<br>considered to be signals. | | INT5 | ĪNT5 | P20/ STOP | IMF-EF <sub>15</sub> = 1 | Falling edge | Any pulse shorter than 2/fc [s] is regarded as noise and removed. Pulses not shorter than 7/fc [s] are definitely regarded as signals. | - Note 1: The noise rejection function is also affected for timer counter input 1 (TC1 pin). - Note 2: 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: - (1) INT2, INT4 pin 31/fc [s] - (2) INT3 pin Refer to the section of the remote control preprocessor. - Note 3: If a dual-function pin is used as an output port, changing data or switching between input and output generates a pseudo interrupt request signal. To ignore this signal, it is necessary to reset the interrupt enable flag. - Note 4: If INT0EN = "0", detecting the falling edge of the $\overline{\text{INT0}}$ pin input does not set the interrupt latch IL3. Figure 1.5.5 External Interrupt Control Register #### 1.6 Reset Circuit The TMP88CS38/CM38A/CP38A has four types of reset generation procedures: an external reset input, an address trap reset output, a watchdog timer reset output and a system clock reset output. Table 1.6.1 shows on-chip hardware initialization by reset action. The malfunction reset output circuit such as watchdog timer reset, address trap reset and system clock reset is not initialized when power is turned on. The $\overline{\text{RESET}}$ pin can output level "L" at the maximum 24/fc [s] (1.5 $\mu$ s at 16 MHz) when power is turned on. | On-chip Hardware | | Initial Value | On-chip Hardware | Initial Value | | |-------------------------------------------------------|-------|--------------------|---------------------------------|-----------------------------|--| | Program counter (PC) Stack pointer (SP) | | (FFFFEH to FFFFCH) | | 0 | | | | | Not initialized | Prescaler and divider of timing | | | | General-purpose registers<br>(W, A, B, C, D, E, H, L) | | Not initialized | generator | Ü | | | Register bank selector | (RBS) | 0 | Watchdog timer | Fachle | | | Jump status flag | (JF) | 1 | watchdog timer | Enable | | | Zero flag (ZF) | | Not initialized | | | | | Carry flag | (CF) | Not initialized | 1 | | | | Half carry flag (HF)<br>Sign flag (SF) | | Not initialized | Output latches of I/O ports | Refer to I/O port circuitry | | | | | Not initialized | Output lateries of 1/O ports | | | | Overflow flag | (VF) | Not initialized | | | | | Interrupt master enable flag (IMF) | | 0 | | | | | Interrupt individual enable flags | | 0 | | Refer to each of | | | (EF) | | | Control registers | control register | | | Interrupt latches | (IL) | 0 | | Control register | | | - | | - | RAM | Not initialized | | Table 1.6.1 Initializing Internal Status by Reset Action #### 1.6.1 External Reset Input The RESET pin contains a Schmitt trigger (Hysteresis) with an internal pull-up resistor. When the RESET pin is held at "L" level for at least 3 machine cycles (12/fc [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 $\overline{\text{RESET}}$ pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFFCH to FFFFEH. Figure 1.6.1 Reset Circuit #### 1.6.2 Address-trap-reset If the CPU should start looping for some cause such as noise and an attempt be made to fetch an instruction from the on-chip RAM, DBR or the SFR area, address-trap-reset will be generated. Then, the $\overline{\text{RESET}}$ pin output will go low. The reset time is about 8/fc to 24/fc [s] (0.5 to 1.5 $\mu s$ at 16 MHz). Figure 1.6.2 Address-trap-reset #### 1.6.3 Watchdog Timer Reset Refer to section 2.4 "Watchdog Timer". #### 1.6.4 System-clock-reset Clearing bits 7 in SYSCR2 to "0", system clock stops and causes the microcomputer to deadlock. This can be prevented by automatically generating a reset signal whenever bits 7, 6 and 5 in SYSCR2 = 000 is detected to continue the oscillation. The $\overline{\text{RESET}}$ pin output goes low from high-impedance. The reset time is about 8/fc to 24/fc [s] (0.5 to 1.5 $\mu$ s at 16 MHz). #### 1.7 ROM Corrective Function The ROM corrective function can patch the part (s) of on-chip ROM with some bugs. The ROM corrective function have two modes. One is to replaced the instruction on a certain address in the ROM with the jump instruction to branch into the RAM area where the patched codes (Program jump mode). The other is to replace a byte or a word (2 or 3 bytes) length data in the ROM with the patched data (Data replacement mode). Four independent location can be patched. - Note 1: When use ROM corrective circuit, it is necessary to contain a program which operates to load patched program and/or replacement data from external memory into an internal data RAM in an initial routine. - Note 2: The address of a instruction for IDLE mode can not be specificated as start address of corrective area. - Note 3: The BM88CS38N0A does not support the ROM corrective circuit. Use the TMP88PS38 to debug a program of this circuit. In this case, note the following. In program jump mode, jump target addresses that can be specified with the TMP88CM38A/CP38A (002C0H to 006BFH) are different from those that can be specified with the TMP88PS38 (002C0H to 008BFH). Therefore, if a jump target address is within a range of 006C0H to 008BFH, it is necessary to change this addresse and also addresses for loading a patch program. Example: # 1.7.1 Configuration Figure 1.7.1 ROM Corrective Circuit #### 1.7.2 Control The ROM corrective function is controlled by ROM corrective control register (ROMCCR) and ROM corrective data register (ROMCDR). Figure 1.7.2 ROM Corrective Control Register, Status Register and ROM Corrective Data Register #### (1) Enable and disable The ROM corrective function is disabled after releasing reset. It is enabled after setting the data for one bank into ROMCDR. And the address-trap-reset is not generated when fetching an instruction from the RAM area except the address 02C0H to 08BFH. After the ROM corrective function is enabled, it is necessary to reset the microcontroller in order to disable it. #### (2) Data replacement mode The ROM corrective function has the program jump mode and the data replacement mode. By setting CMx (x: 0 to 3) in ROMCCR, the data replacement mode is selected. #### (3) The ROM corrective data register writing The ROM corrective data register has four banks corresponding to four independent locations to patch. The write data counter (WDC) points each bank set. (Figure 1.7.2) Figure 1.7.3 Banks and WDC Value of the Program Corrective Data Register Whenever ROMCDR is written, WDC is incremented to indicate what data is writen via ROMCDR. During reset, WDC is initialized to "0". - (1) The lower start address of the corrective area (8 bits) - (2) The middle start address of the corrective area (8 bits) - (3) The upper start address of the corrective area (4 bits) - (4) The lower jump address/replacement data (8 bits) - (5) The middle jump address/replacement data (8 bits) - (6) The upper jump address (4 bits)/replacement data Note 1: Corrective addresses must have over five addresses each other. Note 2: The address of a instruction for IDLE mode can not be specificated as start address of corrective area. #### 1.7.3 Functions The ROM corrective function can correct maximum four ROM areas with their corresponding four banks of ROM corrective registers. Either program jump mode or data replacement mode is selected for each bank by CM0 to CM3 respectively. #### (1) Program jump mode In the program jump mode, the system executes a jump instruction when the program execution reaches the instruction at the corrective ROM address, skips from the instruction which would have been executed, and executes an instruction at a preset jump address. Clearing ROMCCR CMx (x: 0 to 3) to "0" puts the system in the program jump mode. Use ROMCDR to set the corrective ROM address and jump address. When the start address of an erroneous program is a corrective ROM address, and that of the patch program is a jump address, the bug in the erroneous program can be fixed. Note that the patch program should end with a jump instruction, which causes a return to the built-in ROM. Note: For program jump mode, the address to be corrected must be the start address of the instruction. Example 1: Setting the program correction circuit with the initial routine Using the initial routine program, which is executed right after reset, set the program correction circuit's register and stores the patch program into the built-in RAM as follows. - 1. Read the flag, which indicates whether to use the program correction circuit, from the external memory. - If that circuit is not used, perform normal initial processing. - 3. If it is used, clear CMx to 0 to establish the program jump mode. - 4. Read the corrective ROM address and jump address from the external memory. - 5. Set the corrective ROM address and jump address, which were read in step "4.", in ROMCDR. - 6. Read the number of bytes for the patch program from the external memory. - 7. Read the program with a number of bytes, equal to the byte count read in step "6.", from the external memory, and store that program into the built-in RAM. - 8. Repeat steps "4." through "7." as many times as there are required banks. #### Example 2: There is bugs on the locations from 0C020H to 0C085H The corrective address, the jump vector, the program patch codes and other information to patch the ROM with the bugs must be read out from any of memory storage that holds them during initial program routine. CMn = 0 specifies the program jump mode. Subsequently, the patch program codes are loaded into RAM (00600H to 006EFH). The start address (0C020H) of the ROM necessary to patch is written to the corrective ROM address registers, and the start address (00600H) of the RAM area to patch is loaded onto the jump address registers. When the instruction at 0C020H is fetched, the instruction to jump into 00600H is unconditionally executed instead of the instruction at 0C020H, and the subsequent patch program codes are executed. The jump instruction at the end of the patch program codes returns to the ROM at 0C086H. Note: Corrective address must be assigned to 1st byte of instruction codes on the program jump mode. #### (2) Data replacement mode In the data replacement mode, the system replaces reference data stored in the ROM area with the new instead of correcting the data reference instruction when that reference data is changed. The program jump mode reduces the complexity of correcting the processing routine. However, when this mode is used, if there is a need to replace only the fixed data in ROM, the instruction to reference this ROM data should be corrected. Thus, a large amount of ROM is required for the patch program. To avoid this, the system has the data replacement mode. With this mode, three consecutive bytes of data can be replaced for each bank. (For an instruction which accesses only one byte, only the first byte can be replaced. For an instruction which accesses only two bytes, the two consecutive bytes can be replaced.) Setting ROMCCR CMx (x: 0 to 3) to "1" puts the system in the data replacement mode. Specify the start address of ROM data to be replaced as the corrective ROM address. Then, specify the new three-byte data as the patch data. Note: For data replacement mode, the corrective address should be the address of fixed data (including a vector). (The operation code and operand cannot be changed.) Example 1: Setting the program correction circuit with the initial routine Using the initial routine program, which is executed right after reset, set the program correction circuit's register as follows. - Read the flag, which indicates whether to use the program correction circuit, from the external memory. - 2. If that circuit is not used, perform normal initial processing. - 3. If it is used, set CMx to "1" to establish the data replacement mode. - 4. Read the address of the data to be replaced and the patch data from the external memory. - 5. Set the address and patch data, which were read in step "4.", in ROMCDR. - 6. Repeat steps "4." and "5." as many times as there are required banks. #### Example 2: Replacing data 55H at 0C020H with 33H Using the initial routine program, which is executed right after reset, read the start address of the data to be replaced and the patch data from the external memory. Set CMx (x: 0 to 3) to "1" to change the correction mode to the data replacement mode. Specify the start address (0C020H) of the data to be replaced as the corrective ROM address. Then, specify the new three-byte data (33H for 0C020H, CCH for 0C021H, and C3H for 0C022H) as the patch data. - 1. At HL = 0C020H, Executing LD A, (HL) loads 33H in A. (Data replacement) - 2. At HL = 0C021H, Executing LD A, (HL) loads AAH in A. (No data replacement) - 3. At HL = 0C020H, Executing LD WA, (HL) loads CC33H in WA. (Data replacement) - 4. At HL = 0C020H, Executing LD IX, (HL) loads CCC33H in IX. (Data replacement) Note 1: Corrective address must be assigned to constant data area on the data replacement mode. (Ope-code and ope-rand can't be replaced by ROM correction circuit.) Note 2: Instructions which includes "(HL+)" or "(–HL)" operation can't be replaced by ROM corrective circuit on the data replacement mode. # 2. On-chip Peripheral Functions ## 2.1 Special Function Registers (SFR) and Data Buffer Registers (DBR) The TLCS-870/X series uses the memory mapped I/O system and all peripheral control and data transfers are performed through the special function registers (SFR) and data buffer registers (DBR). The SFR are mapped to addresses 00000H to 0003FH, and DBR are mapped to address 00F80H to 00FFFH. Figure 2.1.1 shows the list of the TMP88CS38/CM38A/CP38A SFRs and DBRs. | Address | | Read | Write | Address | Read | Write | |---------|---------------------|---------------------|----------------------------------------------|--------------|----------------------------|---------------------------------------------------| | H00000 | | | Reserved | 00020H | SBISRA (SBI statusA) | SBICRA (SBI control register A) | | 00001 | Reserved | | 00021 | SBIDBR ( | (SBI data buffer) | | | 00002 | | P2 port | | 00022 | - | I <sup>2</sup> CAR (I <sup>2</sup> C bus address) | | 00003 | | | P3 port | 00023 | SBISRB (SBI statusB) | SBICRB (SBI control register B) | | 00004 | | | P4 port | 00024 | - | ORDMAL (OSD control) | | 00005 | | | P5 port | 00025 | - | ORDMAH (OSD control) | | 00006 | | | P6 port | 00026 | RCSR (TC3 status) | RCCR (TC3 control) | | 00007 | | | P7 port | 00027 | PMPXC | R (Port control) | | 80000 | | | P5CR1 (P5 port I/O control1) | 00028 | - | PWMCR1A (PWM control 1A) | | 00009 | | | P7CR (P7 port I/O control) | 00029 | - | PWMCR1B (PWM control 1B) | | 0000A | | | Reserved | 0002A | - | PWMDBR1 (PWMDBR1) | | 0000B | | | Reserved | 0002B | - | P3CR1 (P3 I/O control) | | 0000C | | | P4CR (P4 port I/O control) | 0002C | EIRE | L | | 0000D | | | P6CR (P6 port I/O control) | 0002D | EIRD | (Interrupt enable register) | | 0000E | | ADCCRA (A | D converter control A) | 0002E | ILE | (laterary and laterary | | 0000F | | ADCCRB (A | D converter control B) | 0002F | ILD | (Interrupt latch) | | 00010 | | TC1DRAL | | 00030 | CGCR ( | Divider control) | | 00011 | | TC1DRAH | (Timer register 1A) | 00031 | ADCDR1 (AI | D conversion result) | | 00012 | TC1DRB <sub>L</sub> | | | 00032 | | D conversion result) | | 00013 | TC1DRBH | ·(Timer register 1E | ) | 00033 | | Reserved | | 00014 | | TC1C | R (TC1 control) | 00034 | | WDTCR1 (Watchdog timer) | | 00015 | | | TC2CR (TC2 control) | 00035 | | WDTCR2 \control \ | | 00016 | | | TC2DRI | 00036 | TBTCR ( | TBT/TG control) | | 00017 | | | TC2DRH (Timer register 2) = | 00037 | _ | EINTCR (External interrupt control) | | 00018 | | TC3DRA | (Timer register 3A) | 00038 | SYSCR1 | L : _ \_ : _ : _ : _ : _ : _ : _ : _ | | 00019 | TC3DRB ( | Timer register 3B) | ( | 00039 | SYSCR2 | - (System control) | | 0001A | 103-112 | _ | TC3CR (TC3 control) | 0003A | EIRL | | | 0001B | | | TC4DR (Timer register 4) | 0003B | EIRH | (Interrupt enable register) | | 0001C | | | TC4CR (TC4 control) | 0003C | ILL | | | 0001D | | ORDS | N (OSD control) | 0003D | LH | (Interrupt latch) | | 0001E | | | AL (OSD control) | 0003E | PSWL | | | 0001E | | | AH (OSD control) | 0003F | PSWH | (Program status word) | | 0001F | Note 1: | | (a) Special to see reserved areas by the pro | unction regi | | | | | Note 2: | -: Cannot be | e accessed. | | | | | | Note 3: | | | cannot use | the read-modify-write in | nstructions (Bit manipulation | | | | instructions | such as SET, CLR, etc. and | logical oper | ration instructions such a | as AND, OR, etc.). | | | Note 4: | When defini | ng address 0003FH with ass | sembler sym | bols, use GRBS. | | | | | A dd==== 000 | 3EH must be GPSW/GFLA | _ | | | Figure 2.1.1 (a) SFR Figure 2.1.2 (b) DBR #### 2.2 I/O Ports The TMP88CS38/CM38A/CP38A has 6 parallel input/output ports (33 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, data slicer analog input, timer/counter input, serial bus interface input/output and data slicer input | | Port P4 | 8-bit I/O port | Pulse width modulation output | | Port P5 | 8-bit I/O port | Pulse width modulation output external interrupt input, timer/counter input, key-on wakeup input, serial bus interface input/output, analog input and I output from OSD circuitry. | | Port P6 | 8-bit I/O port | R, G, B and Y/BL output from OSD circuitry, R.G.B and Y/BL input, analog input, test video signal output and key-on wakeup input | | 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.1 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.1 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 - 1. XCH r, (src) - 2. SET/CLR/CPL (src).b - 3. SET/CLR/CPL (pp).g - 4. LD (src).b, CF - 5. LD (pp).b, CF - 6. ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), n - 7. (src) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) - (2) Instructions that read the pin input data - 1. Instructions other than the above (1) - 2. (HL) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) ## 2.2.1 Port P2 (P20) Port P2 is a 1bit 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. Figure 2.2.2 Port P2 ### 2.2.2 Port P3 (P35 to P30) Port P3 is an 6-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 P3 input/output control register 1 (P3CR1). Port P3 is configured as an input if its corresponding P3CR1 bit is cleared to "0", and as an output if its corresponding P3CR1 bit is set to "1". During reset, P3CR1 is initialized to "0", which configures port P3 as an input. The P3 output latches are also initialized to "1". Data is written into the output latch regardless of the P3CR1 contents. Therefore initial output data should be written into the output latch before setting P3CR1. Port P3 is also used as an external interrupt input, remote-control signal input a timer/counter input, data slicer input and serial bus interface input/output. When used as a secondary function input pin except I<sup>2</sup>C bus interface input/output, the input pins should be set to the input mode. When used as a secondary function output pin except I<sup>2</sup>C bus interface input/output, the output pins should be set to the output mode and beforehand the output latch should be set to "1". When P34 and P35 are used as I<sup>2</sup>C bus interface input/output, P3CR2 bits should be set to the sink open drain mode, the output latches should be set to "1", and the output pins should be set to the output mode. 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. ``` Example 1: Outputs an immediate data 5A<sub>H</sub> to port P3 ``` LD (P3), $5A_H$ ; $P3 \leftarrow 5A_H$ Example 2: Inverts the output of the lower 4 bits (P33 to P30) in port P3 XOR (P3), 00001111B ; P33 to P30 $\leftarrow$ P33 to P30 Figure 2.2.3 Port P3 and P3CR #### 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. Figure 2.2.4 Port P4 and P4CR #### 2.2.4 Port P5 (P57 to P50) Port P5 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 P5 input/output control register 1 (P5CR1). Port P5 is configured as an input if its corresponding P5CR1 bit is cleared to "0", and as an output if its corresponding P5CR1 bit is set to "1". During reset, P5CR1 is initialized to "0", which configures port P5 as an input. The P5 output latches are also initialized to "1". Data is written into the output latch regardless of the P5CR1 contents. Therefore initial output data should be written into the output latch before setting P5CR1. Port P5 is also used as is also used as AD converter analog input, a pulse width modulation (PWM) output external interrupt input, timer/counter input, serial bus interface input/output, and an on screen display (OSD) output (I signal). When used as a secondary function input pin except I<sup>2</sup>C bus interface input/output, the input pins should be set to the input mode. When used as a secondary function output pin except I<sup>2</sup>C bus interface input/output, the output pins should be set to the output mode and beforehand the output latch should be set to "1". When P52 and P51 are used as I<sup>2</sup>C bus interface input/output, P5CR2 bits should be set to the sink open-drain mode, the output latches should be set to "1", and the output pins should be set to the output mode. When P57 is used as an OSD output pin, the output pin should be set to the output mode and beforehand the port 6 data selection register (PIDS) should be clear to "0". When used as port P5, the port 6 data selection register (PIDS) 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. Figure 2.2.5 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/output mode is selected by the corresponding bit in the port P6 input/output control register (P6CR). Port P6 is configured as an input if its corresponding P6CR bit is cleared to "0", and as an output if its corresponding P6CR bit is set to "1" and P6nS bit is set to "1". P63 to P60 are sink open-drain ports. During reset, P6CR is initialized to "0", which configures port P6 as an input. The P6 output latches are also initialized to "1". 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)/input (RIN, GIN BIN, Y/BLIN signal), a test video signal output and AD converter analog input. When used as a test video signal output pin, the output pins should be set to the output mode and beforehand the signal control register (SGEN) should be set to "1". When used as a secondary function input, the input pins should be set to the input mode. When used as an OSD 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 clear to "0". When used as port P6, the signal control register (P67 to P64) 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. Example: Sets the lower 4 bits (P63 to P60) in port P6 to the output mode, and the other bit to the input mode. LD (P6CR), 0FH ; P6CR $\leftarrow$ 00001111B 2004-8-18 Figure 2.2.6 Ports P6, P6CR, and P67S to P64S ## 2.2.6 Port P7 (P71 to P70) Port P7 is a 2bit input/output port, and is also used as a vertical synchronous signal ( $\overline{\text{VD}}$ ) input and a horizontal synchronous signal ( $\overline{\text{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.2.7 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.3.1. An INTTBT is generated on the first falling 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. 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/2^{16} [Hz] and enables an INTTBT interrupt. LD (TBTCR), 00000010B ; TBTCK = "010" LD (TBTCR), 00001010B ; TBTEN = "1" SET (EIRL). 6 ``` Figure 2.3.1 Time Base Timer Figure 2.3.2 Time Base Timer and Divider Output Control Register Table 2.3.1 Time Base Timer Interrupt Frequency (Example: at fc = 16 MHz) | | Time Base Timer Interrupt Frequ | uency [Hz] | |-------|---------------------------------|------------| | TBTCK | NORMAL, IDLE mode | • | | | DV1CK = 0 | DV1CK = 1 | | 000 | 1.90 | 0.95 | | 001 | 7.62 | 3.81 | | 010 | 244.14 | 122.07 | | 011 | 976.56 | 488.28 | | 100 | 1953.12 | 976.56 | | 101 | 3906.25 | 1953.12 | | 110 | 7812.50 | 3906.25 | | 111 | 31250 | 15625 | ## 2.4 Watchdog Timer (WDT) The watchdog timer is a fail-safe system to rapidly detect the CPU malfunctions such as endless looping caused by noise or the like, or deadlock and resume the CPU to the normal state. The watchdog timer signal for detecting malfunction can be selected either a reset output or a pseudo 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. Note: Care must be given in system design so as to protect the watchdog timer from disturbing noise. Otherwise the watchdog timer may not fully exhibit its functionality. #### 2.4.1 Watchdog Timer Configuration Figure 2.4.1 Watchdog Timer Configuration ## 2.4.2 Watchdog Timer Control Figure 2.4.2 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 at follows. - 1. Setting the detection time, selecting output, and clearing the binary counter. - 2. Repeatedly clearing the binary counter within the setting detection time. Note: The watchdog timer consists of an internal divider and two-stage binary counter. Writing the clear code (4E<sub>H</sub>) clears the binary counter, but not the internal divider. The minimum overflow time for the binary counter might be three quarters of the WDTCR1 (WDTT) time setting depending on when the clear code (4E<sub>H</sub>) is written into the WDTCR2 register. So, write the clear code on a cycle which is shorter than that minimum overflow time. If the CPU malfunctions such as endless looping or deadlock occur for any cause, the watchdog timer output will become active at the rising of an overflow from the binary counters unless the binary counters are cleared. At this time, when WDTOUT = 1 a reset is generated, which drivers the $\overline{\text{RESET}}$ pin low to reset the internal hardware and the external circuit. 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 the STOP/IDLE mode is released. LD (WDTCR2), 4EH Example: Sets the watchdog timer detection time to 2<sup>21</sup>/fc [s] and resets the CPU malfunction. ; Clears the binary counters Figure 2.4.2 Watchdog Timer Control Registers #### (2) Watchdog timer enable The watchdog timer is enabled by setting WDTEN (Bit3 in WDTCR1) to "1". WDTEN is initialized to "1" during reset, so the watchdog timer operates immediately after reset is released. ``` Example: Disables watchdog timer LDW (WDTCR1), 00001000B ; WDTEN \leftarrow 1 ``` #### (3) Watchdog timer disable To disable the watchdog timer, clear the interrupt mask enable flag (IMF) to "0" and write the clear code (4E<sub>H</sub>) into WDTCR2. Then, clear WDTEN (Bit3 in WDTCR1) to "0". When WDTEN is "0", the watchdog timer is disabled by writing the disable code (B1<sub>H</sub>) into WDTCR2. If WDTEN is cleared to "0" after the disable code has been written into WDTCR2, the watchdog timer is not disabled. While it is disabled, its binary counter is cleared. ``` Example: DI ; Disables interrupt acceptance. LD (WDTCR2), 4EH ; Clears the watchdog timer. LDW (WDTCR1), B101H ; Disables the watchdog timer. EI ; Enables interrupt acceptance. ``` Table 2.4.1 Watchdog Timer Detection Time (Example: fc = 16 MHz) | | Watchdog timer detection time [s] | | | | | |------|-----------------------------------|-----------|--|--|--| | WDTT | NORMAL mode | | | | | | | DV1CK = 0 | DV1CK = 1 | | | | | 00 | 2.097 | 4.194 | | | | | 01 | 524.288 m | 1.048 | | | | | 10 | 131.072 m | 262.1 m | | | | | 11 | 32.768 m | 65.5 m | | | | #### 2.4.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 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. ## 2.4.4 Watchdog Timer Reset If the watchdog timer output becomes active, a reset is generated, which drivers the $\overline{\text{RESET}}$ pin (Sink open drain input/output with pull-up) low to reset the internal hardware. The reset output time is about 8/fc to 24/fc [s] (0.5 to 1.5 $\mu$ s at fc = 16.0 MHz). Note: If there is any fluctuation in the oscillation frequency at the start of clock oscillation, the reset time includes error. Thus, regard the reset time as an approximate value. Figure 2.4.3 Watchdog Timer Interrupt/Reset ## 2.5 16-Bit Timer/Counter 1 (TC1A) ## 2.5.1 Configuration Figure 2.5.1 Timer/Counter 1 #### 2.5.2 Control The timer/counter 1 is controlled by a timer/counter 1 control register (TC1CR) and two 16-bit timer registers (TC1DRA and TC1DRB). Figure 2.5.2 Timer Registers and TC1 Control Register #### 2.5.3 Function Timer/counter 1 has five operating modes: timer, external trigger timer, event counter, window, pulse width measurement. #### (1) Timer mode In this mode, counting up is performed using the internal clock. The contents of TC1DRA are compared with the contents of 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 up counter can be transferred to TC1DRB by setting ACAP1 (Bit6 in TC1CR) to "1" (Software capture function). (Auto-capture function) Table 2.5.1 Source Clock (Internal clock) for Timer/Counter 1 (Example: at fc = 16.0 MHz) | | NORMAL, IDLE mode | | | | | |-------|-------------------|--------------------------|-----------------|--------------------------|--| | TC1CK | DV1CK = 0 | | DV1CK = 1 | | | | | Resolution [μs] | Maximum time setting [s] | Resolution [μs] | Maximum time setting [s] | | | 00 | 128.0 | 8.39 | 256.0 | 16.78 | | | 01 | 8.0 | 0.524 | 16.0 | 1.049 | | | 10 | 0.5 | 32.77 m | 1.0 | 65.54 m | | Example 1: Sets the timer mode with source clock $fc/2^{11}$ [Hz] and generates an interrupt 1 later (at fc = 16 MHz) LDW (TC1DRA), 1E84H ; Sets the timer register $(1 s \div 2^{11}/fc = 1E84H)$ DI SET (EIRL). 4 ; Enable INTTC1 ΕI LD (TC1CR), 00000000B ; Selects the source clock and mode LD (TC1CR), 00010000B ; Starts TC1 Example 2: Auto capture Figure 2.5.3 Timer Mode Timing Chart #### (2) External trigger timer mode In this mode, counting up is started by an external trigger. This trigger is the edge of the TC1 pin input. Either the rising or falling edge can be selected with TC1S. Source clock is an internal clock. The contents of TC1DRA is compared with the contents of 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. When METT1 (Bit6 in TC1CR) is "1", inputting the edge to the reverse direction of the trigger edge to start counting clears the counter, and the counter is stopped. Inputting a constant pulse width can generate interrupts. When METT1 is "0", the reverse directive edge input is ignored. The TC1 pin input edge before a match detection is also ignored. The TC1 pin input has the noise rejection; therefore, pulses of 7/fc [s] or less are rejected as noise. A pulse width of 13/fc [s] or more is required for edge detection in NORMAL or IDLE mode. ``` Example 1: Detects rising edge in TC1 pin input and generates an interrupt 100 µs later. (at fc = 16.0 MHz, DV1CK = 1) LDW (TC1DRA), 0064H 100 \ \mu s \div 2^4/fc = 64H DI SET (EIRL). 4 INTTC1 interrupt enable ΕI LD (TC1CR), 00001000B Selects the source clock and mode LD (TC1CR), 00101000B TC1 external trigger start, METT1 = 0 Example 2: Generates an interrupt, inputting "L" level pulse (Pulse width: 4 ms or more) to the TC1 pin. (at fc = 16.0 MHz, DV1CK = 1) 4 \text{ ms} \div 2^8/\text{fc} = \text{FAH} LDW (TC1DRA), 00FAH DI SET (EIRL). 4 INTTC1 interrupt enable ΕI LD (TC1CR), 00000100B Selects the source clock and mode (TC1CR), 01110100B LD TC1 external trigger start, METT1 = 1 ``` Figure 2.5.4 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 the rising or falling edge can be selected with the external trigger TC1CR<TC1S>). The contents of TC1DRA are compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Match detect is executed on other edge of count-up. A match can not be detected and INTTC1 is not generated when the pulse is still in same state. Setting ACAP1 to "1" transfers the current contents of up counter to TC1DRB (Auto-capture function). Figure 2.5.5 Event Counter Mode Timing Chart Table 2.5.2 Input Pulse Width for Timer/Counter 1 | | Minimum Pulse Width [s] | | |-----------|-------------------------|--| | | NORMAL/IDLE | | | "H" Width | 2 <sup>3</sup> /fc | | | "L" Width | 2 <sup>3</sup> /fc | | #### (4) Window mode Counting up is performed on 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 TC1DRA are compared with the contents of 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 bit4 or 5 in TC1CR. It is necessary that the maximum applied frequency 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.5.6 Window Mode Timing Chart #### (5) Pulse width measurement mode In this mode, counting is started by the external trigger (Set to external trigger start by TC1CR). The trigger can be selected either the rising or falling edge of the TC1 pin input. The source clock is used an internal clock. On the next falling (rising) edge, the counter contents are transferred to TC1DRB and an INTTC1 interrupt is generated. The counter is cleared when the 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 TC1DRB. If a falling (rising) edge capture value is required, it is necessary to read out TC1DRB contents until a rising (falling) edge is detected. Falling or rising edge is selected with the external trigger TC1S (Bit4 or 5 in TC1CR), and single edge or double edge is selected with MCAP1 (Bit6 in TC1CR). - Note 1: Be sure to read the captured value from TC1DRB before the next trigger edge is detected. If fail to read it, it becomes undefined. It is recommended that a 16-bit access instruction be used to read from TC1DRB. - Note 2: If either the falling or rising edge is used in capturing values, the counter stops at "1" after a value has been captured until the next edge is detected. So, the value captured next will become "1" larger than the value captured right after capturing starts. Figure 2.5.7 Pulse Width Measurement Mode Timing Chart # 2.6 16-Bit Timer/Counter 2 (TC2A) # 2.6.1 Configuration Figure 2.6.1 Timer/Counter 2 (TC2) #### 2.6.2 Control The timer/counter 2 is controlled by a timer/counter 2 control register (TC2CR) and a 16-bit timer register 2 (TC2DR). Reset does not affect TC2DR. Figure 2.6.2 Timer Registers 2 and TC2 Control Register #### 2.6.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 TC2DR are compared with the contents of 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.6.1 Source Clock (Internal clock) for Timer/Counter 2 (at fc = 16.0 MHz) | | NORMAL, IDLE Mode | | | | | |--------|-------------------|-------------------------|------------|-------------------------|--| | TC2CK | DV10 | CK = 0 | DV1CK = 1 | | | | 102011 | Resolution | Maximum<br>Time Setting | Resolution | Maximum<br>Time Setting | | | 000 | 524.3 [ms] | 9.54 [h] | 1.05 [s] | 19.1 [h] | | | 001 | 512.0 [μs] | 33.6 [s] | 1.02 [ms] | 1.12 [min] | | | 010 | 16.0 [μs] | 1.05 [s] | 32.0 [μs] | 2.09 [s] | | | 011 | 0.5 [μs] | 32.8 [ms] | 1.0 [μs] | 65.5 [ms] | | | 100 | Reserved | Reserved | Reserved | Reserved | | | 101 | Reserved | Reserved | Reserved | Reserved | | Example: Sets the source clock $fc/2^4$ [Hz] and generates an interrupt event 25 ms (at fc = 16 MHz, DV1CK = 1) LDW (TC2DR), 61A8H ; Sets TC2DR (25 ms $\div$ 2 $^4$ /fc = 61A8H) DI SE SET (EIRH). 6 ; Enable INTTC2 interrupt ΕI LD (TC2CR), 00001100B ; Selects TC2 source clock LD (TC2CR), 00101100B ; Starts TC2 Figure 2.6.3 Timer Mode Timing Chart #### (2) Event counter mode In this mode, events are counted on the rising edge of the TC2 pin input. The contents of TC2DR 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 minimum pulse width to the TC2 pin is shown in Table 2.6.2. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width. Match detect is executed on the falling edge of the TC2 pin. A match can not be detected and INTTC2 is not generated when the pulse is still in a falling state. Example: Sets the event counter mode and generates an INTTC2 interrupt 640 counts later. LDW (TC2DR), 640 ; Sets TC2DR DI SET (EIRH). 6 ; Enables INTTC2 interrupt ΕI LD (TC2CR), 00011100B ; Selects TC2 source clock LD (TC2CR), 00111100B ; Starts TC2 Table 2.6.2 Timer/Counter 2 External Clock Source | | Minimum Pulse Width [S] | |-----------|-------------------------| | | NORMAL, IDLE Mode | | "H" Width | 2 <sup>3</sup> /fc | | "L" Width | 2 <sup>3</sup> /fc | Figure 2.6.4 Event Counter Mode Timing Chart #### (3) Window mode In this mode, counting up performed on the rising edge of an internal clock during TC2 external pin input (window pulse) is "H" level. The contents of TC2DR are compared with the contents of up counter. If a match found, an INTTC2 interrupt is generated, and the up counter is cleared. The maximum applied frequency (TC2 input) must be considerably slower than the selected internal clock. Example: Generates an interrupt, inputting "H" level pulse width of 120 ms or more. (at fc = 16.0 MHz, DV1CK = 1) (TC2DR), 0075H Sets TC2DR (120 ms $\div 2^{14}/fc = 0075H$ ) LDW DΙ SET (EIRH). 6 Enables INTTC2 interrupt ΕI Selects TC2 source clock LD (TC2CR), 00000101B LD (TC2CR), 00100101B Starts TC2 Figure 2.6.5 Window Mode Timing Chart # 2.7 8-Bit Timer/Counter 3 (TC3B) # 2.7.1 Configuration Figure 2.7.1 Timer/Counter 3 (TC3) #### 2.7.2 Control The timer/counter 3 is controlled by a timer/counter 3 control register (TC3CR) and two 8-bit timer registers (TC3DRA and TC3DRB) and port multiplex control register (PMPXCR). Figure 2.7.2 Timer Registers 3 and TC3 Control Register ### 2.7.3 Function The timer/counter 3 has three operating modes: timer, event counter, and capture mode. When it is used in the capture mode, the noise rejection time of TC3 pin input can be set by remote control receive control register. ### (1) Timer mode In this mode, the internal clock is used for counting up. The contents of TC3DRA are compared with the contents of up counter. If a match is found, a timer/counter 3 interrupt (INTTC3) is generated, and the up counter is cleared. The current contents of up counter are loaded into TC3DRB by setting ACAP (Bit6 in TC3CR) to "1" (Auto-capture function). The contents of up counter can be easily confirmed by executing the read instruction (RD instruction) of TC3DRB. Loading the contents of up counter is not synchronized with counting up. The contents of over flow (FFH) and 00H can not be loaded correctly. It is necessary to consider the count cycle. Table 2.7.1 Source Clock (Internal clock) for Timer/Counter 3 (Example: at fc = 16.0 MHz) | | NORMAL, IDLE Mode | | | | | |-------|-------------------|------------------------------|-----------------|------------------------------|--| | тсзск | DV1CK = 0 | | DV1CK = 1 | | | | | Resolution [µs] | Maximum Setting<br>Time [ms] | Resolution [μs] | Maximum Setting<br>Time [ms] | | | 000 | 512 | 130.6 | 1024 | 261.1 | | | 001 | 256 | 65.3 | 512 | 130.6 | | | 010 | 128 | 32.6 | 256 | 65.3 | | | 011 | 64 | 16.3 | 128 | 32.6 | | | 100 | 32 | 8.2 | 64 | 16.3 | | | 101 | 16 | 4.1 | 32 | 8.2 | | | 110 | 8 | 2.0 | 16 | 4.1 | | Figure 2.7.3 Timer Mode Timing Chart #### (2) Event counter mode In this mode, the TC3 pin input pulses are used for counting up Either the rising on falling edge can be selected with TC3ES (Bit0 in PMPXCR). The contents of TC3DRA are compared with the contents of the up counter. If a match is found, an INTTC3 interrupt is generated and the counter is cleared. Match detect is executed on the falling edge of the TC3 pin. A match can not be detected, and INTTC3 is not generated when the pulse is still in a falling state. The maximum applied frequency is shown in Table 2.7.2. 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 TC3DRB by setting ACAP (Bit6 in TC3CR) to "1" (Auto-capture function). The contents of up counter can be easily confirmed by executing the read instruction (RD instruction) of TC3DRB. Loading the contents of up counter is not synchronized with counting up. The contents of over flow (FFH) and 00H can not be loaded correctly. It is necessary to consider the count cycle. Example: Generates an interrupt every 0.5 s, inputting 50 Hz pulses to the TC3 pin. LD (TC3CR), 00001110B ; Sets TC3 mode and source clock LD (TC3DRA), 19H ; $0.5 \text{ s} \div 1/50 = 25 = 19\text{H}$ LD (TC3CR), 00011100B ; Starts TC3 Table 2.7.2 Source Clock (External clock) for Timer/Counter | | Minimum Applied Frequency [Hz] | |-----------|--------------------------------| | | NORMAL, IDLE Mode | | "H" Width | 2 <sup>2</sup> /fc | | "L" Width | 2 <sup>2</sup> /fc | Figure 2.7.4 Event Counter Mode Timing Chart # (3) Capture mode In this 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 signals or distinguishing AC 50/60 Hz, etc. The TC3 pin input can have its polarity changed between normal and inverse by using the TC3ES Register. # a. If TC3ES = "0" (Non-inverting input) Once command operation has started, the counter free-runs on an internal source clock. When the falling edge of the TC3 pin input is detected, the counter value is loaded into TC3DRB. When the rising edge is detected, the counter value is loaded into TC3DRA, and the counter is cleared, generating an INTTC3 interrupt. If the rising edge is detected right after command operation has started, no capture to TC3DRB and an INTTC3 interrupt occurs only on capture to TC3DRA. If a read instruction is executed for TC3DRB, the value that exists at the end of the previous capture (immediately after a reset, "FF") is read. #### b. If TC3ES = "1" (Inverse input) Once command operation has started, the counter free-runs on an internal clock. When the rising edge of the TC3 pin input is detected, the counter value is loaded into TC3DRB. When the falling edge is detected, the counter value is loaded into TC3DRA, and the counter is cleared, generating an INTTC3 interrupt. If the falling edge is detected right after command operation has started, the counter value is not captured into TC3DRB and an INTTC3 interrupt occurs only on capture to TC3DRA. If a read instruction is executed for TC3DRB, the value that exists at end of the previous capture (immediately after a reset, "FF") is read. The minimum acceptable input pulse width is equal to the length of one source clock period selected by TC3CR < TC3CK >. | TC3ES | Capture into TC3DRB | Capture into TC3DRA | INTTC3 Interrupt | |---------------------------|---------------------|---------------------|------------------| | "0" (Non-inverting input) | Falling edge | Rising e | dge | | "1"<br>(Inverting input) | Rising edge | Falling e | edge | Table 2.7.3 TC3INV-based Capture Input Edges Note: Capture of the TC3 pin input requires at least 1 cycle of the selected source clock. Figure 2.7.5 Capture Mode Timing Chart The edge of TC3 pin input is detected in the remote control receive circuit with noise rejection. The remote control receive circuit is controlled by the remote control receive control register (RCCR). The remote control receive status register (RCSR) can monitor the polarity selection and noise rejection circuit. Figure 2.7.6 Remote Control Receiving Circuit Figure 2.7.7 Remote Control Register and Remote Control Receive Status Register Table 2.7.4 Combination between The Polarity and The Edge Selection | RPOLS | TC3 Pin Input Pulse (Interrupt occurrence is shown as allow.) | Measurement | |-------|---------------------------------------------------------------|-------------| | 0 | | <b>→</b> | | 1 | | <b></b> | Note: When TC3CK is used in RCSCK, do not select an external clock to the TC3CK. Figure 2.7.8 Remote Control Receive Circuit Timing Chart # 2.8 8-Bit Timer/Counter 4 (TC4) # 2.8.1 Configuration Figure 2.8.1 Timer/Counter 4 (TC4) #### 2.8.2 Control The timer/counter 4 is controlled by a timer/counter 4 control register (TC4CR) and an 8-bit timer register 4 (TC4DR). Reset does not affect TC4DR. Figure 2.8.2 Timer Register 4 and TC4 Control Register ### 2.8.3 Function The timer/counter 4 has two operating modes: timer, event counter mode. ### (1) Timer mode In this mode, the internal clock is used for counting up. The contents of TC4DR are compared with the contents of up counter. If a match is found, an INTTC4 interrupt is generated and the up counter is cleared to "0". Counting up resumes after the up counter is cleared. Table 2.8.1 Source Clock (Internal clock) for Timer/Counter 4 (Example: at fc = 16.0 MHz) | | NORMAL, IDLE Mode | | | | | |--------|-------------------------------------------|-------|-----------------|------------------------------|--| | TC4CK | DV1CK = 0 | | DV1CK = 1 | | | | 101010 | Resolution [μs] Maximum Setting Time [ms] | | Resolution [μs] | Maximum Setting<br>Time [ms] | | | 000 | 128.0 | 32.6 | 256.0 | 65.3 | | | 001 | 8.0 | 2.0 | 16.0 | 4.1 | | | 010 | 2.0 | 0.510 | 4.0 | 1.0 | | | 100 | 0.5 | 0.128 | 1.0 | 0.255 | | #### (2) Event counter mode In this mode, the TC4 pin input (External clock) pulse is used for counting up. Either the rising or falling edge can be selected with TC4ES (Bit1 PMPXCR). The contents of TC4DR are compared with the contents of the up counter. If a match is found, an INTTC4 interrupt is generated and the counter is cleared. The maximum applied frequency is shown Table 2.8.2. Two or more machine cycles are required for both the high and low level of the pulse width. Note: The event counter mode can only be used in NORMAL or IDLE mode. Table 2.8.2 Timer/Counter 4 External Clock Source | | Minimum Input Pulse Width [s] | |-----------|-------------------------------| | | NORMAL1, IDLE1 Mode | | "H" Width | 2 <sup>3</sup> /fc | | "L" Width | 2 <sup>3</sup> /fc | # 2.9 Serial Bus Interface (SBI-ver. D) The TMP88CS38 and TMP88CM38ACP38A has a 1-channel 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). The serial bus interface pins are selectively used as either channel 0 or channel 1. The serial interface is connected to external devices through P35 (SDA0)/P52 (SDA1) and P34 (SCL0)/P51 (SCL1) in the I<sup>2</sup>C bus mode; and through P53 (SCK1), P52 (SO1) and P51 (SI1) in the clocked-synchronous 8-bit SIO mode. The serial bus interface pins are also used for the P3/P5 port. When used for serial bus interface pins, set the P3/P5 output latches of these pins to "1". When not used as serial bus interface pins, the P3/P5 port is used as a normal I/O port. Note 1: When P3 and P5 is used as serial bus interface pins, P35, P34, P51 and P50 should be set as a sink open-drain output by clearing PSELCR to "0". Note 2: The I<sup>2</sup>C of TMP88CS38 and TMP88CM38A/CP38A can be used only in the standard mode of I<sup>2</sup>C. The fast mode and the high speed mode can not be used. # 2.9.1 Configuration Figure 2.9.1 Serial Bus Interface (SBI) #### 2.9.2 Control The following registers are used for control the serial bus interface and monitor the operation status. - Serial bus interface control register A (SBICRA) - Serial bus interface control register B (SBICRB) - Serial bus interface data buffer register (SBIDBR) - I<sup>2</sup>C bus address register (I2CAR) - Serial bus interface status register A (SBISRA) - Serial bus interface status register B (SBISRB) - Serial clock source control register (SCCRB) - Serial clock control status register (SCSR) The above registers differ depending on a mode to be used. Refer to section 2.9.7 "I<sup>2</sup>C Bus Mode Control" and 2.9.9 "Clocked-synchronous 8-Bit SIO Mode Control". #### 2.9.3 Serial Clock Source Control A serial bus interface circuit can reduce the power consumption by stopping a serial clock generater. Figure 2.9.2 Serial Clock Source #### 2.9.4 Channel Select A serial bus interface circuit can select I/O pin when a serial bus interface is used for I<sup>2</sup>C bus mode. Figure 2.9.3 Channel Select #### 2.9.5 Software Reset A serial bus interface circuit has a software reset function, when a serial bus interface circuit is locked by an external noise, etc. To occur software reset, write "01", "10" into the SWRST (Bit1, 0 in SBICRB). During software reset, the SWRMON (Bit0 in SBISRA) is clear to "0". # 2.9.6 The Data Format in The I<sup>2</sup>C bus Mode The data format when using the TMP88CS38 AND TMP88CM38A/CP38A in the I<sup>2</sup>C bus mode are shown in as below. Figure 2.9.4 Data Format in I<sup>2</sup>C Bus Mode # 2.9.7 I<sup>2</sup>C Bus Mode Control The following registers are used to control the serial bus interface (SBI) and monitor the operation status in the I<sup>2</sup>C bus mode. Figure 2.9.5 Serial Bus Interface Control Register A, Serial Bus Interface Data Buffer Register and I<sup>2</sup>C Bus Address Register In The I<sup>2</sup>C Bus Mode Figure 2.9.6 Serial Bus Interface Control Register B and Serial Bus Interface Status Register A/B in the I<sup>2</sup>C Bus Mode #### (1) Acknowledgement mode specification #### a. Acknowledgement mode (ACK = "1") To set the device as an acknowledgement mode, the ACK (Bit4 in SBICRA) should be set to "1". When a serial bus interface circuit is a master mode, an additional clock pulse is generated for an acknowledge signal. In a slave mode, a clock is counted for the acknowledge signal. In the master transmitter mode, the SDA pin is released in order to receive an acknowledge signal from the receiver during additional clock pulse cycle. In the master receiver mode, the SDA pin is set to low level generation an acknowledge signal during additional clock pulse cycle. In a slave mode, when a received slave address matches to a slave address which is set to the I2CAR or when a "GENERAL CALL" is received, the SDA pin is set to low level generating an acknowledge signal. After the matching of slave address or the detection of "GENERAL CALL", in the transmitter the SDA pin is released in order to receive an acknowledge signal from the receiver during additional clock pulse cycle. In a receiver, the SDA pin is set to low level generation an acknowledge signal during additional clock pulse cycle after the matching of slave address or the detection of "GENERAL CALL". The Table 2.9.1 shows the SCL and SDA pins status in acknowledgement mode. | Mode | Pin | | Transmitter | Receiver | | |--------|--------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------|----------------------------------------------------|--| | | SCL | | An additional clock pulse is generated. | | | | Master | SDA Released in order to receive and Joer to low level | | Set to low level generating an acknowledge signal. | | | | | SCL | | A clock is counted for the acknowledge signal. | | | | Slave | SDA | When slave address matches or a general call is detected | - | Set to low level generating an acknowledge signal. | | | | After matching of slave address or general call | | Released in order to receive an acknowledge signal. | Set to low level generating an acknowledge signal. | | Table 2.9.1 SCL and SDA Pins Status in Acknowledgement Mode #### b. Non-acknowledgement mode (ACK = "0") To set the device as a non-acknowledgement mode, the ACK should be cleared to "0". In the master mode, a clock pulse for an acknowledge signal is not generated. In the slave mode, a clock for a acknowledge signal is not counted. #### (2) Number of transfer bits The BC (Bits 7 to 5 in SBICRA) is used to select a number of bits for next transmitting and receiving data. Since the BC is cleared to "000" as a start condition, a slave address and direction bit transmissions are always executed in 8 bits. Other than these, the BC retains a specified value. #### (3) Serial clock #### a. Clock source The SCK (Bits 2 to 0 in SBICRA) is used to select a maximum transfer frequency output from the SCL pin in the master mode. Four or more machine cycles are required for both high and low levels of pulse width in the external clock which is input from SCL pin. Note: Since the I<sup>2</sup>C of TMP88CS38 AND TMP88CM38A/CP38A can not be used as the Fast mode and the High Speed mode, do not set SCK as the frequency that is over 100 kHz. Figure 2.9.7 Clock Source #### b. Clock synchronization In the I<sup>2</sup>C bus mode, in order to drive a bus with a wired AND, a master device which pulls down a clock pulse to low will, in the first place, invalidate a clock pulse of another master device which generates a high-level clock pulse. The serial bus interface circuit has a clock synchronization function. This function ensures normal transfer even if there are two or more masters on the same bus. The example explains clock synchronization procedures when two masters simultaneously exist on a bus. Figure 2.9.8 Clock Synchronization As master 1 pulls down the SCL pin to the low level at point "a", the SCL line of the bus becomes the low level. After detecting this situation, master 2 resets counting a clock pulse in the high level and sets the SCL pin to the low level. Master 1 finishes counting a clock pulse in the low level at point "b" and sets the SCL pin to the high level. Since master 2 holds the SCL line of the bus at the low level, master 1 waits for counting a clock pulse in the high level. After master 2 sets a clock pulse to the high level at point "c" and detects the SCL line of the bus at the high level, master 1 starts counting a clock pulse in the high level. Then, the master, which has finished the counting a clock pulse in the high level, pulls down the SCL pin to the low level. The clock pulse on the bus is determined by the master device with the shortest high-level period and the master device with the longest low-level period from among those master devices connected to the bus. ## (4) Slave address and address recognition mode specification When the serial bus interface circuit is used with an addressing format to recognize the slave address, clear the ALS (Bit0 in I2CAR) to "0", and set the SA (Bits 7 to 1 in I2CAR) to the slave address. When the serial bus interfac circuit is used with a free data format not to recognize the slave address, set the ALS to "1". With a free data format, the slave address and the direction bit are not recognized, and they are processed as data from immediately after start condition. #### (5) Master/slave selection To set a master device, the MST (Bit7 in SBICRB) should be set to "1". To set a slave device, the MST should be cleared to "0". When a stop condition on the bus or an arbitration lost is detected, the MST is cleared to "0" by the hardware. #### (6) Transmitter/receiver selection To set the device as a transmitter, the TRX (Bit6 in SBICRB) should be set to "1". To set the device as a receiver, the TRX should be cleared to "0". When data with an addressing format is transferred in the slave mode, the TRX is set to "1" by a hardware if the direction bit $(R/\overline{W})$ sent from the master device is "1", and is cleared to "0" by a hardware if the bit is "0. In the master mode, after an acknowledge signal is returned from the slave device, the TRX is cleared to "0" by a hardware if a transmitted direction bit is "1", and is set to "1" by a hardware if it is "0". When an acknowledge signal is not returned, the current condition is maintained. When a stop condition on the bus or an arbitration lost is detected, the TRX is cleared to "0" by the hardware. The following table show TRX changing conditions in each mode and TRX value after changing. | Mode | Direction Bit | Conditions | TRX after Changing | |--------|---------------|---------------------------------|--------------------| | Slave | "0" | A received slave address is the | "0" | | mode | "1" | same value set to I2CAR | "1" | | Master | "0" | ACK signal is returned | "1" | | mode | "1" | ACK signal is returned | "0" | When a serial bus interface circuit operates in the free data format, a slave address and a direction bit are not recognized. They are handled as data just after generating a start condition. The TRX is not changed by a hardware. #### (7) Start/stop condition generation When the BB (Bit5 in SBICRB) is "0", a slave address and a 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 SBIDBR and set "1" to ACK beforehand. Figure 2.9.9 Start Condition Generation and Slave Address Generation When the BB is "1", sequence of generating a stop condition is started by writeng "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.9.10 Stop Condition Generation When a stop condition is generated and the SCL line on a bus is pulled down to low level by another device, a stop condition is generated after releasing the SCL line. The bus condition can be indicated by reading the contents of the BB (Bit5 in SBISRB). 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. ### (8) Interrupt service request and cancel When a serial bus interface circuit is in the master mode and transferring a number of clocks set by the BC and the ACK is complete, a serial bus interface interrupt request (INTSBI) is generated. In the slave mode, the conditions of generating INTSBI are follows: - At the end of acknowledge signal when the received slave address matches to the value set by the I2CAR - At the end of acknowledge signal when a "GENERAL CALL" is received - At the end of transferring or receiving after matching of slave address or receiving of "GENRAL CALL" When a serial bus interface interrupt request occurs, the PIN (Bit4 in SBISR) is cleared to "0". During the time that the PIN is "0", the SCL pin is pulled down to low level. Either writing data to SBIDBR or reading data from the SBIDBR sets the PIN to "1". The time from the PIN being set to "1" until the SCL pin is released takes tLOW. Although the PIN (Bit4 in SBICRB) can be set to "1" by the program, the PIN can not be cleared to "0" by the program. Note: If the arbitration lost occurs, when the slave address does not match, the PIN is not cleared to "0" even thought INTSBI is generated. #### (9) Serial bus interface operating mode selection The SBIM (Bit3 and 2 in SBICRB) is used to specify a serial bus interface operation mode. Set the SBIM to "10" in order to change a operation mode to I<sup>2</sup>C bus mode. Before changing operation mode, confirm serial bus interface pins in a high level. And switch a mode to port after confirming that a bus is free. #### (10) Arbitration lost detection monitor Since more than one master device can exist simultaneously on a bus in the $I^2C$ bus mode, a bus arbitration procedure is implemented in order to guarantee the contents of transferred data. Data on the SDA line is used for bus arbitration of the I<sup>2</sup>C bus. The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on a bus. Master 1 and master 2 output the same data until point "a". After master 1 outputs "1" and master 2, "0", the SDA line of a bus is wired AND and the SDA line is pulled down to the low level by master 2. When the SCL line of a bus is pulled up at point "b", the slave device reads data on the SDA line, that is data in master 2. Data transmitted from master 1 becomes invalid. The state in master 1 is called "arbitration lost". A master device which loses arbitration releases the SDA pin and the SCL pin in order not to effect data transmitted from other masters with arbitration. When more than one master sends the same data at the first word, arbitration occurs continuously after the second word. Figure 2.9.11 Arbitration Lost The serial bus interface circuit compares levels of a SDA line of a bus with its those SDA pin at the rising edge of the SCL line. If the levels are unmatched, arbitration is lost and the AL (Bit3 in SBISRB) is set to "1". When the AL is set to "1", the MST and TRX are cleared to "0" and the mode is switched to a slave receiver mode. The AL is cleared to "0" by writing or reading data to or from the SBIDBR or writing data to the SBICRB. Figure 2.9.12 Example of when a Serial Bus Interface Circuit is a Master B #### (11) Slave address match detection monitor In the slave mode, the AAS (Bit2 in SBISR) is set to "1" when the received data is "GENERAL CALL" or the received data matches the slave address setting by I2CAR with an address recognition mode (ALS = 0). When a serial bus interface circuit operates in the free data format (ALS = 1), the AAS is set to "1" after receiving the first 1-word of data. The AAS is cleared to "0" by writing data to the SBIDBR or reading data from the SBIDBR. ### (12) GENERAL CALL detection monitor The AD0 (Bit1 in SBISR) is set to "1" when all 8-bit received data is "0" immediately after a start condition in a slave mode. The AD0 is cleared to "0" when a start or stop condition is detected on a bus. #### (13) Last received bit monitor The SDA value stored at the rising edge of the SCL is set to the LRB (Bit0 in SBISRB). In the acknowledge mode, immediately after an INTSBI interrupt request is generated, an acknowledge signal is read by reading the contents of the LRB. # 2.9.8 Data Transfer of I<sup>2</sup>C Bus #### (1) Device initialization For initialization of device, set the ACK in SBICRA to "1" and the BC to "000". Specify the data length to 8 bits to count clocks for an acknowledge signal. Set a transfer frequency to the SCK in SBICRA. Next, set the slave address to the SA in I2CAR and clear the ALS to "0" to set an addressing format. After confirming that the serial bus interface pin is high-level, for specifying the default setting to a slave receiver mode, clear "0" to the MST, TRX and BB in SBICRB, set "1" to the PIN, "10" to the SBIM, and "00" to bits SWRST1 and SWRST0. Note: The initialization of a serial bus interface circuit must be complete within the time from all devices which are connected to a bus have initialized to and device does not generate a start condition. If not, the data can not be received correctly because the other device starts transferring before an end of the initialization of a serial bus interface circuit. # (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. By writing "1" to the MST, TRX, BB and PIN, the start condition is generated on a bus and then, the slave address and the direction bit which are set to the SBIDBR are output. An INTSBI interrupt request occurs at the 9th falling edge of a 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 bits only when an acknowledge signal is returned from the slave device. - Note 1: Do not write a slave address to be output to the SBIDBR while data is transferred. If data is written to the SBIDBR, data to been outputting may be destroyed. - Note 2: The bus free must be confirmed by software within 98.0 $\mu$ s (the shortest transmitting time according to the I<sup>2</sup>C bus standard) after setting of the slave address to be output. Only when the bus free is confirmed, set "1" to the MST, TRX, BB, and PIN doesn't finish within 98.0 $\mu$ s, the other masters may start the transferring and the slave address data written in SBIDBR may be broken. Figure 2.9.13 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 completed, 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. #### 1. When the TRX is "1" (Transmitter mode) Test the LRB. When the LRB is "1", a receiver does not request data. Implement the process to generate a stop condition (Described later) and terminate data transfer. When the LRB is "0", the receiver requests next data. When the next transmitted data is other than 8 bits, set the BC, set the ACK to "1", and write the transmitted data to the SBIDBR. After writing the data, the PIN becomes "1", a serial clock pulse is generated for transferring a next 1 word of data from the SCL pin, and then the 1 word data is transmitted. After the data is transmitted, and an INTSBI interrupt request occurs. The PIN become "0" and the SCL pin is set to low level. If the data to be transferred is more than one word in length, repeat the procedure from the LRB test above. Figure 2.9.14 Example of when BC = "000", ACK = "1" ## 2. When the TRX is "0" (Receiver mode) When the next transmitted data is other than of 8 bits, set the BC again. Set the ACK to "1" and read the received data from the SBIDBR (Reading data is undefined immediately after a slave address is sent). After the data is read, the PIN becomes "1". A serial bus interface circuit outputs a serial clock pulse to the SCL to transfer next 1 word of data and sets the SDA pin to "0" at the acknowledge signal timing. An INTSBI interrupt request occurs and the PIN becomes "0". Then a serial bus interface circuit 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.9.15 Example of when BC = "000", ACK = "1" To make the transmitter terminate transmit, clear the ACK to "0" before reading data which is 1 word before the last data to be received. A serial bus interface circuit does not generate a clock pulse for the acknowledge signal by clearing ACK. In the interrupt routine of end of transmission, when the BC is set to "001" and read the data, PIN is set to "1" and generates a clock pulse for a 1-bit data transfer. In this case, since the master device is a receiver, the SDA line on a bus keeps the high level. The transmitter receives the high-level signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete. After 1-bit data is received and an interrupt request has occurred, generates the stop condition to terminate data transter. Figure 2.9.16 Termination of Data Transfer in Master Receiver Mode #### b. When the MST is "0" (Slave mode) In the slave mode, a serial bus interface circuit operates either in normal slave mode or in slave mode after losing arbitration. In the slave mode, the conditions of generating INTSBI are follows: - When the received slave address matches to the value set by the I2CAR - When a "GENERAL CALL" is received - At the end of transferring or receiving after matching of slave address or receiving of "GENERAL CALL" A serial bus interface circuit changes to a slave mode if arbitration is lost in the master mode. And an INTSBI interrupt request occurs when word data transfer terminates after losing arbitration. The behavior of INTSBI and PIN after losing arbitration are shown in Table 2.9.2. Table 2.9.2 The Behavior of INTSBI and PIN after Losing Arbitration | | When the arbitration occurs during transmission of slave address as a master | When the arbitration occurs during transmission of data as a master transmit mode | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------| | INTSBI | INTSIB is generated at th | e terminatin of word data. | | PIN | When the slave address matches the value set by I2CAR, the PIN is cleared to "0" by generating of INTSBI. When the slave address doesn't match the value set by I2CAR, the PIN keeps "1". | PIN keeps "1". | Check the AL (Bit3 in the SBISR), the TRX (Bit6 in the SBISR), the AAS (Bit2 in the SBISR), and the AD0 (Bit1 in the SBISR) and implements processes according to conditions listed in Table 2.9.3. | TRX | AL | AAS | AD0 | Conditions | Process | |-----|----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | 1 | 1 | 0 | A serial bus interface circuit loses arbitration when transmitting a slave address. And receives a slave address of which the value of the direction bit sent from another master is "1". | Set the number of bits in 1 word to the BC and write transmitted data to the SBIDBR. | | | 0 | 1 | 0 | In the slave receiver mode, a serial bus interface circuit receives a slave address of which the value of the direction bit sent from the master is "1". | | | | | 0 | 0 | In the slave transmitter mode, 1-word data is transmitted. | Test the LRB. If the LRB is set to "1", set the PIN to "1" since the receiver does not request next data. Then, clear the TRX to "0" release the bus. If the LRB is set to "0", set the number of bits in 1-word to the BC and write transmitted data to the SBIDBR since the receiver requests next data. | | 0 | 1 | 1 | 1/0 | A serial bus interface circuit loses arbitration when transmitting a slave address. And receives a slave address of which the value of the direction bit sent from another master is "0" or receives a "GENERAL CALL". | Read the SBIDBR for setting the PIN to "1" (Reading dummy data) or write "1" to the PIN. | | | | 0 | 0 | A serial bus interface circuit loses arbitration when transmitting a slave address or data. And terminates transferring word data. | A serial bus interface circuit is changed to slave mode. To clear AL to "0", read the SBIDBR or write the data to SBIDBR. | | | 0 | 1 | 1/0 | In the slave receiver mode, a serial bus interface circuit receives a slave address of which the value of the direction bit sent from the master is "0" or receives "GENERAL CALL". | Read the SBIDBR for setting the PIN to "1" (Reading dummy data) or write "1" to the PIN. | | | | 0 | 1/0 | In the slave receiver mode, a serial bus interface circuit terminates receiving of 1-word data. | Set the number of bits in 1 word to the BC and read received data from the SBIDBR. | Table 2.9.3 Operation in the Slave Mode Note: In the slave mode, if the slave address set in I2CAR is "00000000B", the TRX changes to "1" by receiving the start byte data "00000001B". # (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 clear "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 on a bus is pulled down by other devices, a serial bus interface circuit generates a stop condition after they release a SCL line. Figure 2.9.17 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 a serial bus interface circuit. Clear "0" to the MST, TRX and BB and set "1" to the PIN. 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. Test the BB until it becomes "0" to check that the SCL pin a serial bus interface circuit is released. Test the LRB until it becomes "1" to check that the SCL line on a bus is not pulled down to the low level by other devices. After confirming that a bus stays in a free state, generate a start condition with procedure (2). In order to meet setup time when restarting, take at least $4.7 \mu s$ of waiting time by software from the time of restarting to confirm that a bus is free until the time to generate a start condition. Note: When restarting after receiving in master receiver mode, because the divice doesn't send an acknowledgement as a last data, the level of SCL line can not be conrirmied by reading LRB. Therefore, confirm the status of SCL line by reading P5PRD register. Figure 2.9.18 Timing Diagram when Restarting # 2.9.9 Clocked-synchronous 8-Bit SIO Mode Control The following registers are used to control the serial bus interface (SBI) and monitor the operation in the clocked-synchronous 8-bit SIO mode. Figure 2.9.19 Control Register/Data Buffer Register/Status Register in SIO Mode (1) Figure 2.9.20 Control Register/Data Buffer Register/Status Register in SIO Mode (2) #### (1) Serial clock a. Clock source The SCK (Bits 2 to 0 in SBICRA) is used to select the following functions. #### 1. 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{SCK}$ pin. The $\overline{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.9.21 Automatic Wait Function #### 2. External (SCK = "111") An external clock supplied to the $\overline{SCK}$ pin is used as the serial clock. In order to ensure shift operation, a pulse width of at least 2-machine cycles is required for both high and low levels in the serial clock. The maximum data transfer frequency is 1 MHz (fc = 16.0 MHz). Figure 2.9.22 The Maximum Data Transfer Frequency in The External Clock Input #### b. Shift edge The leading edge is used to transmit data, and the trailing edge is used to receive data. # 1. Leading edge Data is shifted on the leading edge of the serial clock (at a falling edge of the $\overline{SCK}$ pin input/output). # 2. 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.9.23 Shift Edge #### (2) Transfer mode The SIOM (Bits 5 and 4 in SBICRA) 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 transmit 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 transmit new 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 SO pin is "1" from the time transmission starts until the first data bit is sent. When SIOF becomes "0", the shift register is cleared. So, output of an undefined value is not prevented at the start of the next transmission. 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. Transmitting data is ended by cleaning 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 (Bit3 in the SBISRB) 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.9.24 Transfer Mode Example: Program to stop transmitting data. (When external clock is used.) STEST1: TEST (SBISRB). SEF ; If SEF = 1 then loop JRS F, STEST1 STEST2: TEST (P5). 3 ; If $\overline{SCK} = 0$ then loop JRS T, STEST2 LD (SBICRA), 00000111B ; SIOS $\leftarrow$ 0 Figure 2.9.25 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 read from the SBIDBR by the interrupt service program. When the external clock is used, since shift operation is synchronized with the clock pulse provided externally, the received data should be read from SBIDBR before next serial clock is input. If the received data is not read, further data to be received is canceled. When the internal clock is used, the automatic wait function is executed until received data is read from SBIDBR. 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. Received data disappears if this data is not completely read before reception of the next data terminates. In this case, the next data received 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 (Bit3 in 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 is concluded by clearing the SIOS to "0", read the last data, and then switch the mode. Figure 2.9.26 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 transmission starts, a value which is the same as the last bit of previously transmitted data is output from the time SIOF is set to "1" until the falling edge of $\overline{\text{SCK}}$ occurs. Transmitting/receiving data is ended by cleaning the SIOS to "0" by the INTSBI interrupt service program or setting the SIONH 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 SBISRB) to be sensed. The SIOF becomes "0" after transmitting/receiving is complete. When the SIONH 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.9.27 Transmit/Receive Mode (Example: Internal clock) Figure 2.9.28 Transmitted Data Hold Time at End of Transmit/Receive # 2.10 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.10.1 Configuration Figure 2.10.1 Remote Control Signal Preprocessor # 2.10.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". Figure 2.10.2 Remote Control Receive Control Register 1, 2 | Remote Conti | ol Receive ( | Counter Register | | | | | | | |--------------|--------------|---------------------------|--------------|----------|----------|----------------|----------------------------|-------------| | RXCTR | 7 | 6 5 | 4 3 | 2 | 1 | 0 | Read Only | | | (00FEAH) | | | | | | | (Initial value: 0000 0000) | ) | | | I | 1 | 1 | | | | | | | Remote Conti | ol Receive [ | Data Buffer Registe | er | | | | | | | RXDBR | 7 | 6 5 | 4 3 | 2 | 1 | 0 | Read Only | | | (00FEBH) | | | | | | | (Initial value: 0000 0000) | ) | | | | ' | • | | | | | | | Remote Conti | ol Receive S | Status Register | | | | | | | | RXSR | 7 | 6 5 | 4 3 | 2 | 1 | 0 | Read Only | | | (00FECH) | 1 | RBÇTM | 1 | OVFF | SRM | RNCM | (Initial value: 0000 *000) | | | | | 1 | | | | | | <del></del> | | | RBCTM | Receive bit count monitor | er value | | | | | | | | | monitor | | 0: N= =: | | | | | | | OVFF | 8-bit up counter of | verflow flag | | erflow | | | | | | | | | 1: Over | | | | Read | | | SRM | Data buffer regist | er input | | | | ounter < CREGA | only | | | | monitor | | 1: Uppe | r 4 bits | of 8-bit up co | ounter ≥ CREGA | | | | D.11014 | Remote control s | • | | | | | | | | RNCM | after passing thro | ough noise | | | | | | | | | | | | | | | | | | *: Don't car | e | | | | | | | Figure 2.10.3 Remote Control Receive Counter Register, Data Buffer Register, Status Register **RPOLS EINT RMM** Interrupt Source Measurement Mode Receive end Receive end Table 2.10.1 Combination of Interrupt Source and Measurement Mode ## 2.10.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. RNC Minimum Signal Pulse Width Maximum Noise Width to be Eliminated 000 $(2^5 + 5)/fc$ 001 $(2.31 \mu s)$ $(2^2 \times 7 - 1)/fc$ $(1.69 \mu s)$ 010 $(2^8 + 5)/fc$ (16.31 µs) $(2^5 \times 7 - 1)/fc$ $(13.88 \mu s)$ 011 $(2^9 + 5)/fc$ (32.31 µs) $(2^6 \times 7 - 1)/fc$ $(27.88 \mu s)$ 100 $(2^{10} + 5)/fc$ $(2^7 \times 7 - 1)/fc$ (55.88 µs) $(64.31 \mu s)$ 101 $(2^{11} + 5)/fc$ (128.3 $(2^8 \times 7 - 1)/fc$ (111.9 µs) μs) 110 $(2^{13} + 5)/fc$ (512.3 $(2^{10} \times 7 - 1)/fc$ (447.9 μs) μs) (2<sup>14</sup> + 5)/fc $(2^{11}\times 7-1)/\text{fc}$ (1.024 ms) (895.9 μs) 111 Table 2.10.2 Noise Elimination Time Setting (fc = 16 MHz) ### 2.10.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.10.4 Rising Edge Interrupt Timing Chart (RPOLS = 0) Figure 2.10.5 Falling Edge Interrupt Timing Chart (RPOLS = 0) Figure 2.10.6 Rising/Falling Edge Interrupt Timing Chart ## (2) 8-bit receive end interrupts and measurement modes By determining one-cycle remote control signal as one-bit data set to "0" or one-pulse width remote control signal as one-bit data set to "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.10.7 Overflow Interrupt Timing Chart Figure 2.10.8 8-Bit Receive End Interrupt Timing Chart (PROLS = 0) Table 2.10.3 Count Clock for Remote Control Preprocessor Circuit (at fc = 16 MHz) | Count Clock (RCCK) | Resolution [µs] | Maximum Setting Time [ms] | |--------------------|-----------------|---------------------------| | 00 | 4 | 1.024 | | 01 | 16 | 4.096 | | 10 | 64 | 16.38 | | 11 | 256 | 65.53 | # 2.11 8-Bit AD Converter (ADC) The TMP88CS38/CM38A/CP38A has a 8-bit successive approximation type AD converter. ## 2.11.1 Configuration Figure 2.11.1 shows the circuit configuration of the AD converter. The AD converter includes control registers ADCCRA and ADCCRB, conversion result registers ADCDR1 and ADCDR2, a DA converter, a sample hold circuit, a comparator, and sequential transducer circuit. To use P5 and P6 as analog inputs, clear the output latch for P5 and P6 to "0". Also, clear the input/output control registers (P5CR1 and P6CR) to "0". Figure 2.11.1 AD Converter (ADC) ## 2.11.2 Control Register The following register are used foe AD converter. - AD converter control register 1 (ADCCRA) - AD converter control register 2 (ADCCRB) - AD conversion result register (ADCDR1/ADCDR2) - (1) AD converter control register 1 (ADCCRA) ADCCRA control AD conversion start, AD operation mode select, analog input control and analog input channel select. (2) AD converter control register 2 (ADCCRB) ADCCRB control AD conversion time select. (3) AD conversion result register (ADCDR1) AD conversion result is stored after end of conversion. (4) AD conversion result register (ADCDR2) For monitoring status of conversion. Figure 2.11.2 and Figure 2.11.3 show AD converter control register. AD Converter Control Register 1 **ADCCRA** 0 5 4 (0000EH) **ADRS** AMD AINDS "0" SAIN (Initial value: 0001 0000) The ADRS bit is automatically cleared after starting AD conversion. During AD conversion, setting ADRS to "1" initializes the ADRS bit **ADRS** AD conversion start and resets conversion. 0: 1: AD conversion restart 00: STOP mode 01: Software start mode AMD AD Operation mode select 00: Trigger start mode 11: reserved R/W 0: Analog input enable **AINDS** Analog input control 1: Analog input disable 000: select AIN0 001: select AIN1 010: select AIN2 Analog input channel 011: select AIN3 SAIN selection 100: select AIN4 101: select AIN5 110: -111: -Select analog input when AD converter stops. Note 1: When the analog input is all use disabling, the AINDS should be set to "1". Note 3: During conversion, do not perform output instruction to maintain a precision for all of the pins. And port near to analog input, do not input intense signaling of change. Note 4: The ADRS is automatically cleared to "0" after starting conversion. Note 5: Always set bit 3 in ADCCRA to "0". Note 6: Do not set ADRS (Bit7 in ADCCRA) to "1" during AD conversion. Re-set it after confirming with EOCF (Bit5 in ADCDR2) that the conversion is completed or after generation an interrupt signal (INTADC) (by the interrupt processing routine or the like). Note 7 In the trigger mode, the system does not accept the second and subsequent triggers after accepting the first trigger for starting AD conversion. To restart AD conversion by a trigger, set AMD (Bits 6 and 5 in ADCCRA) to "00" and then put the system in trigger start mode again (with AMD = "10"). Note 8: When the system enters STOP mode, AD converter control register 1 (ADCCRA) is initialized. Re-set this register after the system reenters NORMAL mode. AD Converter Control Register 2 **ADCCRB** ACK (0000FH) (Initial value: \*\*0\* 000\*) Conversion DV1CK = 0DV1CK = 1 **ACK** fc = 16 MHz fc = 8 MHz fc = 16 MHz fc = 8 MHztime 000 Reserved 001 010 **ACK** AD conversion time select 011 156/fc [s] 19.5 39 R/W 100 312/fc [s] 19.5 39.0 39 78 101 624/fc [s] 78 39.0 78.0 156 110 1248/fc [s] 78.0 156 111 Reserved Note 1: Do not use setting except the above liset. Note 2: Set conversion time by analog reference voltage (VDD) as follows. $V_{DD} = 4.5 \text{ to } 5.5 \text{ V } (15.6 \,\mu \text{ or more})$ Note 3: Always set bit0 and bit5 in ADCCRB to "0" and set bit4 in ADCCRB to "1". Note 4: When a read instruction for ADCCRB, bit6 to 7 in ADCCRB read in as undefined data. Note 5: fc: High-frequency clock [Hz] When the system enters STOP mode, AD converter control register 2 (ADCCRA) is initialized. Re-set this register after the system reenters NORMAL mode. Figure 2.11.2 AD Converter Control Register Figure 2.11.3 AD Converter Result Register ## 2.11.3 AD Converter Operation The high side of an analog reference voltage is applied to VDD, and the low side is applied to VSS pin. Dividing a reference voltage between VDD and VSS to the voltage corresponding to a bit by a rudder resistance and comparing it with the analog input voltage converts the AD. | Mode | Function | |---------------------------|-----------------------------------------------------------------------------------------------------------| | AD converter disable mode | AD converter stop mode. This mode is always used to change modes. | | Software start mode | Single AD conversion of 1 channel which specifies input. | | Trigger start mode | Single AD conversion of 1 channel which specifies input (AD8TRG) from Key-on wakeup circuit as a trigger. | Table 2.11.1 AD Converter Operation Mode ## 2.11.4 Interrupt Interrupt request signal occur at the timing when the EOCF bit is set to "1". ## 2.11.5 AD Converter Operation Modes When the MCU places in the STOP mode during the AD conversion, the conversion is stopped and the ADCDR2 content becomes indefinite. After returning from the STOP mode, the EOCF and INTADC does not occur. Therefore, the AD conversion must be restarted after returning from the STOP mode. Figure 2.11.4 AD Conversion Timing chart #### (1) AD conversion in STOP mode When the AD converter stop mode is specified during AD conversion, the AD conversion is stopped immediately. The AD conversion is not implemented, so the undefined value is not written to the AD conversion result register. The AD conversion start commands which occur is the AD converter stop mode are ignored. This mode is automatically selected by reset. This mode is used to change the AD converter operation mode. ### (2) Single mode When the AMD (Bit6, 5 to in ADCCRA) set to "01", the AD conversion signal mode This mode does AD conversion of single channel, and conversion result is stored in ADCDR1. The EOCF (Bit5 in ADCDR2) is set to "1" at end of one conversion, and an interrupt request signal occurs. The EOCF is cleared to "0" by reading the AD conversion registers. But when the AD conversion is restarted before the ADCDR is read, the EOCF is cleared to "0" and the last AD conversion result is maintained till next conversion end. Do not set ADRS (Bit7 in ADCCRA) during AD conversion. Again set it after confirming with EOCF (Bit5 in ADCDR2) that the conversion is completed or after generating an interrupt signal (INTADC) (by the interrupt processing routine or the like). Figure 2.11.5 Single Mode Example: The AD conversion starts after $19.5 \mu s$ (at fc = $16 \mu$ ) and AIN4 pin are selected as the conversion time and the analog input channel. Confirming the EOCF, the converted value is read out, and the 8 bits data is stored to address 009EH in RAM. The operation mode is a signal mode. ``` ;AIN SELECT (P5), 00000000B LD LD (P5CR1), 00000000B LD (P6), 00000000B (P6CR), 00000000B LD LD (ADCCRA), 00100100B Selects AIN4, selects the software start mode (ADCCRB), 00011000B Selects the conversion time and the operation mode. ; AD CONVERT START SET (ADCCRA). 7 ADRS = 1 SLOOP: EOCF = 1? TEST (ADCCR2). 5 JRS T, SLOOP ; RESULT DATA READ (9EH), (ADCDR1) ``` ### (3) Trigger start mode The AD conversion of a specified single channel is executed when input (AD8TRG) from Key-on wakeup circuit is set as trigger, the conversion result is stored in the ADCDR1. The EOCF (Bit5 in ADCDR2) is set to "1" at end of one conversion, and an interrupt request signal occurs. It needs to be set the STOP mode by bit5 to 6 in ADCCRA before the AD conversion is executed again. ## 2.11.6 Analog Input Voltage and AD Conversion Result The analog input voltage is corresponded to the 8-bit digital value converted by the AD as shown in Figure 2.11.6. Figure 2.11.6 Analog Input Voltage and AD Conversion Result (typ.) ## 2.11.7 STOP Modes during AD Conversion When standby mode (STOP mode) is entered forcibly during AD conversion, the AD convert operation is suspended and the AD converter is initialized. (ADCCRA and ADCCRB are initialized to initial value.) Also, the conversion result is indeterminate. (Conversion results up to the previous operation are cleared, so be sure to read the conversion results before entering standby mode.) When restored from standby mode, AD conversion is not automatically restarted, so it is necessary to restart AD conversion after setting ADCCRA and ADCCRB. Note that since the analog reference voltage is automatically disconnected, there is no possibility of current flowing into the analog reference voltage. #### 2.11.8 Notice of AD Converter ### (1) Analog input voltage range Voltage range of analog input (AIN0 to AIN5) must be forced from VSS to VDD. If input voltage of which out of range is forced to analog input pin, AD conversion result to unknown. Also, this cause other analog input pin unstable. ## (2) I/O port with analog input Analog input pins (AIN0 to AIN5) are also I/O port. During AD conversion using any analog input pin, don't operate other I/O port with analog input. Because, AD accuracy would be worse. Also, other electrically swinging port without analog input may cause noise to near analog input pin. #### (3) Reduce to noise Figure 2.11.7 is shown as internal equivalent circuit of analog input pin. Increasing output impedance of analog input supply, cause noise or other non-good condition. Therefore, output impedance of analog input supply must be less than 5 k $\Omega$ . And we recommend to connect capacitance to analog input pin. Figure 2.11.7 Analog Input Equivalent Circuit and Analog Input Pin # 2.12 Key-on Wakeup In this MCU the IDLE mode is also released by low active port inputs. The low input voltage is regulated higher than the other normal ports. Therefore the ports can be enabled by analog input level. ## 2.12.1 Configuration Figure 2.12.1 Key-on Wakeup Control Circuit ## 2.12.2 Control P53 to P56 and P60, P61 ports can be controlled by IDLE control register (IDLECR). It can be configured as enable/disable in one-bit unit. When those pins are used by IDLE mode release, those pins must be set input mode (P5CR1, P5, P6CR, P6, ADCCRA). IDLE mode is controlled by system control register 2 (SYSCR2) and maskable interrupts. After the individual enable flag (EF5) is set to "1", the IDLE mode must starts. When enabled port input generates INTKWU interrupt, the IDLE mode is released. Low level input voltage in those ports is regulated to less than $VDD \times 0.65$ (V). IDLE port monitorring register (IDLEIN) can be used to check state of ports. INTADEN can enable to generate AD8TRG, which is used as trigger of AD converter trigger start mode. Noise reject circuit eliminate noise, which is less than 24 µs period. | DLECR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |------------------|---------------------------|------------------|-------------------------------------------------------------|-----------------------------|-------------|----------------------------------------------|-----------------------------------------------------------------------------------------|------------------|----------------------------|---------------| | 00FD0H) | INTAD<br>EN | * | IDLE5<br>EN | IDLE4<br>EN | IDLE3<br>EN | IDLE2<br>EN | IDLE1<br>EN | IDLE0<br>EN | (Initial value: 0*00 0000) | | | | INTADE | N G | eneration o | AD8TRG | | 0:<br>1: | Disable<br>Enable | | | | | | IDLE5E | ۱ R | elease IDLE | mode by | KWU5 | 0:<br>1: | Disable<br>Enable | | | | | | IDLE4E | ۱ R | elease IDLE | mode by | KWU4 | _ | Disable<br>Enable | | | | | | IDLE3E1 | ۱ R | elease IDLE | mode by | KWU3 | 0:<br>1: | Disable<br>Enable | | | Write<br>only | | | IDLE2E | ۱ R | elease IDLE | mode by | KWU2 | | Disable<br>Enable | | | | | | IDLE1E | ۱ R | elease IDLE | mode by | KWU1 | 0:<br>1: | Disable<br>Enable | | | | | | IDLE0E1 | ۱ R | elease IDLE | mode by | KWU0 | 0:<br>1: | Disable<br>Enable | | | | | | *: Don't ca | ıre | | | | | | | | | | LE Port Mo | nitoring Reo | - | 5 | 4 | 3 | | | | | | | 00FD0H) | | 6 | J | 4 | 3 | 2 | 1 | 0 | | | | JOI DOM) | * | * | IDLE5 | IDLE4<br>IN | IDLE3<br>IN | IDLE2 | 1<br>IDLE1<br>IN | 0<br>IDLE0<br>IN | (Initial value: **00 0000) | | | טו טטרון | | * | IDLE5 | IDLE4<br>IN | IDLE3 | IDLE2 | IDLE1 | IDLE0<br>IN | (Initial value: **00 0000) | | | оог <i>Б</i> ОП) | * | * | IDLE5<br>IN | IDLE4<br>IN<br>KWU5 | IDLE3 | IDLE2<br>IN<br>0: | IDLE1<br>IN<br>"0" detect | IDLE0<br>IN | (Initial value: **00 0000) | | | OOI DUIT) | * IDLE5IN | * In In | IDLE5<br>IN<br>put level of | IDLE4<br>IN<br>KWU5 | IDLE3 | IDLE2<br>IN 0:<br>1:<br>0: | IDLE1<br>IN<br>"0" detect<br>"1" detect | IDLE0<br>IN | (Initial value: **00 0000) | Read | | ooi Duri) | * IDLE5IN | * In In | IDLE5<br>IN<br>put level of<br>put level of | IDLE4<br>IN<br>KWU5<br>KWU4 | IDLE3 | IDLE2<br> IN | "0" detect "1" detect "0" detect "1" detect "1" detect "0" detect | IDLE0<br>IN | (Initial value: **00 0000) | Read<br>only | | ooi Duri) | * IDLE5IN IDLE4IN IDLE3IN | * In In In In In | IDLE5<br>IN<br>put level of<br>put level of<br>put level of | IDLE4 IN KWU5 KWU4 KWU3 | IDLE3 | 0:<br>1:<br>0:<br>1:<br>0:<br>1:<br>0:<br>1: | "0" detect "1" detect "0" detect "1" detect "1" detect "0" detect "1" detect "0" detect | IDLE0<br>IN | (Initial value: **00 0000) | | Figure 2.12.2 Key-on Wakeup Control Register # 2.13 Pulse Width Modulation Circuit Output The TMP88CS38/CM38A/CP38A has four 12-bit resolution PWM output channels including two 14-bit resolution selectable and six 7-bit resolution PWM output channels. DA 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 ( $\overline{\text{PWM0}}$ ) to P47 ( $\overline{\text{PWM7}}$ ), P50 ( $\overline{\text{PWM8}}$ ), P51 ( $\overline{\text{PWM9}}$ ). PWM output is negative logic. 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". In STOP mode, PWM output pin keeps high-level. When operation mode is changed from STOP mode to NORMAL mode, PWM control register (PWMCR1A, PWMCR2A, PWMCR1B, PWMCR2B) are initialized. # 2.13.1 Configuration Figure 2.13.1 PWM Output Circuit ## 2.13.2 PWM Output Wave Form ## (1) $\overline{PWM0}$ to $\overline{PWM1}$ Outputs PWM0 and PWM1 output can be selected 12-bit or 14-bit resolution PWM outputs. ### 1. 12-bit resolution PWM output When these are used as 12-bits PWM output, one period is $T_M = 2^{13}/\text{fc}$ [s] (When DV1CK = 0) and $T_M = 2^{14}/\text{fc}$ [s] (When DV1CK = 1) and sub period is $T_S = T_M/16$ . The lower 8 bits of the PWM data latch controls the low level pulse width with a cycle of Ts. The lower 8 bits of the PWM data latch is n (n = 1 to 255), the low level pulse width with a cycle becomes $n \times t_0$ [s] ( $t_0 = 2/fc$ [s] when DV1CK = 0, $t_0 = 4/fc$ [s] when DV1CK = 1). The upper 4 bits of the PWM data latch controls a position to output the additional pulses. When the upper 4 bits of the PWM data latch is m, the additional pulses are generated in each of m periods out of 16 periods contained in a $T_M$ period. The relationship between the 4-bit data and the position of Ts period where the additional pulses are generated is shown in Table 2.13.1. | | Bit Position of the Lower 4 Bits of PWMDRxH | | WMDRxH | Relative position of $T_S$ in $T_M$ period where the additional | | |----|---------------------------------------------|-------|--------|-----------------------------------------------------------------|--------------------------------------------------------------| | | Bit11 | Bit10 | Bit9 | Bit8 | pulse is generated. (Number of T <sub>S (I)</sub> is listed) | | a) | 0 | 0 | 0 | 0 | No additional pulse | | b) | 0 | 0 | 0 | 1 | 8 | | c) | 0 | 0 | 1 | 0 | 4, 12 | | d) | 0 | 1 | 0 | 0 | 2, 6, 10, 14 | | e) | 1 | 0 | 0 | 0 | 1, 3, 5, 7, 9, 11, 13, 15 | Table 2.13.1 The Addition Pulse (12-bit mode) Note 1: The bit positions of a) to e) can be combined. Note 2: If the low order eight bits for the PWM data latch are set to "FFH", be sure to set the high order four bits for this latch to "00H". #### 2. 14-bit resolution PWM output When these are used as 14-bit PWM output, one period is $T_M = 2^{15}/fc$ [s] (When DV1CK = 0) and $TM = 2^{16}/fc$ [s] (When DV1CK = 1) and sub period is $T_S = T_M/64$ . The lower 8 bits of the PWM data latch controls the low level pulse width with a cycle of Ts. The lower 8 bits of the PWM data latch is n (n = 1 to 255), the low level pulse width with a cycle becomes $n \times t_0$ [s] ( $t_0 = 2/fc$ [s] when DV1CK = 0, $t_0 = 4/fc$ [s] when DV1CK = 1). The upper 6 bits of the PWM data latch controls a position to output the additional pulses. When the upper 6 bits of the PWM data latch is m, the additional pulses are generated in each of m periods out of 64 periods contained in a $T_M$ period. The relationship between the 6-bit data and the position of Ts period where the additional pulses are generated is shown in Table 2.13.2. | | Bit Po | it Position of the Lower 6 Bits of PWMDRxH | | DRxH | Relative position of T <sub>S</sub> in T <sub>M</sub> period where the additional | | | |----|--------|--------------------------------------------|-------|-------|-----------------------------------------------------------------------------------|------|--------------------------------------------------------------------| | | Bit13 | Bit12 | Bit11 | Bit10 | Bit9 | Bit8 | pulse is generated. (Number of T <sub>S (I)</sub> is listed) | | a) | 0 | 0 | 0 | 0 | 0 | 0 | No additional pulse | | b) | 0 | 0 | 0 | 0 | 0 | 1 | 32 | | c) | 0 | 0 | 0 | 0 | 1 | 0 | 16, 48 | | d) | 0 | 0 | 0 | 1 | 0 | 0 | 8, 24, 40, 56 | | e) | 0 | 0 | 1 | 0 | 0 | 0 | 4, 12, 20, 28, 36, 44, 52, 60 | | f) | 0 | 1 | 0 | 0 | 0 | 0 | 2, 6, 10, 14, 18, 22, 26, 30, 34, 38, 42, 46, 50, 54, 58, 62 | | g) | 1 | 0 | 0 | 0 | 0 | 0 | 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, 33, 35, | | | | | | | | | 37, 39, 41, 43, 45, 47, 49, 51, 53, 55, 57, 59, 61, 63 | Table 2.13.2 The Addition Pulse (14 bit mode) Note 1: The bit positions of a) to g) can be combined. Note 2: If the low order eight bits for the PWM data latch are set to "FFH", be sure to set the high order 6 bits for this latch to "00H". ## (2) PWM2 to PWM3 Outputs PWM2 and PWM3 output are 12-bit resolution PWM outputs. One period is $T_M = 2^{13}/fc$ [s] (When DV1CK = 0) and $T_M = 2^{14}/fc$ [s] (When DV1CK = 1) and sub period is $T_S = T_M/16$ . The lower 8 bits of the PWM data latch controls the low level pulse width with a cycle of Ts. The lower 8 bits of the PWM data latch is n (n = 1 to 255), the low level pulse width with a cycle becomes $n \times t_0$ [s] ( $t_0 = 2/fc$ [s] when DV1CK = 0, $t_0 = 4/fc$ [s] when DV1CK = 1). The upper 4 bits of the PWM data latch controls a position to output the additional pulses. When the upper 4 bits of the PWM data latch is m, the additional pulses are generated in each of m periods out of 16 periods contained in a T<sub>M</sub> period. The relationship between the 4-bit data and the position of Ts period where the additional pulses are generated is shown in Table 2.13.1. ### (3) PWM4 to PMW9 Outputs These are 7-bit resolution PWM outputs. One period is $T_N = 2^8/fc$ [s] (When DV1CK = 0) and $T_N = 2^9/fc$ [s] (When DV1CK = 1). The 7 bits of the PWM data latch controls the low level pulse width with a cycle of $T_N$ . The lower 7 bits of the PWM data latch is k (k = 1 to 127), the low level pulse width with a cycle becomes $k \times t_0$ [s] ( $t_0 = 2/fc$ [s] when DV1CK = 0, $t_0 = 4/fc$ [s] when DV1CK = 1). Figure 2.13.2 PWM Output Waveform ### 2.13.3 Control PWM output is controlled by PWM control register (PWMCR1A, PWMCR1B, PWMCR2A, PWMCR2B) and PWM data buffer register (PWMDBR1, PWMDBR2). Figure 2.13.3 PWM Control Register 1A/1B and PWM Data Buffer Register 1 Figure 2.13.4 PWM Control Register 2A/2B and PWM Data Buffer Register 2 Figure 2.13.5 DIVIDER Control Register #### (1) Internal counter The internal counter of PWM outputs is a free running counter. The all bits of counter are set to "1" and are not counted up at one of the following conditions. - 1. During reset - 2. The operation mode is changed to STOP mode. - 3. Setting ABORTx (x: 1, 2) to "1". - 4. The START3 to 0 are "0" in 12-bit PWM outputs. The START9 to 4 are "0" in 7-bit PWM outputs. - 5. The lower 8-bit of PWM data latch in 12-bit PWM outputs is "00H". The PWM data latch in 7-bit PWM outputs is "00H". ## (2) Outputs control and programming of PWM data The PWM outputs are fixed to a high-level immediately when the ABORTx (x: 1, 2) is set to "1". The PWM outputs starts the operation when the STARTx (x: 0 to 9) is set to "1". The data from the transfer buffer to a PWM data latch is transferred when the all bits of internal counter are set to "1". Therefore, the data is transferred to a PWM data latch immediately when the internal counter is initialized. And the data is transferred to a PWM data latch at the beginning of the next cycle when all bits of the internal counter are not set to "1". The sequence of writing the output data to PWM data latches is shown as follows; ### 1. $\overline{PWM0}$ to $\overline{PWM1}$ - a) Write the channel number of PWM data latch to PWMCHS1 (Bit2 and 1 in PWMCR1B) and clear PWMHL (Bit0 in PWMCR1B) to "0". - b) Write the lower 8-bit PWM output data to PWMDBR1. - c) Write the channel number of PWM data latch to PWMCHS1 and set PWMHL to "1". - d) Write the upper 4-bit or 6-bit PWM output data to PWMDBR1. - e) Select the resolution of PWM output to RESOLUTIONx (x: 0, 1) (Bit0 and 1 in PWMCR1A) and set STARTx (x: 0, 1) (Bit2 and 3 in PWMCR1B) to "1". Note: PWM output data must be write to PWMDBR1 in the order of the lower 8-bit PWM output data, the upper 4-bit (or 6-bit) PWM output data. If the upper 4-bit (or 6-bit) PWM output data is write to PWMDBR1, the lower 8-bit PWM output data is not changed (except when lower 8-bit PWM output data is "00H"). ## 2. $\overline{PWM2}$ to $\overline{PWM3}$ - a) Write the channel number of PWM data latch to PWMCHS1 and clear PWMHL to "0". - b) Write the lower 8-bit PWM output data to PWMDBR1. - c) Write the channel number of PWM data latch to PWMCHS1 and set PWMHL to "1". - d) Write the upper 4-bit PWM output data to PWMDBR1. - e) Set STARTx (x: 2, 3) to "1". Figure 2.13.6 Waveform of PWM0 to PWM3 Note: PWM output data must be write to PWMDBR1 in the order of the lower 8-bit PWM output data, the upper 4-bit (or 6-bit) PWM output data. If the upper 4-bit (or 6-bit) PWM output data is write to PWMDBR1, the lower 8-bit PWM output data is not changed (except when lower 8-bit PWM output data is "00H"). # 3. $\overline{PWM4}$ to $\overline{PWM9}$ - a) Write the channel number of PWM data latch to PWMCHS2. - b) Write the lower 7-bit PWM output data to PWMDBR2. - c) Set STARTx (x: 4 to 9) to "1". Figure 2.13.7 Waveform of PWM4 to PWM9 Example: at fc = 16 MHz, DV1CK = 0 | LD | (CGCR), 00H | ; | DV1CK = 0 | |----|----------------|---|----------------------------------------------------| | LD | (PWMCR1B), 00H | ; | Select the lower 8 bits of PWM0 output data latch | | LD | (PWMDBR1), 80H | ; | $32 \mu s \div 4/fc = 80H$ | | LD | (PWMCR1B), 01H | ; | Select the upper 6 bits of PWM0 output data latch | | LD | (PWMDBR1), 00H | ; | No additional pulse = 00H | | LD | (PWMCR1B), 02H | ; | Select the lower 8 bits of PWM0 output data latch | | LD | (PWMDBR1), 40H | ; | $16 \ \mu s \div 4/fc = 40H$ | | LD | (PWMCR1B), 03H | ; | Select the upper 4 bits of PWM0 output data latch | | LD | (PWMDBR1), 01H | ; | Additional pulse (Ts (8)) = 01H | | LD | (PWMCR1A), 0DH | ; | Start PWM0 and PWM1, | | | | | PWM0 : 14-bit resolution, PWM1 : 12-bit resolution | | LD | (PWMCR2B), 00H | ; | Select PWM4 output data latch | | LD | (PWMDBR2), 20H | ; | $8 \mu s \div 2/fc = 20H$ | | LD | (PWMCR2A), 01H | ; | Start PWM4 | # 2.14 Test Video Signal Output for Adjusting TV Screen The TMP88CS38/CM38A/CP38A has a built-in video signal output circuit to output necessary signal for TV screen adjustment. Picture pattern : Total eight types, monochromatic inversion possible Output format : Three states (H, L, High-Z) output Comp.sync duration time L output Black level/pedestal duration time High-Z output White level duration time H output # 2.14.1 Configuration Figure 2.14.1 Test Video Signal Output Circuit # 2.14.2 Control The test video signal output circuit can be controlled with the test video signal control register. | TVSCR | 7 | 6 5 | 4 | 3 | 2 | 1 | 0 | | | | | |----------|--------------------------------------|------------------------------------|----------------------------------|--------------|------------------|--------------------------------------------------------------------------------|-------------|------------------------------|------------|--|--| | (00FE6H) | SGEN SGVBLK SGPAL SGIV SGCHS | | | | | SGPAT | "0" | (Initial value: 0000 0000) | ) | | | | | SGEN | SG functio | n selection | | 0: | Disable<br>Enable | | | | | | | | SGVBLK | Picuture s | gnal for VE | BLK duration | 1:<br>n 0:<br>1: | Output No output | | | _ | | | | | SGPAL | PAL/NTS0 | selection | | 0: | NTSC<br>PAL | | | | | | | | SGIV Pattern monochromatic inversion | | | | | No inversion | on | | - | | | | | SGCHS | OSD sync | OSD synchronous signal selection | | | | nal circu | it | Write only | | | | | SGPAT | GPAT Display pattern | | | | 000: Black on the whole screen 001: White on the whole screen 010: Cross hatch | | | | | | | | | | | | 01 | ປ:Cross natc<br>1:Cross dot ເ<br>0:Cross bar | | | | | | | | | | | | 10 | | • • • | side/black on the lower side | | | | | | | | | | | 1:H resolutio | | | | | | | | | est video sign<br>Clear the bit2 a | • | | | orrectly wher | n fc is not | t 16 MHz. | | | | Figure 2.14.2 Test Video Signal Control Register # 2.14.3 Functions Video signal output is to generate monochromatic picture 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. Table 2.14.1 Display Pattern and TV Screen | <br>Display pattern | TV screen | | |--------------------------------------------------------------|-----------|--| | 000<br>(Black on the whole surface) | | | | 001<br>(White on the whole surface) | | | | 010<br>(Cross hatch) | | | | 011<br>(Cross dot) | | | | 100<br>(Cross bar) | | | | 101<br>(White on the upper side/<br>black on the lower side) | | | | 110<br>(H signal pattern) | | | | 111<br>(H resolution pattern) | | | There are three states of the output to generate picture signal with the external circuit of the resistance divided voltage. # 2.15 On-screen Display (OSD) Circuit The TMP88CS38/CM38A/CP38A features a built-in on-screen display circuit used to display characters and symbols on the TV screen. There are 384 characters and any characters can be displayed in an area of 32 columns $\times$ 12 lines (Include 2 columns for solid space). 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: (1) Number of character fonts: 384 (2) Number of display characters: 384 (32 columns × 12 lines) (3) Composition of character: Horizontal 16 × vertical 18 dots (4) Character sizes: 3 kinds for large, middle and small characters (Selectable line by line) (5) Character ornamentation function Fringing function Smoothing function Slant function (Italics) Blinking function Underline (6) Solid space (7) Area plane function: 2 planes (8) Full-raster blanking function (9) Display colors Character colors: 8 or 15 colors (Selectable character by character) Fringe color: 8 or 15 colors (Selectable page by page) Background color: 8 or 15 colors (Selectable page by page) Area plane color: 8 or 15 colors (Selectable each of 2 planes) Raster color: 8 or 15 colors (Selectable page by page) (10) Display position: 256 horizontal steps and 512 vertical steps for code plane : 512 horizontal steps and 512 vertical steps for Area plane (11) Window function: 512 vertical steps (12) Half transparency output function The TMP88CS38/CM38A/CP38A outputs OSD through 3 planes; code, area, and raster. 3 planes function independently. In addition, they are displayed simultaneously. There is the priority among these 3 planes, so they are displayed on a screen according to the priority. These 3 planes have the priority such as Code > Area > Raster. # 1. Code plane OSD character is displayed on the code plane. The code plane consists of 32 characters $\times$ 1 row and a total of 12 planes. The 12 planes have the priority such as code 1 > code 2 > ... > code 11 > code 12. On the code plane, characters of $16\times18$ dots is displayed. These fonts are called characters, and read from character ROM and display memory through the character code on the display memory. ### 2. Area plane The area on a screen is displayed on the area plane. The area plane can display 2 square areas of any size by specifying coordinates. The 2 planes have the priority such as area plane 1 > area plane 2. # 2.15.1 Configuration Figure 2.15-1 OSD Circuit ### 2.15.2 Character ROM and Display Memory # (1) Character ROM The character ROM contains 384 character fonts. The user can set fonts as desired. The character ROM consists of 384 characters in 16 × 18 dots (Character codes 000H to 17FH). Each dot corresponds to one bit in the character ROM. 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 corresponding to a character code is determined by the following expression: Start address in character ROM = $CRA \times 40H + 20000H$ Since character code 000H is used as blank character, the character font for this character code cannot be changed. Write "0" in the data of character code 000H. Write the data "FFH" to all unused address (5th bit of an address is "1" and also the lower 4 bits of an address are 2H to FH) in character ROM. Figure 2.15-2 (a) shows an example of the character font configuration for the character code 000H and 001H, together with the ROM addresses and data. Figure 2.15.2 (b) shows the character ROM dump list for these 2 character fonts. Note 1: CRA: Character code (000H to 17FH). Note 2: A data can not be read from character ROM by software. Note 3: When ordering a mask, load the data to character ROM at addresses 20000H to 25FFFH. And the data in unused are of character ROM are must be specified to FFH. Figure 2.15-2 Character Font Configuration and ROM Dump List ### (2) Display memory Each character of the 384 characters displayed in 32 columns × 12 lines consists of 16 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. 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.15.5.7 (1). Note: The display memory is in an unknown state at reset. Display memory configuration Figure 2.15-3 Display Memory Bit Configuration Figure 2.15-4 Display Memory Address Configuration #### 2.15.3 OSD Circuit Control The OSD circuit performs control functions using the OSD control registers which reside in addresses 0001DH to 0001FH and 00024H to 00025H in the special function registers (SFR), and in addresses 0F80H to 0FBFH in the data buffer register (DBR). Section 2.15.5.9 shows the OSD control registers. 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, (Bit0 in ORDON) to "1" enables display (Starts display). Setting DON to "0" disables display (Halts display). Note: The contents of OSD control registers except PIDS, P67S to P64S, ORCLKF, CRCLKC are initialized in STOP mode. Then, OSD display clock does not stop in STOP mode. Therefore, clear ORCLKC to "00H" when stop the OSD display clock. # 2.15.4 OSD Control Register Write There are lists of the OSD control registers on Figure 2.15-30 and Figure 2.15-31. When data is written into a shaded register, the data is transferred to the OSD circuit, and then the data becomes valid. After data is written into an unshaded register, the data is transferred to the OSD circuit, and then the data becomes valid. To transfer the contents of a control register to the OSD circuit, use data transfer request register RGWR (Bit2 in ORDON). Setting "1" in the RGWR register outputs the transfer request signal to the OSD circuit. Three instruction cycles later, transfer of the written data to the OSD circuit starts. While the data is being transferred, data transfer status monitoring flag RGWR (Bit2 in ORDON) is "1". When this transfer is completed, the flag is cleared to "0". Written data transfer register (1 bit) ....... RGWR (Bit2 in ORDON) "0" ........ Initialized state "1" ....... Transfers written data to OSD circuit. (after transfer, RGWR is reset to 0.) Note: Don't write "0" to RGWR. # (1) RGWR system Figure 2.15-5 RGWR System ### (2) Transfer timing 1. No display area When having set RGWR to "1" during no display area, the timing OSD register can be transferred is at the falling edge of $\overline{\text{HD}}$ signal. Figure 2.15-6 Data Transfer Timing in No Display Area 2. Display area (Including any lines specified as display off by character size) When having set RGWR to "1" during display area, the timing OSD register can be transforred is at the folling edge of HD signal when the display line has been be transferred is at the falling edge of $\overline{\rm HD}$ signal when the display line has been finished. Figure 2.15-7 Data Transfer Timing in Display Area ### 2.15.5 OSD Function ### 2.15.5.1 Signal Control (Port I/O) (1) P6 port output select function This function is used to select whether the contents of port P57, P67 to P64 will be output or I, R, G, B, Y/BL signals of the OSD circuit will be output on pins P57, P67 to P64. P57 port output select registers (1 bit): PIDS (Bit3 in ORP6S) | | PIDS = 0 | PIDS = 1 | |-----|----------|----------| | P57 | 1 | Port | P67 to P64 port output select registers (4 bits): P67S, P66S, P65S, P64S, (Bit7 to 4 in ORP6S) | | P6nS = 0 | P6nS = 1 | |-----|----------|----------| | P64 | R | | | P65 | G | Port | | P66 | В | roit | | P67 | Y/BL | | (2) OSD pin output polarity control function This function is used to select the polarity of the OSD outputs for RGB, I and Y/BL. Output polarity control register (4 bits) ...... BLIV, YIV, RGBIV, IIV (Bit3 to 0 in ORIV) $\,$ "0" .... Active high "1" .... Active low (3) OSD pin input polarity control Input polarity control Input polarity control register of RIN/GIN/BIN/Y/BLIN (2 bits) For Y/BLIN ...... YBLII (Bit5 in ORIV) For RIN, GIN, and BIN .....RGBII (Bit4 in ORIV) Input polarity control YBLII, RGBII "0" ... Active high "1" ... Active low Input polarity control register of $\overline{\rm HD}/\overline{\rm VD}$ (2 bits) For $\overline{\text{VD}}$ ......VDPOL (Bit7 in ORIV) For HD ...... HDPOL (Bit6 in ORIV) Input polarity control VDPOL, HDPOL "0" ....... Not invert input signal "1" ....... Invert input signal Figure 2.15-8 VD/HD input and VDPOL/HDPOL # (4) Y/BL signal select function This function is used to select either Y or BL signal output from the Y/BL pin. #### (5) I signal function select When PISEL (Bit6 in ORETC) is set to "1" and PIDS (Bit3 in ORP6S) is set to "0", Port 57 (I pin) can be used as half transparency/half tone through an extra circuit. At half transparency/half tone function, contents of IDT (Bit3 in ORDSN) is make no sense. Therefore character color are limited to 8 colors. Similarly background color, fringing color, raster plane color and area plane color are limited to 8 colors. When PISEL (Bit6 in ORETC) sets to "0" and, PIDS (Bit3 in ORP6S) set to "0", 15 colors to be selectable. # (6) R, G, B, Y/BL Internal/external signal select. Selects either R, G, B, and Y/BL signals from the internal OSD circuit, or RIN, GIN, BIN, and Y/BLIN signals from external input. | R. | $\mathbf{G}$ | В | Y/BL s | signal | select | registers | (2 | hits) | MPXS1/MPXS0 | |-----|--------------|----|--------|--------|--------|-----------|------------|---------|--------------------------| | ıυ, | u, | ъ, | -1/DD | signai | SCICCI | 102101010 | \ <u>~</u> | עסטנט י | 1111 1111 1111 1111 1111 | (Bits 1 and 0 in ORP6S) "00" ...... Simultaneous output (Signal from the OSD circuit has higher priority.) "01" ...... Output of signal from internal OSD circuit "10" ...... Output of signal from external input "11" ...... Simultaneous output (External input signal has higher priority.) #### 2.15.5.2 OSD Data Output Format Control #### (1) Scan mode The double scan mode is used to handle non-interlaced scanning TV. When double scan mode is enabled, the vertical display counter increases every 2 scan lines and a vertical size of a dot is double. This function is enabled by setting VDSMD (Bit7 in ORETC) in the OSD control register to "1". Scan mode select register (1 bit).........VDSMD (Bit7 in ORETC) "0" ....... Normal mode "1" Double scan mode Note 1: The data written to those control register is transferred to the OSD circuit and become valid when the data is written. Note 2: When OSD circuit is used on an interlace scanning TV, a jitter elimination circuit must be enabled and set AFLD to "1" in JECR. Table 2.15.1 The Difference of 2 Types of Scan Mode | | Normal Mode | Double Scan Mode | |-------------------------------------------------------|-------------------|------------------------| | Specification unit of vertical display start position | One scanning line | Two scanning lines | | 1 dot height | T | Normal mode height × 2 | Figure 2.15-9 Scan Mode #### 2.15.5.3 Display Position Control # (1) Code display position setting # 1. Horizontal display start position The horizontal display start position can be set in 256 steps by writing to OSD control registers HS17 to HS10 (Bit7 to 0 in ORHS1). The value is in common with all lines. Specification unit: 2 Tosc Specification steps: 256 Specification horizontal display start position: Line 1 to 12: HS17 to HS10 (ORHS1) $HS1 = (HS17 \text{ to } HS10) \text{ } H \times 2T_{OSC} + 20T_{OSC} \text{ (Line1 to } 12)$ Note 1: T<sub>OSC</sub>: One cycle of OSD oscillation. Note 2: The data written to these control registers is transmitted to OSD circuit by setting RGWR (Bit2 in ORDON) to "1". # 2. Vertical display start position The vertical display start position can be specified for each display line using 512 steps by writing to VSn8 to VSn0 (in ORVSn (n:1 to 12)). Specification unit: 1 scan line Specification steps: 512 Specification vertical display start position: Line1: VS18 to VS10 (ORVS 1) Line2: VS28 to VS20 (ORVS 2) : Line12: VS128 to VS120 (ORVS 12) Line n: $VSn = (VSn8 \text{ to } VSn0) \text{ H} \times 1THD \text{ (n: 1 to 12)}$ Note 1: T<sub>HD</sub>: One cycle of HD signal. Note 2: The data written to these control registers is transmitted to OSD circuit by setting RGWR (Bit2 in ORDON) to "1". Note 3: If display lines are overlapped each other, previous display line is enabled and next line is disabled. If vertical display start positions of two or more lines are set on same value, high priority line is enabled. Lines of OSD (VS1 to VS12) are fixed priority levels as follows: Set the vertical display start position not to overlap display lines. Note 4: The line which is displayed off is managed as a small size character line. Note 5: Transfer the contents of vertical display start position registers into OSD circuit before the position of the scanning line coincides with their own vertical display start position. ### (2) Area display position setting The planes have the priority such as Code plane > Area plane 1 > Area plane 2 > Raster plane. ### 1. Horizontal display start and end position The horizontal display start position can be set in 512 steps by writing to OSD control registers AHSn8 to AHSn0 (Bit8 to 0 in ORAHSn). And also display stop position is correspond to AHEn8 to AHEn0 (Bit8 to 0 in ORAHEn). (n: 1 to 2) Horizontal display start position $AHSn = (AHSn8 \text{ to } AHSn0)_H \times 2TOSC$ Horizontal display end position $AHEn = (AHEn8 \text{ to } AHEn0)_{H} \times 2TOSC$ Note 1: T<sub>OSC</sub>: One cycle of OSD oscillation. Note 2: If the horizontal display start position for characters is the same as that for areas, the two positions are not displayed at the same time. The horizontal display start position for characters is displayed 16 T<sub>OSC</sub> (Corresponding to a register value of 8) later than that for areas. ## 2. Vertical display start and end position The vertical display start position can be set in 512 steps by writing to OSD control registers AVSn8to AVSn0 (Bit8 to 0 ORAVSn). And also display stop position is correspond to AVEn8 to AVEn0 (Bit8 to 0 in ORAVEn). (n: 1 to 2) Vertical display start position $AVSn = (AVSn8 \text{ to } AVSn0) \text{ } H \times THD$ Vertical display end position $AVEn = (AVEn8 \text{ to } AVEn0) \text{ } H \times THD$ Note: $T_{HD}$ : One cycle of $\overline{HD}$ signal. Figure 2.15-10 TV scan image #### 2.15.5.4 Character Ornamentation Control ## (1) Character sizes Character size can be selected line by line from 3 sizes. And display on/off also can be set line by line. Small, middle and large character size and display on/off can be set with OSD control registers CSn (n: 1 to 12, ORCS4, ORCS4, ORCS12) in the OSD control registers. Character sizes: 3 sizes (Small, middle and large) Character size and display on/off specification unit: Line Character size select/display on/off register (2 bits $\times$ 12) Line 1: CS1 Line 2: CS2 : : Line 12: CS12 Table 2.15.2 Character Size and Display On/Off Specifications (n: 1 to 12) | CSn (Upper Bit) | CSn (Lower Bit) | Character Size | Display On/Off | |-----------------|-----------------|----------------|----------------| | 1 | 1 | Small | On | | 1 | 0 | Middle | On | | 0 | 1 | Large | On | | 0 | 0 | _ | Off | - Note 1: The display off line operates like the width of small character size line thought the character is not displayed. - Note 2: The data written to these control registers is transmitted to OSD circuit by setting RGWR (Bit2 in ORDON) to "1". - Note 3: When OSD circuit is used on an interlace scanning TV, a jitter elimination circuit must be enabled and set AFLD to "1" in JECR. - Note 4: When VDSMD and AFLD are "0", only character of even display dot is displayed. (Refer to 2.16 a jitter elimination circuit.) Table 2.15.3 Dot and Character Sizes | | | VDSM | 1D = 0 (Normal | mode) | VDSMD = 1 (Double scan mode) | | | | |------------|--------|--------------------------------------|----------------------------------------|----------------------------------------|--------------------------------------|----------------------------------------|-----------------------------------------|--| | | | | Character Size | | _ | Charac | Character Size | | | | | Dot Size | EFRn = 0<br>(Fringe off) | EFRn = 1<br>(Fringe on) | Dot Size | EFRn = 0<br>(Fringe off) | EFRn = 1<br>(Fringe on) | | | EULAn = 0 | Small | $1T_{OSC} \times 0.5T_{HD}$ | 16T <sub>OSC</sub> × 9T <sub>HD</sub> | 16T <sub>OSC</sub> × 11T <sub>HD</sub> | 1T <sub>OSC</sub> × 1T <sub>HD</sub> | 16T <sub>OSC</sub> × 18T <sub>HD</sub> | 16T <sub>OSC</sub> × 20T <sub>HD</sub> | | | (Underline | Middle | $2T_{OSC} \times 1T_{HD}$ | 32T <sub>OSC</sub> × 18T <sub>HD</sub> | $32T_{OSC} \times 20T_{HD}$ | $2T_{OSC} \times 2T_{HD}$ | $32T_{OSC} \times 36T_{HD}$ | $32T_{OSC} \times 40T_{HD}$ | | | off) | Large | $4T_{OSC} \times 2T_{HD}$ | 64T <sub>OSC</sub> × 36T <sub>HD</sub> | 64T <sub>OSC</sub> × 40T <sub>HD</sub> | $4T_{OSC} \times 4T_{HD}$ | 64T <sub>OSC</sub> × 72T <sub>HD</sub> | 64T <sub>OSC</sub> × 80T <sub>HD</sub> | | | EULAn = 1 | Small | $1T_{OSC} \times 0.5T_{HD}$ | 16T <sub>OSC</sub> × 12T <sub>HD</sub> | 16T <sub>OSC</sub> × 13T <sub>HD</sub> | 1T <sub>OSC</sub> × 1T <sub>HD</sub> | 16T <sub>OSC</sub> × 24T <sub>HD</sub> | 16T <sub>OSC</sub> × 25T <sub>HD</sub> | | | (Underline | Middle | 2T <sub>OSC</sub> × 1T <sub>HD</sub> | $32T_{OSC} \times 24T_{HD}$ | $32T_{OSC} \times 25T_{HD}$ | $2T_{OSC} \times 2T_{HD}$ | 32T <sub>OSC</sub> × 48T <sub>HD</sub> | $32T_{OSC} \times 50T_{HD}$ | | | on) | Large | $4T_{OSC} \times 2T_{HD}$ | 64T <sub>OSC</sub> × 48T <sub>HD</sub> | $64T_{OSC} \times 50T_{HD}$ | $4T_{OSC} \times 4T_{HD}$ | 64T <sub>OSC</sub> × 96T <sub>HD</sub> | 64T <sub>OSC</sub> × 100T <sub>HD</sub> | | T<sub>OSC</sub>: One cycle of OSD oscillation, T<sub>HD</sub>: One cycle of HD signal Figure 2.15-11 Character Size ### (2) Smoothing function The smoothing function is used to make characters look smooth. Enabling smoothing displays 1/4 dot between two dots connecting corner to corner within a character. Small size character can not be enabled smoothing. Smoothing is enabled by setting ESMZ (Bit4 in ORETC) in the OSD control register to "1". Smoothing specification unit:Display page Smoothing specification register (1 bit) ..... ESMZ (Bit4 in ORETC) "0" ...... Disable smoothing "1" Enable smoothing Note: Data of the register is transferred to the OSD circuit and become valid when the data is written. Figure 2.15-12 Available Form and Invalid Form for Smoothing Figure 2.15-13 Smoothing Example ## (3) Fringing function The fringing function is used to display a character with a fringe width is 1 dot in a different color from that of the character. When a character is displayed with the maximum of 18 vertical dots and 16 horizontal dots, the fringe exceeds right and left, top, and bottom of the character display area. If there is an adjacent character that 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 (OREFR8) and EFR9 to EFR12 (OREFR12) in the OSD control register to "1". A color for fringe is specified common to all lines using OSD control registers, IFDT, RFDT, GFDT, and BFDT (Bit3 to 0 in ORBK). Fringing specification unit: Line Fringing enable register (1 bit $\times$ 12) ... EFRn (n: 1 to 8) (OREFR8), EFRn (n: 9 to 12) (OREFR12) "0" ...... Disable fringing "1" ...... Enable fringing Fringe colors: 8 or 15 Fringe color specification unit: Display page Fringe color register (4 bits) .... IFDT, RFDT, GFDT, BFDT (Bit3 to 0 in ORBK) I signal function select: PISEL (Bit6 in ORETC) "0" ....... 15 colors specification I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit. "1" ...... 8 colors specification Contents of IDT register is disregarded. I pin can be used as half transparency/half tone through an extra circuit. Note: The fringe of 1st column character does not exceed left, and the fringe of 32th character does not exceed right. Table 2.15.4 Fringe Color (15 colors) | IFDT | RFDT | GFDT | BFDT | Figure Color | |----------|------|------|------|--------------| | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Blue | | | 0 | 1 | 0 | Green | | 0 | 0 | 1 | 1 | Cyan | | | 1 | 0 | 0 | Red | | | 1 | 0 | 1 | Magenta | | | 1 | 1 | 0 | Yellow | | | 1 | 1 | 1 | White | | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Dark blue | | | 0 | 1 | 0 | Dark green | | 1 | 0 | 1 | 1 | Dark cyan | | <b>'</b> | 1 | 0 | 0 | Dark red | | | 1 | 0 | 1 | Dark magenta | | | 1 | 1 | 0 | Dark yellow | | | 1 | 1 | 1 | Gray | Figure 2.15-14 Example Circuit for 15 Colors by I Pin. Figure 2.15-15 (a) Fringing Example Figure 2.15-16 (b) Fringing Example Figure 2.15-17 (c) Fringing Example Figure 2.15-18 (d) Fringing Example ## (4) Background function Background color function is used to color the entire background for the character area (Refer to Table 2.15.4). Except the character area whose character code is 000H. This function is specified for each display page by setting EBKGD (Bit7 in ORRCL) in the OSD control register to "1". A background color is specified for each display page by setting IBDT, RBDT, GBDT, and BBDT (Bit7 to 4 in ORBK) in the OSD control registers. Background specification unit: Display page Background enable register (1 bit) ..... EBKGD (Bit7 in ORRCL) "0" ...... Disable background "1" Enable background Background color specification unit: Display page Background color specification registers (4 bits) ... IBDT, RBDT, GBDT, BBDT (Bit7 to 4 in ORBK) I signal function select: PISEL (Bit6 in ORETC) "0" ....... 15 colors specification I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit. "1" 8 colors specification Contents of IBDT register is disregarded. I pin can be used as half transparency/half tone through an extra circuit. Table 2.15.5 Background Color (15 colors) | IBDT | RBDT | GBDT | BBDT | Background Color | |------|------|------|------|------------------| | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Blue | | | 0 | 1 | 0 | Green | | 0 | 0 | 1 | 1 | Cyan | | O O | 1 | 0 | 0 | Red | | | 1 | 0 | 1 | Magenta | | | 1 | 1 | 0 | Yellow | | | 1 | 1 | 1 | White | | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Dark blue | | | 0 | 1 | 0 | Dark green | | 1 | 0 | 1 | 1 | Dark cyan | | ' | 1 | 0 | 0 | Dark red | | | 1 | 0 | 1 | Dark magenta | | | 1 | 1 | 0 | Dark yellow | | | 1 | 1 | 1 | Gray | Figure 2.15-19 Example Circuit for 15 Colors by I Pin. Figure 2.15-20 Background Function Note: When the background function is enabled, the line enable the fringing function should not start with a blank character. If it starts with a blank character, a fringe is displayed to the left of the blank character. #### 2.15.5.5 OSD Display Screen Control ### (1) Display on/off This function is used to display characters specified for on/off display. Display on/off specification unit: Display page Display on/off specification register (1 bit) ...... DON (Bit0 in ORDON) "0" ...... Disable display "1" Enable display Note: Do not start STOP mode during display is enable. #### (2) Window function This function is used to set upper and lower limit of display page. Window upper limit is specified by WVSH (ORWVSH). Window lower limit is specified by WVSL (ORWVSL). This function is enabled by setting EWDW (Bit1 in ORDON) in the OSD control register to 1. Window specification unit: Display page Window function enable specification register (1 bit) ...........EWDW (Bit1 in ORDON) "0" Disable window function "1" Enable window function Window upper limit specification register (9 bits) .... WVSH8 to 0 (ORWVSH) Window lower limit specification register (9 bits) ..... WVSL8 to 0 (ORWVSL) Window upper and lower limit position ..... When VDSMD is "0" (Normal mode): $WVSH = (WVSH8 \text{ to } WVSH0) \text{ } H \times THD$ $WVSL = (WVSL8 \text{ to } WVSL0) \text{ }_{H} \times T_{HD}$ When VDSMD is "1" (Double scan mode): $WVSH = (WVSH8 \text{ to } WVSH0) \text{ }_{H} \times 2T_{HD}$ $WVSL = (WVSL8 \text{ to } WVSL0) \text{ } H \times 2THD$ Note 1: THD: One cycle of HD signal Note 2: WVSL > WVSH ≥ "1" Note 3: Modify the value of window upper and lower limit register and the value of EWDW during VD signal is low. Note 4: It is recommendable that the window function is always enabled (EWDW = "1") and set WVSH to "01H", WVSL to "1FEH". Note 5: Characters and symbols at scanning line specified by WVSL are not displayed. Correspond to Closed Caption Figure 2.15-21 If WVSH is on a Code Plane ## (3) Full-raster blanking function Full-raster blanking function is used to color the entire background for the display area (TV screen). When using the full-raster blanking function, set YBLCS (Bit2 in ORP6S) to "1", output BL signal from Y/BL pin, because Y signal cannot delete whole display page from video signal. This function is specified for each display page by setting EXBL (Bit6 in ORRCL) in the OSD register to "1". Full-raster blanking specification unit: Display page Full-raster blanking enable register (1 bit) ..... EXBL (Bit6 in ORRCL) "0" ...... Disable full-raster blanking "1" Enable full-raster blanking Full-raster blanking color specification ........ RCLI, RCLR, RCLG, RCLB registers (4 bits) (Bit3 to 0 in ORRCL) I signal function select: PISEL (Bit6 in ORETC) "0" ....... 15 colors specification I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit. "1" 8 colors specification Contents of RCLI register is disregarded. I pin can be used as half transparency/half tone through an extra circuit. Table 2.15.5.6 Raster Plane Color (15 colors) | RCLI | RCLR | RCLG | RCLB | Raster Plane Color | |----------|------|------|------|--------------------| | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Blue | | | 0 | 1 | 0 | Green | | 0 | 0 | 1 | 1 | Cyan | | | 1 | 0 | 0 | Red | | | 1 | 0 | 1 | Magenta | | | 1 | 1 | 0 | Yellow | | | 1 | 1 | 1 | White | | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Dark blue | | | 0 | 1 | 0 | Dark green | | 4 | 0 | 1 | 1 | Dark cyan | | <b>'</b> | 1 | 0 | 0 | Dark red | | | 1 | 0 | 1 | Dark magenta | | | 1 | 1 | 0 | Dark yellow | | | 1 | 1 | 1 | Gray | ## (4) Area plane function Area plane function is used to display square area to two points on a screen. Two planes operate independently. They are displayed according to the priority (Area plane 1 > Area plane 2). See area plane display position setting in section 2.15.5.3 (2) how to set display positions for each area. Each area plane is set to ON or OFF by AON2 and AON1 (Bit5 and bit4 in ORRCL). Area plane colors are set by ACLIx, ACLRx, ACLGx, ACLBx (Bit7 to bit0 in ORACL, x: 1, 2). Area plane colors: 8 or 15 Area plane specification unit: plane Area plane color specification register (8 bit) Area plane 1: ACLI1/ACLR1/ACLG1/ACLB1 (Bit3 to 0 in ORACL) Area plane 2: ACLI2/ACLR2/ACLG2/ACLB2 (Bit7 to 4 in ORACL) I signal function select: PISEL (Bit6 in ORETC) "0" ....... 15 colors specification I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit. "1" 8 colors specification Contents of ACLI1 and ACLI2 register is disregarded. I pin can be used as half transparency/half tone through an extra circuit. Table 2.15.5.7 Area Plane Color (15 colors) | ACLIx | ACLRx | ACLGx | ACLBx | Area Plane Color | |-------|-------|-------|-------|------------------| | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Blue | | | 0 | 1 | 0 | Green | | 0 | 0 | 1 | 1 | Cyan | | O | 1 | 0 | 0 | Red | | | 1 | 0 | 1 | Magenta | | | 1 | 1 | 0 | Yellow | | | 1 | 1 | 1 | White | | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Dark blue | | | 0 | 1 | 0 | Dark green | | 1 | 0 | 1 | 1 | Dark cyan | | ı | 1 | 0 | 0 | Dark red | | | 1 | 0 | 1 | Dark magenta | | | 1 | 1 | 0 | Dark yellow | | | 1 | 1 | 1 | Gray | x: 1, 2 # I signal function select 1. Using for 15 colors (PISEL = 0) Figure 2.15-22 TV Display and OSD Signals (PISEL = 0) 2. Using for half transparency/half tone (PISEL = 1) Figure 2.15-23 TV Display and OSD Signals (PISEL = 1) #### 2.15.5.6 Interrupt Control ### (1) Display line counter The display line counter indicates number of display line (s) by OSD circuit on the TV screen. The display line counter is a 4-bit counter which is initialized to "0" by the falling edge of the $\overline{\text{VD}}$ signal and which increments when last scanning of each display line is completed (Falling edge of the $\overline{\text{HD}}$ signal). It is necessary to be read out display line counter several times, because it does not synchronize CPU clock. Figure 2.15-24 Display Line Counter #### (2) Interrupt generator circuit An interrupt request is generated when a falling edge of $\overline{\text{VD}}$ signal or when line counter (DCTR) is counted to the certain value specified by ISDC. Interrupt source select register (1 bit) ..... SVD (Bit4 in ORIRC) "0" ....... Interrupt request generated when the display line counter (DCTR) is counted to the certain value which is specified by ISDC. "1" ....... Interrupt request is generated when a falling edge of $\overline{\text{VD}}$ signal. Interrupt generation line specification register (4 bits) ...... ISDC (Bit3 to 0 in ORIRC) "0000" ....... Interrupt request generated when the display line counter is cleared. "0001" ....... Interrupt request generated at end points of the last scanning line of the first display line "0010" ....... Interrupt request generated at end points of the last scanning line of the 2'nd display line "1111" ........ Interrupt request generated at end points of the last scanning line of the 15'th display line #### 2.15.5.7 Display Memory Access #### (1) Display memory The display memory is accessed for two purposes, one for writing data to the display memory, and one for reading data from the display memory. Display memory address specification registers .... DMA8 to MDA0 (ORDMA) (9 bits) Display memory data write registers Character code write register (9 bits) .... CRA8 to CRA0 (ORCRA) Character ornamentation data write registers .... SLNT, EUL, BLF, IDT, RDT, (7 bits) GDT, and BDT (ORDSN) Display memory bank select register MBK (Bit1 in ORETC) "0" ....... When writing either character code or character ornamentation data "1" ....... When writing both character code and character ornamentation data - Note 1: These control registers have a characteristic that immediately when a value is written to the register, the content of the register is transferred as valid data to the OSD circuit/display memory. - Note 2: The data written to the display memory takes effect at the same time it is written. When character code or character ornamentation data is written to the display memory while it is displaying some character, the character may not be displayed correctly. When writing data to the display memory, make sure no character is being displayed in the memory location where you are going to write data. - Note 3: When writing data to or reading data from the display memory, do not use two-byte transfer instructions such as "LDW(HL),mn LD rr, (pp)". Otherwise, erroneous data may be written to the display memory or data may be written to an incorrect address. - Note 4: Allow for at least two instruction cycles between a display memory address write instruction and a data write or read instruction. Also, when continuous writing data to or reading data from the display memory, allow for at least two instruction cycles between one write or read instruction and the next. Otherwise, erroneous data may be written to the display memory or data may be written to an incorrect address. - Note 5: When setting display memory addresses, always be sure to write all of 9 address bits sequentially in order of DMA8 and DMA7 to DMA0. #### Normal mode In normal mode, the display memory addresses are automatically incremented each time data is read from or written to the memory. Because addresses are automatically incremented, this mode may be used for reading from or writing data to multiple continuous addresses simultaneously. <Display memory write sequence in normal mode> - a. When writing either character code or character ornamentation data - (1) Set MFYWR, MBK, and RDWRV all to 0. - (2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0. - (3) Writing character code or character ornamentation data - Writing character code Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 through CRA0. At this point in time, the 9 bits of character code written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented. • Writing character ornamentation data Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation data written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented. - (4) To write data (character code or character ornamentation data) to continuous addresses, repeat step (3). - b. When writing character code and character ornamentation data at a time - (1) Set MFYWR to 0, MBK to 1, and RDWRV to 0. - (2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0. - (3) Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation written are transferred to the display memory. - (4) Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, the 9 bits of character code written and the character ornamentation data written in step (3) are transferred to the display memory, and DMA8 to DMA0 are automatically incremented. - (5) To write data to continuous addresses, repeat steps (3) and (4). <Display memory read sequence in normal mode> - a. When reading either character code or character ornamentation data - (1) Set MFYWR to 0, MBK to 0, and RDWRV to 1. - (2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0. - (3) Reading character code or character ornamentation data - Reading character code Read the most significant bit of character code to CRA8. Go on and read the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, DMA8 to DMA0 are automatically incremented. · Reading character ornamentation data Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, DMA8 through DMA0 are automatically incremented. - (4) To read data (Character code or character ornamentation data) from continuous addresses, repeat step (3). - b. When reading character code and character ornamentation data at a time - (1) Set MFYWR to 0, MBK to 1, and RDWRV to 1. - (2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0. - (3) Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. - (4) Read the most significant bit of character code to CRA8. Read the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, DMA8 to DMA0 are automatically incremented. - (5) To read data from continuous addresses, repeat steps (3) and (4). #### 2. Read-modify-write mode When writing data in read-modify-write mode, the display memory addresses are automatically incremented as in normal mode, but when reading data in this mode, the memory addresses are not automatically incremented. Therefore, immediately after executing a read from some display memory address, you can execute a write to the same display memory address. After executing a write, the display memory addresses are automatically incremented. - Reading/writing either character code or character ornamentation data in read-modify-write mode - (1) Set MFYWR to 1 and MBK to 0, and RDWRV to 1. - (2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0. - (3) Reading character code or character ornamentation data - Reading character code Read the most significant bit of character code to CRA8. Read the 8 low-order bits of character code to CRA7 to CRA0. DMA8 to DMA0 are not incremented. Reading character ornamentation data Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. DMA8 to DMA0 are not incremented. - (4) Writing character code or character ornamentation data - Set RDWRV to "0". - Writing character code Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, the 9 bits of character code written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented. Writing character ornamentation data Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation data written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented. - (5) To continue executing read-modify-write operations, repeat steps (1) to (4). To read/write data (Character code or character ornamentation data). To continue executing read-modify-write mode from continuous addresses, repeat steps (3) and (4). - Reading/writing both character code and character ornamentation data in read-modify-write mode - (1) Set MFYWR to 1, MBK to 1 and RDWRV to 1 - (2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0. - (3) Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, DMA8 to DMA0 are not incremented. - (4) Read the most significant bit of character code to CRA8. Read the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, DMA8 to DMA0 are not incremented. - (5) Set RDWRV to "0". - (6) Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation data written is transferred to the display memory. - (7) Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, the 9 bits of character code written and the character ornamentation data written in step (6) are transferred to the display memory, and DMA8 to DMA0 are automatically incremented. - (8) To continue executing read-modify-write operations, repeat steps (1) to (7). (To read/write data to and from continuous addresses in read-modify-write mode, repeat steps (3) to (7).) | | | RD (RDWRV = 1) | | WR (RDWRV = 0) | | | |-----------------|---------|----------------------------|-------------------|----------------------------|-------------------|--| | | | Character<br>Ornamentation | Character<br>Code | Character<br>Ornamentation | Character<br>Code | | | MFYWR = 0 | MBK = 0 | INC | INC | INC | INC | | | IVIF I VVIX = U | MBK = 1 | _ | INC | - | INC | | | MFYWR = 1 | MBK = 0 | _ | _ | INC | INC | | | IVIF T VV K = 1 | MBK = 1 | _ | _ | _ | INC | | Table 2.15.5.8 Address Increment INC: Automatic address increment at read or write. Example: Setting a character code (020H) to the display memory (Address: 120H) and setting (001H) for a character ornamentation. - 1. MBK = 0 - ; Set display memory address LD (0x25), 0x01 ; ORDMA<DMA8> LD (0x24), 0x20 ; ORDMA<DMA7:0> ; Set character code LD (0x1F), 0x00 ; ORCRA<CRA8> LD (0x1E), 0x20 ; ORCRA<CRA7:0> ; Set display memory address again LD (0x25), 0x01 LD (0x24), 0x20 ; Set character ornamentation LD (0x1D), 0X01 ; ORDSN<SLNT,.....BDT> - 2. MBK = 1 - ; Set display memory address LD (0x25), 0x01 LD (0x24), 0x20 ; Set character ornamentation LD (0x1D), 0X01 ; Set character code LD (0x1F), 0x00 LD (0x1E), 0x20 - Note 1: To write character code into the display memory, first write into register CRA8 and then write into registers CRA7 to CRA0. When data is written into registers CRA7 to CRA0, DMA8 to DMA0 is incremented. It is impossible to write into the display memory for CRA7 to CRA0 alone. If no data is written into register CRA8 while data is written into registers CRA7 to CRA0, the value previously written into register CRA8 is written into the associated display memory. - Note 2: To read character code from the display memory, first read from register CRA8, and then read from registers CRA7 to CRA0. When data is read from registers CRA7 to CRA0, DMA8 to DMA0 is incremented. - Note 3: There should be a time interval of at least two machine cycles between a DMA set instruction and a data write/read instruction. There should be a time interval of at least two machine cycles between a data write instruction and a data read instruction. - (2) Character Characters: 384 (including blank character) Character specification register (9 bits) ...... CRA8 to CRA0 (Bit8 to 0 in RCRA) Character code "000H" ...... Blank character Character code "001H" to "017FH" ....... User programmable by character $$\operatorname{ROM}$$ No address change at data read or write. # (3) Character color Character colors: 8 or 15 Character color specification unit: Character Character color specification register (4 bits): IDT/RDT/GDT/BDT (Bit3 to 0 in ORDSN) I signal function select: PISEL (Bit6 in ORETC) "0" ...... 15 colors specification I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit. "1" 8 colors specification Contents of IDT register is disregarded. I pin can be used as half transparency/half tone through an extra $\,$ circuit. Table 2.15.5.9 Character Color (15 colors) | IDT | RDT | GDT | BDT | Character Color | |-----|-----|-----|-----|-----------------| | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Blue | | | 0 | 1 | 0 | Green | | 0 | 0 | 1 | 1 | Cyan | | | 1 | 0 | 0 | Red | | | 1 | 0 | 1 | Magenta | | | 1 | 1 | 0 | Yellow | | | 1 | 1 | 1 | White | | | 0 | 0 | 0 | Black | | | 0 | 0 | 1 | Dark blue | | | 0 | 1 | 0 | Dark green | | 1 | 0 | 1 | 1 | Dark cyan | | ' | 1 | 0 | 0 | Dark red | | | 1 | 0 | 1 | Dark magenta | | | 1 | 1 | 0 | Dark yellow | | | 1 | 1 | 1 | Gray | Figure 2.15-25 Example of Circuit for 15 Color by I Pin #### (4) Blinking function Blinking function is used to blink display characters. When BKMF is "1", characters specified for blinking by BLF are not displayed. (If the background color function is used, the background color is not disappeared.) Blinking specification unit: Character Blinking specification register (1 bit) ...... BLF (Bit4 in ORDSN) "0" ....... No blinking "1" Blinking Blinking master specification register (1 bit) ...... BKMF (Bit5 in ORETC) "0" ...... Disable blinking "1" ....... Enable blinking (Characters whose BLF are set to "1" are not displayed.) Note: Regarding the extra dot of the left and/or right character by fringing function, it is not enabled as blink. #### (5) 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/line Underline enable register (Character unit) (1 bit) ..... EUL (Bit5 in ORDSN) "0" ....... No underline "1" ....... Underline Underline enable register (Line unit) (1 bit × 12) ...... EULAn (n: 1 to 8)(OREULA8), EULAn (n: 9 to 12) (OREULA12) Underline colors: 8 or 15 Underline color specification registers (4 bits) ..... RDT, GDT, BDT, IDT (Bit3 to 0 in ORDSN) (Refer to Table 2.15.5.9) Note: To use the underline function, set both the underline enable register for underlining text in characters and that for underlining text in lines. If the former register (EUL) only is set, an underline is not displayed. Figure 2.15-26 Underline ### (6) 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 (24 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 12 SOL121 and SOL120 (Bits 7 and 6 in ORSOL12) ## Solid space specification The solid space control functions as follows: SOLx1/SOLx0 (x: 1 to 12) ``` "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 (4 bits) ....... IBDT, RBDT, GBDT, BBDT (Bits 3 to 0 in ORBK) (Same color as that of background) Figure 2.15-27 Solid Space ### (7) Slant function Slant function is used to slant characters for italics. Slant specification unit: Character Slant enable register (1 bit) ...... SLNT (Bit6 in ORDSN) "0" ...... No slant "1" ...... Slant - Note 1: 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. - Note 2: When a character is slanted in an area, which overlaps with the character field, the overlap is also slanted. - Note 3: If slanting a character causes part of the character to get into the character field to the immediate right of the character, then this part is not displayed. - Note 4: To provide closed caption display (CCD), specify black as the background color, and set YBLCS to "1". R, G, B and Y are all slanted. Thus, if the Y signal is selected, a video signal is displayed above and to the left of the slant character. - Note 5: When a character is slanted, the dot data to the immediate left of the character is also slanted. When an entire character field (including its background) contains dots: When the character field on the right does not contain a dot: Figure 2.15-28 Slant #### 2.15.5.8 Clock Generation for OSD Display The TMP88CS38/CM38A/CP38A has clock generator for OSD display. It can generate a clock from 8 MHz to 24 MHz. However, note that the OSD display clock (fosc) frequency should not exceed multiply-by-1.6 basic clock frequency (fc). (Refer to the clock frequency in "recommended operating conditions".) The frequency of display clock is specified by ORCLKC and is monitored by ORCLKF. Display clock frequency specification register: ORCLKC (8 bits) $fOSC = ORCLKC \times 8/THdhigh$ (THdhigh: High period of $\overline{HD}$ signal) Display clock frequency locked monitor: ORCLKF (8 bits) 0: Unmatched 1: Matched Figure 2.15-29 Clock Generation For OSD Display Control #### 2.15.5.8.1 Operating Principle The clock generator for OSD display consists of a ring oscillator, an 11-bit counter, a comparator and an oscillator controller. The frequency of the ring oscillator depends on the cycle of the external $\overline{\text{HD}}$ input and the ORCLKC setting. The ring oscillator generates clocks required for one scanning line and the 11-bit counter counts the number of clocks. Then the counted number of the upper-order 8 bits is compared with the value set by ORCLCK. The comparator sends the compared result, which controls the ring oscillator and changes the oscillating frequency. At the frequencies of 8 MHz, 16 MHz and 24 MHz set by ORCLKC, the error percentages are 1.65%, 0.83% and 0.55% respectively. Thus, even when the same value is rewritten to ORCLKC, the display position after refresh deviates by the error percentage (Note 1). The oscillator controller controls the operation of the ring oscillator using a result from the comparator. To avoid display jitter created by fine adjustment, the oscillator controller receives a coincidence signal and automatically stops adjusting the ring oscillator. After the ring oscillator becomes stable, it drives a display clock at a regular frequency. The output frequency fluctuates according to changes of temperature and voltage (Note 2). The frequency of the ring oscillator can be adjusted to the required frequency (Display position) by writing value to ORCLKC in response to the change of condition. When the oscillating frequency of the ring oscillator is adjusted under software control, please writes value before adjustment to ORCLKC. The comparator compares ORCLKF (the result from comparing the counted number of the upper-order 8 bits of the 11-bit counter with the ORCLKC setting value.) with the ORCLKC setting value. Comparing ORCLKF with ORCLKC, the deviation of the oscillating frequency is checked and please writes values before adjustment to ORCLKC. In this case, the deviation of the display position occurs as described in Note 1. Therefore, care must be taken to the interval of adjusting the frequency of the ring oscillator. Note 1: Since the clock generator for OSD display controls the frequency using the upper-order 8 bits of the 11-bit counter, the low-order 3 bits do not participate in determining the frequency. This yields an error equal to relative magnitude of the low-order 3 bits at maximum. Even when the same value is set to a register, up to 8-count error occurs in one line. (Errors when using clock generator for OSD display in NTSC (interlace) mode (HD = 53.2 μs) are explained subsequently.) (Example 1) fOSC = 8 MHz Frequency error when ORCLKC is 35H (at the 8 MHz setting). When the low-order 3 bits are 000, the value of the 11-bit counter is 424 (1A8), so the frequency is 7.97 MHz. When the low-order 3 bits are 111, the value of the 11-bit counter is 431 (1AF), so the frequency is 8.10 MHz. 1 dot in the errors above is 2 ns (max). The effect of the 24th character in the display. Display position error: $16 \text{ dots} \times (24 \text{th character} - 1) \times 1 \text{ dot error} = 16 \times 23 \times 2 = 736 \text{ ns.}$ This is approximately equivalent to 6 dot error for the character display. (Example 2) fOSC = 16 MHz Frequency error when ORCLKC is 6AH (at the 16 MHz setting). When the low-order 3 bits are 000, the value of the 11-bit counter is 848 (350), so the frequency is 15.94 MHz. When the low-order 3 bits are 111, the value of the 11-bit counter is 855 (357), so the frequency is 16.07 MHz. 1 dot in the errors above is 0.52 (max). The effect of the 24th character in the display. Display position error: 16 dots $\times$ (24th character - 1) $\times$ 1 dot error = 16 $\times$ 23 $\times$ 0.52 = 191.4 ns. This is approximately equivalent to 3.1 dot error for the character display. - Note 1: When a character is displayed in the right side towards the screen, the display position deviates significantly by number of clocks from the rising edge of the $\overline{\text{HD}}$ signal $\times$ error delay time. - Note 2: After the operation of the ring oscillator becomes stable, the cycle of the display clock changes according to temperature and voltage. The percentage of oscillator clock period by temperature fluctuation is up to 38% within the usage temperature range. (Set the frequency of the OSD oscillator at $Ta = -30^{\circ}C$ and change the temperature to $70^{\circ}C$ .) The percentage of oscillator clock period by voltage fluctuation is up to 19% within the usage voltage range. (Set the frequency of the OSD oscillator at OVDD = 4.5 V and change the voltage to 5.5 V.) \*) Please set the power supply voltage (OVDD) of the clock generator for OSD display to the same value as the system power supply voltage (VDD). It is not recommended that only the OVDD be changed intentionally. (It will affect the internal operation.) When the power supply voltage (OVDD) fluctuates for some reasons, it changes the OSD display position. Thus, make sure that the voltage does not fluctuate during operation. When voltage and temperature fluctuate simultaneously, both errors overlaps each other. The percentage of the both fluctuations is up to 57% (38% + 19%) within the usage range. Frequency adjustment is performed for the display clock frequency every time when value is written to ORCLKC. Therefore, please monitor the ORCLKF register periodically and check if a deviation occurs. When it happens, the display position can be corrected when the value before adjustment is written to the ORCLKC register under software control. However, an error as described in Note 1 occurs when the display position is corrected. ### 2.15.5.8.2 Notes on Creating a Software Program (1) If you want to change the OSD display screen, rewrite the same value to ORCLKC for adjustment of . the oscillating frequency. Example) When the OSD display screen is ON. When the content of the OSD screen is all changed. When OFF command is received while CCD is displayed. (2) When the content of the OSD screen is displayed for a long time, the OSD display position deviates because the oscillating frequency changes according to the power supply voltage and temperature characteristics. To adjust the deviation, monitor the oscillating frequency error using ORCLKF, then rewrite the value before adjustment to ORCLKC during OSD screen off. In this case, the OSD display position deviates (Refer to Note 1), please take the timing of writing a setting value to ORCLKC into consideration. (3) The clock generator for OSD display does not stop oscillating even in STOP mode. If you want to stop it, write 00H to ORCLKC. By reading ORCLKF, the status of a display clock frequency can be monitored. When the read value is FFH, it turns out that the display clock frequency is in a setting value. However, depending on temperature, power supply voltage, and OSD oscillation frequency, the lower 3 bits of ORCLKF may not be in agreement (the maximum difference of the lower 3 bits value is "5"), then the display clock frequency may become lower than a setting value. Please setup the oscillation frequency which has a margin in the composition of a display screen in consideration of these characteristics. The period from the ORCLKC writing to the completion of a setting of a display clock frequency is required the time of 256 scanning lines at maximum. When the ORCLKC is resetup in order to change OSD oscillation frequency, OSD oscillation frequency may become higher rapidly. In order to slip out of this state, a resetup of ORCLKC is required. Please repeat a resetup of ORCLKC until the higher 5 bits of the ORCLKF or more bits are in agreement. Please write in the ORCLKC at timing of the OSD display period (near the center of the OSD display period is recommended) of a horizontal synchronizing signal, or please write in the ORCLKC two or more times. ## The example of software of an OSD clock setup <Condition> Please execute this flow during OSD screen OFF. The horizontal synchronizing signal: $\overline{\rm HD}\,$ has described as the active Low. #### Note 1: Condition 1 By calculating XNOR of data "a" and data "b<sub>1</sub>", the setting value inside the OSD oscillator can be calculated. The setting value inside the OSD oscillator: (Data "c<sub>1</sub>") = data "a" XNOR data "b<sub>1</sub>" In the case so that data " $c_1$ " may become extremely large to data "a" ((" $c_1$ " – "a") > 5), please move on to the flow which writes in ORCLKC 5 times. \* In the case so that data " $c_1$ " may become extremely large, data " $c_1$ " is more than E0h (when the high width of $\overline{HD}$ is 60 microseconds, OSD oscillation frequency becomes 30 MHz or more.). #### Note 2: Condition 2 By calculating XNOR of data "a" and data " $b_i$ " (i = 1, 2), the setting value inside the OSD oscillator can be calculated. The setting value inside the OSD oscillator: (Data "c<sub>i</sub>") = data "a" XNOR data "b<sub>i</sub>" \* From the difference of data " $c_i$ " and data "a", it can judge whether it is in the error range. Please set the error range to a maximum of $\pm 5$ . ## 2.15.5.9 OSD Control Registers Can not access all OSD control registers in any of read-modify-write instructions such as bit operation, etc. | 0RHS1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | | |-------------------|-----------|----------------|--------------|-------------|------------|--------------------------------------------------|-----------|-----------|----------------------------|--------| | (00F81H) | HS17 | HS16 | HS15 | HS14 | HS13 | HS12 | HS11 | HS10 | (Initial value: 0000 0000) | | | | | | | | | | | | | | | | Horizont | al displav | start posi | tion speci | fication | | | | | Write | | | | | | | | | | | | only | | 001/04 | 7 | 0 | - | 4 | 0 | 0 | 4 | 0 | | | | ORVS1<br>(00F82H) | 7<br>VS17 | 6<br>VS16 | 5<br>VS15 | 4<br>VS14 | 3<br>VS13 | 2<br>VS12 | 1<br>VS11 | 0<br>VS10 | (Initial value: 0000 0000 | ٦١ | | (00F82H) | V317 | V310 | V 3 1 3 | V 314 | V 3 1 3 | 1 7312 | V 311 | VS18 | (Initial value: **** ***( | , | | (001 0311) | <b>'</b> | ' <i>-</i> | ' <u>-</u> | ! | ! | ! <del>-</del> | ٠ | V310 | (Illitial value. | ') | | ORVS2 | | | | | | | | | <b>-</b> | | | (00F84H) | VS27 | VS26 | VS25 | VS24 | VS23 | VS22 | VS21 | VS20 | (Initial value: 0000 0000 | 0) | | (00F85H) | L | | <u> </u> | | | <u> </u> | <u> </u> | VS28 | (Initial value: **** ***C | )) | | | | | | | | | | | | | | ORVS3 | VS37 | VS36 | VS35 | VS34 | VS33 | VS32 | VS31 | VS30 | (Initial value: 0000 0000 | וו | | (00F86H) | V 007 | V 0 0 0 | 7000 | V 004 | V 0 0 0 0 | V 032 | 7001 | | (Initial value: **** ***( | , | | (00F87H) | L | ' <del>-</del> | ' <i>-</i> | ! | ! | <u> </u> | · | VS38 | (Illiliai value. | ') | | ORVS4 | | | | | | | | | <u>-</u> | | | (00F88H) | VS47 | VS46 | VS45 | VS44 | VS43 | VS42 | VS41 | VS40 | (Initial value: 0000 0000 | 0) | | (00F89H) | - | - | - | - | - | - | - | VS48 | (Initial value: **** ***C | )) | | | | | | | | | | | | | | ORVS5 | VS57 | VS56 | VS55 | VS54 | VS53 | VS52 | VS51 | VS50 | (Initial value: 0000 0000 | ٦١ | | (00F8AH) | V 337 | V 330 | V 333 | V 334 | V 333 | V 332 | V 331 | | 1 | • | | (00F8BH) | | | | i ; | i | i | i | VS58 | Initial value: **** ***C | ') | | ORVS6 | | | | | | | | | _ | | | (00F8CH) | VS67 | VS66 | VS65 | VS64 | VS63 | VS62 | VS61 | VS60 | (Initial value: 0000 0000 | 0) | | (00F8DH) | - | - | - | - | _ | _ | _ | VS68 | (Initial value: **** ***C | )) | | | | | | | | | | | • | | | ORVS7 | 1/077 | 1/076 | \/C7E | 1/07/ | 1/072 | 1/070 | VC71 | 1/070 | (Initial value: 0000 0000 | ٦١ | | (00F8EH) | VS77 | VS76 | VS75 | VS74 | VS73 | VS72 | VS71 | VS70 | (Initial value: 0000 0000 | , | | (00F8FH) | | | | | | | <u></u> | VS78 | (Initial value: **** ***C | )) | | ORVS8 | | | | | | | | | _ | | | (00F90H) | VS87 | VS86 | VS85 | VS84 | VS83 | VS82 | VS81 | VS80 | (Initial value: 0000 0000 | 0) | | (00F91H) | - | - | - | - | - | - | - | VS88 | (Initial value: **** ***C | )) | | | | | | | | • | | | • | | | ORVS9 | 1/007 | 1/000 | 1/005 | 1/004 | 1/000 | \/C00 | 1/004 | 1/000 | 1 (/-:/:- | 2) | | (00F92H) | VS97 | VS96 | VS95 | VS94 | VS93 | VS92 | VS91 | VS90 | (Initial value: 0000 0000 | • | | (00F93H) | <u></u> | | ! <u>-</u> | !! | ! | ! | ! | VS98 | (Initial value: **** ***C | )) | | ORVS10 | | | | | | | | | | | | (00F94H) | VS107 | VS106 | VS105 | VS104 | VS103 | VS102 | VS101 | VS100 | (Initial value: 0000 0000 | 0) | | (00F95H) | _ | - | - | - | _ | <del> </del> | - | VS108 | (Initial value: **** ***C | )) | | | | | | | | | | | | | | ORVS11 | 1/0447 | 1/0440 | 1/0445 | 1/0444 | 1/0440 | 1/0440 | 1/0444 | 1/0440 | 1 (/-:// | 2) | | (00F96H) | VS117 | VS116 | VS115 | VS114 | VS113 | VS112 | VS111 | VS110 | (Initial value: 0000 0000 | , | | (00F97H) | i | | | | | i = | i | VS118 | (Initial value: **** ***C | )) | | ORVS12 | | | | | | | | | | | | (00F98H) | VS127 | VS126 | VS125 | VS124 | VS123 | VS122 | VS121 | VS120 | (Initial value: 0000 0000 | 0) | | (00F99H) | <u> </u> | | | _ | | <u> </u> | <u> </u> | VS128 | (Initial value: **** ***( | • | | (55. 55.1) | · | | ' | | | | | | 1 ( | , | | | VSn8 | to | | | | | | | | Write | | | VSnO | I Ver | tical displa | ay start po | sition for | line n | | | | only | | | | - | | | | | | | (n: 1 | to 12) | (n: 1 to 12) Note 1: If display lines are overlapped each other, previous display line is enabled and next line is disabled. Set the vertical display start position not to overlap display lines. Note 2: Transfer the contents of vertical display start position registers into OSD circuit before a position of the scanning line coincides with their own vertical display start position. ORCS4 (00F9AH) ORCS8 (00F9BH) ORCS12 (00F9CH) | 7 6 | 5 4 | 3 2 | 1 0 | |------|------|------|-----| | CŞ4 | CŞ3 | CŞ2 | CŞ1 | | CŞ8 | C\$7 | CŞ6 | CŞ5 | | CS12 | CS11 | CS10 | CŞ9 | (Initial value: 0000 0000) (Initial value: 0000 0000) (Initial value: 0000 0000) | | | 00: | Display off | | |------|----------------------------|-----|-------------|-------| | CSn | Character size and display | 01: | Large size | Write | | CSII | on/off for line n | 10: | Middle size | only | | | | 11: | Small size | | (n: 1 to 12) OREULA8 (00F9DH) OREULA12 (00F9EH) | EULA8 | EULA7 | EULA6 | EULA5 | EULA4 | EULA3 | EULA2 | EULA1 | |-------|-------|-------|-------|--------|--------|--------|-------| | | | | | EULA12 | EULA11 | EULA10 | EULA9 | (Initial value: 0000 0000) (Initial value: \*\*\*\* 0000) | EULAn | Underline for display line for | 0: | Display off | | |--------|--------------------------------|----|-------------|--| | EULAII | line n | 1: | Display on | | (n: 1 to 12) OREFR8 (00F9FH) OREFR12 (00FA0H) | EFR8 | EFR7 | EFR6 | EFR5 | EFR4 | EFR3 | EFR2 | EFR1 | |----------|------|------|------|-------|-------|-------|------| | <u> </u> | | | | EFR12 | EFR11 | EFR10 | EFR9 | (Initial value: 0000 0000) (Initial value: \*\*\*\* 0000) | EFRn | Fringing enable specification register for line n | 0:<br>1: | Disable fringing Enable fringing | Write | |------|---------------------------------------------------|----------|----------------------------------|-------| | | 109.0101 101 11110 11 | | =agg | J, | (n: 1 to 12) Note: When a display line is enabled fringing function, its vertical size is increased by one dot (by two dots when its character size is small) independent of its character font. Therefore, when a vertical display start position is specified to no space between the lines, the display line which is overlapped with increasing dot(s) is canceled. ORCLKF (00FA1H) ORCLKC (00FA1H) | CK7 | CK6 | CK5 | CK4 | CK3 | CK2 | CK1 | CK0 | |------|------|------|------|------|------|------|------| | CKC7 | CKC6 | CKC5 | CKC4 | CKC3 | CKC2 | CKC1 | CKC0 | (Initial value: 0000 0000) (Initial value: 0000 0000) | CKn | Display clock frequency locked monitor | Read<br>only | |------|------------------------------------------------|--------------| | CKCn | Display clock frequency specification register | Write only | (n: 0 to 7) ORSLO4 (00FA2H) ORSLO8 (00FA3H) ORSLO12 (00FA4H) | SLO4 | SLO3 | SLO2 | SLO1 | |-------|-------|-------|------| | | | | | | SLO8 | SLO7 | SLO6 | SLO5 | | | | | | | SLO12 | SLO11 | SLO10 | SLO9 | (Initial value: 0000 0000) (Initial value: 0000 0000) (Initial value: 0000 0000) | | | 00: | No solid space display | | |-----------------------------|-------------------------|--------------------------|------------------------------------|------| | SLOn Solid space for line n | 01: | Solid space display left | Write | | | SLOII | Solid space for line fi | 10: | Solid space display right | only | | | | 11: | Solid space display left and right | | | | | | | | (n: 0 to 12) ORBK (00FA5H) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------------------------------|--------|-------------|-----------|------|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------|----------------------------|------| | IBDT | RBDT | GBDT | BBDT | IFDT | RFDT | GFDT | BFDT | (Initial value: 0000 0000) | | | | | | | | • | | | | | | IBDT/<br>RBDT/<br>GBDT/<br>BBDT | Backç | ground cole | or select | | 0110:<br>0111:<br>1000:<br>1001:<br>1010:<br>1011:<br>1100:<br>1101: | Blue Green Cyan Red Magenta Yellow White Black Dark blue Dark greei Dark red Dark mage Dark yello | enta | Wri | iite | | IFDT/<br>RFDT/<br>GFDT/<br>BFDT | Fringi | ng color se | elect | | 0000:<br>0001:<br>0010:<br>0011:<br>0100:<br>0101:<br>0110:<br>0111:<br>1000:<br>1010:<br>1010:<br>1100:<br>1101: | Black Blue Green Cyan Red Magenta Yellow White Black Dark blue Dark greei Dark cyan Dark red Dark mage | enta | oni | ly | Note: Set IBDT and IFDT to 1 when PISEL (Bit6 in ORETC) sets to 1. Then background color select and fringing color select are 8 variety. ORACL (00FA6H) | ACLI2 | ACLR2 | ACLG2 | ACLB2 | ACLI1 | ACLR | ACLG1 ACLB1 | (Initial value: | 0000 0000) | | |----------|--------|------------|-------------|-------|------|---------------------------|------------------|------------|-------| | | | | | | | | | | | | | | | | | | Black | | | | | | | | | | | Blue | | | | | | | | | | | Green | | | | | | | | | | | Cyan | | | | | | | | | | 0100 | | | | | | 4.01.107 | | | | | | Magenta | | | | | ACLI2/ | | | | | | Yellow | | | | | ACLR2/ | Area 2 | 2 plane co | lor select | | | White | | | | | ACLG2/ | | • | | | | Black | | | | | ACLB2 | | | | | | Dark blue | | | | | | | | | | | Dark green | | | | | | | | | | | Dark cyan<br>Dark red | | | | | | | | | | | Dark magenta | | | | | | | | | | | Dark magenta Dark yellow | | | | | | | | | | | Gray | | | | | | | | | | | Black | | | | | | | | | | | Blue | | | Write | | | | | | | | Green | | | only | | | | | | | | Cyan | | | Only | | | | | | | 0100 | | | | | | | | | | | | Magenta | | | | | ACLI1/ | | | | | | Yellow | | | | | ACLR1/ | A 4 | 4 | | | 0111 | White | | | | | ACLG1/ | Area | 1 plane co | olor select | | 1000 | Black | | | | | ACLB1 | | | | | 1001 | Dark blue | | | | | | | | | | 1010 | Dark green | | | | | | | | | | 1011 | Dark cyan | | | | | | | | | | | Dark red | | | | | | | | | | | Dark magenta | | | | | | | | | | | Dark yellow | | | | | | | | | | | Gray | | | | | ACLI2 | | | | | | lot assign half transpare | | ne | | | | | | | | | ssign half transparency | | | | | ACLI1 | | | | | | lot assign half transpare | | ne | | | | | | | | 1: | Assign half transparency | for area 1 plane | | | 0 Note: Set ACLI2 and ACLI1 to 1 when PISEL (Bit6 in ORETC) sets to 1. Then area 2 plane color select and area 1 plane color select are 8 variety. | ORIV | 7 | 6 5 | 4 | 3 | 2 | 1 | 0 | | | |--------------------|-------------------------------|----------------------------------------------------------------------------|--------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------------|--------------------------| | (00FBBH) | VDPOL H | IDPOL YBLI | RGBII | YIV | BLIV | RGBIV | IIV | (Initial value: 0000 0 | 000) | | | | 1 | | | | | | | | | | VDPOL | VD input pol | arity select | | | on-invert invert invert in | | al . | | | | LIDDOI | | | | | on-invert i | | al | | | | HDPOL | HD input pol | arity select | | 1: lr | vert input | | | | | | YBLII | Y/BLIN input | oolarity sele | ect | | ctive high ctive low | | | | | | RGBII | RIN, GIN, BIN | I input pola | arity | 0: A | ctive high | | | | | | | select | | | | ctive low | | | Write only | | | YIV | Y output pola | ity select | | 1: A | ctive low | | | | | | BLIV | BL output pol | arity select | | | ctive high ctive low | | | | | | RGBIV | R, G, B outpu | t polarity se | elect | 0: A | ctive high | | | | | | | , , , , , , | | | | ctive low<br>ctive high | | | | | | IIV | I output polar | ty select | | | ctive low | | | | | | | JI. | | | l . | | | | | | ORDMA | 7 | 6 5 | 4 | 3 | 2 | 1 | 0 | | | | (00024H) | DMA7 | DMA6 DMA | DMA4 | DMA3 | DMA2 | DMA1 | DMA0 | (Initial value: 0000 0 | 000) | | (00025H) | <u> </u> | | . j | | | <u> </u> | DMA8 | (Initial value: **** * | **0) | | | | | | | | | | | | | | DMAn | Display me | mory addre | ss | | | | | Write | | | | | | | | | | | only | | | | | | | | | | | (n: 0 to 8) | | | | | | | | | | | | | | | - | rite all bits | of display | memory | address, | writng DM | IA7 to DMA0 after DMA8, wh | | | | | necessary to visplay address. | rite all bits | of display | memory | address, | writng DM | A7 to DMA0 after DMA8, wh | | | ODDON | d | isplay address. | | | | | - | IA7 to DMA0 after DMA8, wh | | | ORDSN<br>(0001 DH) | d<br>7 | isplay address. | 4 | 3 | 2 | 1 | 0 | | en writing | | ORDSN<br>(0001DH) | d<br>7 | isplay address. | | | | | - | IA7 to DMA0 after DMA8, wh | en writing | | | 7<br> | isplay address. 6 5 SLNT EUL | 4<br>BLF | 3<br>IDT | 2<br>RDT | 1<br>GDT | 0<br>BDT | | en writing | | | d<br>7 | isplay address. | 4<br>BLF | 3<br>IDT | 2<br>RDT | 1 | 0<br>BDT | | en writing | | | 7<br>- SLNT | splay address. 6 5 SLNT EUL Slant enable register Underline ena | 4<br>BLF<br>specification | 3 IDT | 2<br>RDT<br>0: D<br>1: E | 1<br>GDT<br>isable slar | 0<br>BDT | | en writing | | | 7<br> | splay address. 6 5 SLNT EUL Slant enable register Underline enaregister | 4 BLF specification | 3 IDT | 2<br>RDT<br>0: D<br>1: E<br>0: D | 1<br>GDT<br>isable slar<br>nable slan | 0<br>BDT | | en writing | | | 7<br>- SLNT | Slant enable register Underline enaregister Blinking enab | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D | 1 GDT isable slan nable slan isable und nable und isable blin | 0 BDT Int t erline erline king | | en writing | | | 7 - SLNT | splay address. 6 5 SLNT EUL Slant enable register Underline enaregister | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 1: E | 1 GDT isable slan nable slan isable und nable und isable blin nable blink | 0 BDT Int t erline erline king | | en writing | | | 7 - SLNT | Slant enable register Underline enaregister Blinking enab | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 1: E 0: D 0: D | 1 GDT isable slar nable slan isable und nable und isable blin nable blink Black | 0 BDT Int t erline erline king | | en writing | | | 7 - SLNT | Slant enable register Underline enaregister Blinking enab | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 1: E 0: D | 1 GDT isable slar nable slan isable und nable und isable blin nable blink Black | 0 BDT Int t erline erline king | | en writing | | | 7 - SLNT | Slant enable register Underline enaregister Blinking enab | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 1: E 0: D | 1 GDT isable slan nable slan isable und nable blin nable blin Black Blue Green | 0 BDT Int t erline erline king | | en writing | | | 7 - SLNT | Slant enable register Underline enaregister Blinking enab | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D | 1 GDT isable slan nable unden nable unden nable blink Black Blue Green Cyan Red | 0 BDT Int t erline erline king | | en writing ****) Read/ | | | T SLNT EUL BLF | Slant enable register Underline enaregister Blinking enab | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D | isable slan<br>nable slan<br>isable und<br>nable blin<br>nable blink<br>Black<br>Blue<br>Green<br>Cyan<br>Red<br>Magenta | 0 BDT Int t erline erline king | | en writing | | | TOT/ | Slant enable register Underline enaregister Blinking enab | 4 BLF specification | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 0: D 0: E 0: D | isable slannisable under isable blinnisable blinnisabl | 0 BDT Int t erline erline king | | en writing ****) Read/ | | | TOT/RDT/ | Slant enable register Underline enaregister Blinking enab | BLF specification ble specific e specifica | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 0: D 1: E 0: D 0: D 1: E 0: D 0: D 1: D 0: 0 | isable slannisable under nable blink blue Green Cyan Red Magenta Yellow White | 0 BDT Int t erline erline king | | en writing ****) Read/ | | | T SLNT EUL BLF IDT/ RDT/ GDT/ | Slant enable register Underline enaregister Blinking enabregister | BLF specification ble specific e specifica | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 1: E 0: O01: 0010: 0111: 0100: 0111: 1000: | isable slan isable und nable und isable blin Black Blue Green Cyan Red Magenta Yellow White Black | 0 BDT Int t erline erline king | | en writing ****) Read/ | | | TOT/RDT/ | Slant enable register Underline enaregister Blinking enabregister | BLF specification ble specific e specifica | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 1: E 0: O001: 0010: 0111: 1000: 0111: 1000: 1001: | isable slannisable under nable blink blue Green Cyan Red Magenta Yellow White | 0 BDT Int tt erline erline king king | | en writing ****) Read/ | | | T SLNT EUL BLF IDT/ RDT/ GDT/ | Slant enable register Underline enaregister Blinking enabregister | BLF specification ble specific e specifica | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 0: D 1: E | isable slan isable und nable und isable blin Black Blue Green Cyan Red Magenta Yellow White Black Dark blue | 0 BDT Int t terline erline king king | | en writing ****) Read/ | | | T SLNT EUL BLF IDT/ RDT/ GDT/ | Slant enable register Underline enaregister Blinking enabregister | BLF specification ble specific e specifica | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 0: D 1: E 1 | isable slannable under isable blink black Blue Green Cyan Red Magenta Yellow White Black Dark blue Dark gree Dark cyan Dark red | 0 BDT Int tt erline erline king king | | en writing ****) Read/ | | | T SLNT EUL BLF IDT/ RDT/ GDT/ | Slant enable register Underline enaregister Blinking enabregister | BLF specification ble specific e specifica | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 0: D 1: E 1 | isable slarnable slan isable und nable und isable blink black blue Green Cyan Red Magenta Yellow White black black black black bark blue Dark green Dark cyan park red bark magenta cyan ma | 0 BDT Int tt erline erline king king | | en writing ****) Read/ | | | T SLNT EUL BLF IDT/ RDT/ GDT/ | Slant enable register Underline enaregister Blinking enabregister | BLF specification ble specific e specifica | 3 IDT | 2 RDT 0: D 1: E 0: D 1: E 0: D 0: D 1: E 1 | isable slarnable slandisable under isable blindisable | 0 BDT Int tt erline erline king king | | en writing ****) Read/ | Note: Set IDT to 1 when PISEL (Bit6 in ORETC) sets to 1. Then character color select is 8 variety. | ORCRA | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------------------|----------|-----------------|--------------|---------------|-------------|----------|-------------------------------|--------|--------------------------|----------------| | (0001EH) | CRA7 | CRA6 | CRA5 | CRA4 | CRA3 | CRA2 | CRA1 | CRA0 | (Initial value: **** *** | **) | | (0001FH) | | | | | | | <u> </u> | CRA8 | (Initial value: **** *** | **) | | | | | | | | | | | | | | | CRAn | Cha | aracter cod | de | | | | | | Read/<br>Write | | | | | | | | | | | ( | n: 0 to 8) | | | Note: Wr | ite or rea | ad CRA7 t | to CRA0 a | after write | or read | CRA8. | | | | | ORWVSH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | (00FBCH) | WVSH7 V | VVSH6 | WVSH5 | WVSH4 | WVSH3 | WVSH | 2 WVSH1 | WVSH0 | (Initial value: 0000 00 | 00) | | (00FBDH) | - : | _ | - | - | - | - | - | WVSH8 | (Initial value: **** *** | ·(0) | | | | | | | | | | | | | | | WVSLn | W/in | idow uppe | r limit nos | ition | | | | | Write | | | WVOLII | VVII | idow uppe | i iiiiiii pos | Sition | | | | | only | | | | | | | | | | | ( | n: 0 to 8) | | ODWVCI | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | ORWVSL<br>(00FBEH) | | VVSL6 | WVSL5 | WVSL4 | WVSL3 | WVSL | | | (Initial value: 0000 00 | 201 | | (00FBFH) | VVV3L7 V | - VVSLO | WVSLS | VVV SL4 | W V SLS | I WWSL | 2 WV3L1 | WVSL8 | (Initial value: **** *** | , | | (001 D111) | | | ٠ | | | <u> </u> | | VVVOLO | (iiiliai vaide. | 0) | | | | | | | | | | | | Write | | | WVSLn | Win | dow lowe | r limit pos | ition | | | | | only | | | | | | | | | | | ( | n: 0 to 8) | | | | | | | | | | | | | | ORDON | 7 | 6 | 5 | 4 | , 3 | 2 | 1 | 0 | | | | (00F80H) | | | اـــــا | | | RGWF | REWDW | DON | (Initial value: **** *00 | 00) | | | | ı | | | | • | <u> </u> | ` | | | | | RGWR | Writte | n data trar | nsfer cont | rol | | (Initial state<br>Transfers w | , | to OSD circuit | | | | NOW! | · · · · · · · · | ii data tiai | 10101 0011 | | | | | is reset to 0) | <b>.</b> | | | EWDW | Windo | w enable | specificat | ion | | Disable win | | | Read/<br>Write | | | | registe | er | | | | Enable wind | | on | _ | | | DON | Displa | y on/off se | elect | | | Disable disp<br>Enable disp | • | | | | | L | 1 | | | | 1. | _nable disp | лау | | | | ORRCL | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | |----------|-------|------|------|------|------|------|------|------|----------------------------| | (00FA7H) | EBKGD | EXBL | AON2 | AON1 | RCLI | RCLR | RCLG | RCLB | (Initial value: 0000 0000) | | EBKGD | Background function enable specification register | No background function Background function enable | | |--------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | EXBL | Full-raster blanking enable specification register | O: No Full-raster blanking 1: Full-raster blanking | | | AON2 | Area 2 plane display enable specification register | O: No area 2 plane display 1: Area 2 plane display enable | | | AON1 | Area 1 plane display enable specification register | O: No area 1 plane display 1: Area 1 plane display enable | | | RCLI<br>RCLR/<br>RCLG/<br>RCLB | Raster plane color select | 0000: Black 0001: Blue 0010: Green 0011: Cyan 0100: Red 0101: Magenta 0110: Yellow 0111: White 1000: Black 1001: Dark blue 1010: Dark green 1011: Dark cyan 1100: Dark red 1101: Dark magenta 1110: Dark yellow 1111: Gray | Write<br>only | Note: Set RCLI to 1 when PISEL (Bit6 in ORETC) sets to 1. Then transfer plane select is 8 variety. | ORAHS1 | 7 6 | 5 5 | 4 | 3 | 2 | 1 | 0 | | | |----------------------|----------------|---------------------------------|--------------|------------|--------------|----------|----------------|---------------------------|---------| | (00FA8H) | AHS17 AHS | S16 AHS15 | AHS14 | AHS13 | AHS12 | AHS11 | AHS10 | (Initial value: 0000 0000 | 0) | | (00FA9H) | | | | | <u> </u> | | AHS18 | (Initial value: **** ***0 | ) | | ORAHE1 | | | | | | | | | | | (00FAAH) | AHE17 AHI | E16 AHE15 | AHE14 | AHE13 | AHE12 | AHE11 | AHE10 | (Initial value: 0000 0000 | 0) | | (00FABH) | | j | <del>.</del> | | <del>-</del> | | AHE18 | (Initial value: **** ***0 | ) | | | | I | | | | | | | | | | AHS1n<br>AHE1n | Horizontal sta<br>Horizontal en | | | | | | | Write | | | ALEIII | Honzoniai en | и роши ю | alea i p | iaile | | | (n: | 0 to 8) | | | | | | | | | | ζ | , | | ORAVS1 | | | | | ı | ı | | | | | (00FACH) | AVS17 AVS | S16 AVS15 | AVS14 | AVS13 | AVS12 | AVS11 | AVS10 | (Initial value: 0000 0000 | , | | (00FADH) | تسلستا | j | ! <u>_</u> ! | | <u> </u> | <u> </u> | AVS18 | (Initial value: **** ***0 | ) | | ORAVE1 | | | 1 | | ı | ı | T1 | | | | (00FAEH) | AVE17 AVE | E16 AVE15 | AVE14 | AVE13 | AVE12 | AVE11 | AVE10 | (Initial value: 0000 0000 | • | | (00FAFH) | | | | | <u> </u> | | AVE18 | (Initial value: **** ***0 | ) | | | AVS1n | Vertical start | point for a | rea 1 plai | 20 | | | | Write | | | AVE1n | Vertical start | • | | | | | | only | | | | | | | <u>-</u> | | | (n: | 0 to 8) | | | | | | | | | | | | | ORAHS2 | A11007 A116 | 000 411005 | ALICO 4 | A11000 | 411000 | A11004 | 411000 | | | | (00FB0H)<br>(00FB1H) | AHS27 AHS | S26 AHS25 | AHS24 | AHS23 | AHS22 | AHS21 | AHS20<br>AHS28 | | | | (001 1111) | | | ; | | | | A11020 | | | | ORAHE2 | AUE07 AU | E00 ALIE0E | ALIE04 | A11500 | ALIFOO | ALIFOA | 411500 | (1-14-1-1-1 | | | (00FB2H) | AHE27 AHI | E26 AHE25 | AHE24 | AHE23 | AHE22 | AHE21 | AHE20 | (Initial value: 0000 0000 | , | | (00FB3H) | | | ;; | | ! | 1 | AHE28 | (Initial value: **** ***0 | ') | | | AHS2n | Horizontal sta | art point fo | r area 2 p | olane | | | | Write | | | AHE2n | Horizontal en | d point for | r area 2 p | lane | | | | only | | | | | | | | | | (n: | 0 to 8) | | ODAVCO | | | | | | | | | | | ORAVS2<br>(00FB4H) | AVS27 AVS | S26 AVS25 | AVS24 | AVS23 | AVS22 | AVS21 | AVS20 | (Initial value: 0000 0000 | )) | | (00FB5H) | | - ! - | - | - | - | - | AVS28 | (Initial value: **** ***0 | • | | (, | ' | | ! | | <u> </u> | L | | ( | , | | ORAVE2 | AVE27 AVE | E26 AVE25 | AVE24 | AVE23 | AVE22 | AVE21 | AVE20 | (Initial value: 0000 0000 | )) | | (00FB6H)<br>(00FB7H) | /\V_2/ /\V | | | - | - | - | AVE28 | (Initial value: **** ***0 | • | | (001 5711) | | | J J | | 1 | L | | (IIIIIai vaido. 0 | , | | | AVS2n | Vertical start | point for a | rea 2 plai | ne | | | | Write | | | AVE2n | Vertical end | point for ar | ea 2 plan | ie | | | | only | | | | | | | | | | (n: | 0 to 8) | | ORP6S | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | _ | | |-------------------|-----------------|------------------|-------------------|-------------|--------|------------|-----------------------|---------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------|-------| | (00FBAH) | P67S | P66S | P65S | P64S | PIDS | YBLC | S | MΡ | KS | (Initial value: 0000 0000 | ) | | | | | | | | 1 | | | | | | | | P67S to<br>P64S | Р6 ро | rt output s | elect | | | R, G, B,<br>P67 to F | | | | | | | PIDS | I pin c | output sele | ect | | | I signal<br>P57 por | t outp | out | | | | | YBLCS | Y/BL s | signal sele | ect | | 1: | Y signal<br>BL signa | al out | tput | | Write | | | MPXS | R, G, | B, Y/BL si | gnal seled | ct | 01:<br>10: | higher p<br>Output of | oriority<br>of sig<br>of sig<br>neous | y)<br>nal from<br>nal from<br>s output | (Signal from the OSD circuit has internal OSD circuit externally input (Externally input signal has | only | | ORETC<br>(00FB8H) | 7<br>VDSMD | 6<br>PISEL | 5<br>BKMF | 4<br>ESMZ | 3 "0" | 2<br>MFYW | 1<br>/R MB | | 0<br>RDWRV | (Initial value: 0000 0000 | ) | | | VDSMD | Scan | mode sele | ect | | 0:<br>1: | Normal<br>Double | | - | | | | | PISEL | I pin f | unction se | lect | | 0:<br>1: | 15 color<br>Half trar | - | ency/ha | If tone | | | | BKMF | Blinkir | ng master | | | | Double<br>Enable | | 0 | | | | | ESMZ | Smoo<br>registe | thing enat<br>er | ole specifi | cation | 0:<br>1: | Disable<br>Enable | | U | | Write | | | MFYWR | Displa<br>select | ay memory | read mo | de | 0:<br>1: | Normal<br>Read-m | | - | ode | only | | | МВК | Displa<br>switch | ay memory<br>ning | / bank | | | options | | | acter code or character display er display option and character | | | | RDWRV | Read/ | write mod | e select | | | | | | display memory<br>display memory | | Note: Clear "0" to Bit3 in ORETC. | ORIRC | 7 | <br>6 | | 5 | 4 | 3 | 2 | 1 | 0 | | |----------|---|-------|---|---|-----|---|-----|---|---|----------------------------| | (00FB9H) | | | • | | SDV | | ISE | C | 1 | (Initial value: ***0 0000) | | SVD | Interrupt source select | O: Interrupt request by ISDC value 1: Interrupt request at falling edge of VD signal | | |------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | ISDC | Interrupt generation line select | When the line display of the ISDC value ends (with the falling edge of HD signal) while SVD = 0, interrupt request is generated. 0000: Request interrupt when display of low-order 4 bits "0000" of DCTR ends. 0001: Low-order 4 bits "0001" of DCTR 0010: Low-order 4 bits "0011" of DCTR 0011: Low-order 4 bits "0111" of DCTR 0100: Low-order 4 bits "0101" of DCTR 0101: Low-order 4 bits "0111" of DCTR 0110: Low-order 4 bits "0111" of DCTR 0111: Low-order 4 bits "0111" of DCTR 1000: Low-order 4 bits "1000" of DCTR 1001: Low-order 4 bits "1000" of DCTR 1001: Low-order 4 bits "1001" of DCTR 1010: Low-order 4 bits "1010" of DCTR 1011: Low-order 4 bits "1010" of DCTR 1011: Low-order 4 bits "1101" of DCTR 1101: Low-order 4 bits "1101" of DCTR 1101: Low-order 4 bits "1101" of DCTR 1101: Low-order 4 bits "1101" of DCTR 1101: Low-order 4 bits "1101" of DCTR | Write | | ORIRC | | | | |----------|----------|--------|----------------------------| | (00FB9H) | [-]-]-]- | , DCTR | (Initial value: **** 0000) | | DCTR | Display line counter | 0000: No line display or when the display of the 16th line ends. 0001: 1st line display ends. 0010: 2nd line display ends. 0011: 3rd line display ends. 0110: 4th line display ends. 0100: 4th line display ends. 0110: 5th line display ends. 0110: 6th line display ends. 0111: 7th line display ends. 1000: 8th line display ends. 1001: 9th line display ends. 1011: 1th line display ends. 1011: 1th line display ends. | Read<br>only | |------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------| | | | ' ' | | - Note 1: The display line counter also increments when a line with all blank data or a line with display off is specified. If display lines are overlapped each other, previous display line is enabled and next line is disabled. At this time, the display line counter for canceled line does not increment. - Note 2: \*: Don't care. - Note 3: 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.) Figure 2.15-30 OSD Control Register List (1/2) | 1 | | | | <u> </u> | D'1 / | ~ · · · · · · · · · · · · · · · · · · · | | - 3 - | | ( · ) | |----------|----------|---------|--------|----------|--------------|-----------------------------------------|--------|--------|---------|--------------------------------------------------------------------------------------------| | Register | Register | D::- | Dire | | gister Bit ( | | | D::4 | D'io | Bit Contents | | Address | Name | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | | | 00F81 | ORHS1 | HS17 | HS16 | HS15 | HS14 | HS13 | HS12 | HS11 | HS10 | HS17 to 10: Code horizontal display base position setting | | 00F82, | ORVSn | VSn7 | VSn6 | VSn5 | VSn4 | VSn3 | VSn2 | VSn1 | VSn0 | VSn8 to 0: Code vertical display position setting (n: 0 to 12) | | 00F83 to | | - | - | - | - | - | - | - | VSn8 | (11. 0 to 12) | | 00F98, | | | | | | | | | | | | 00F99 | | | | _ | | | | | | | | 00F9A | ORCS4 | C | | | S3 | | S2 | | S1 | CSn: Character size (n: 1 to 12) | | 00F9B | ORCS8 | C | | C | | | S6 | | S5 | 00: Display off 10: Middle size 01: Large size 11: Small size | | 00F9C | ORCS12 | CS | | | 511 | | 310 | _ | S9 | · · · • · · · · · · · · · · · · · · · · | | 00F9D | OREULA8 | EULA8 | EULA7 | EULA6 | EULA5 | EULA4 | EULA3 | EULA2 | EULA1 | EULAn: Underline display setting for line n (n: 0 to 12) | | 00F9E | OREULA12 | - | - | - | - | EULA12 | EULA11 | EULA10 | EULA9 | | | 00F9F | OREFR8 | EFR8 | EFR7 | EFR6 | EFR5 | EFR4 | EFR3 | EFR2 | EFR1 | EFRn: Fringing setting for line n (n: 0 to 12) | | 00FA0 | OREFR12 | - | - | - | - | EFR12 | EFR11 | EFR10 | EFR9 | | | 00FA1 | ORCLKF | CK7 | CK6 | CK5 | CK4 | CK3 | CK2 | CK1 | CK0 | CKx: Display clock frequency monitor (x: 0 to 7) | | 00FA1 | ORCLKC | CKC7 | CKC6 | CKC5 | CKC4 | CKC3 | CKC2 | CKC1 | CKC0 | CKCx: Display clock frequency (x: 0 to 7) | | 00FA2 | ORSOL4 | SC | | | DL3 | | DL2 | | DL1 | SOLn: Solid space display setting for line n (n: 0 to 12) | | 00FA3 | ORSOL8 | SC | | | DL7 | | DL6 | | DL5 | 00: No solid space 10: Right 01: Left 11: Left and right | | 00FA4 | ORSOL12 | | L12 | | L11 | | L10 | | L9 | 3 1 | | 00FA5 | ORBK | IBDT | RBDT | GBDT | BBDT | IFDT | RFDT | GFDT | BFDT | IBDT, RBDT, GBDT, BBDT: Background color setting | | 00540 | 0040 | 4.01.10 | 401.00 | 401.00 | A OL DO | 40114 | 101.04 | 401.04 | 4 OL D4 | IFDT, RFDT, GFDT, BFDT: Fringing color setting | | 00FA6 | ORACL | ACLI2 | ACLR2 | ACLG2 | ACLB2 | ACLI1 | ACLR1 | ACLG1 | ACLB1 | ACLI2/ACLR2/ACLG2/ACLB2: Area 2 plane color<br>ACLI1/ACLR1/ACLG1/ACLB1: Area 1 plane color | | | | | | | | | | | | Set ACLI2 and SCLI1 to 1, when PISEL: 1 | | 00FA7 | CRRCL | EBKGD | EXBL | AON2 | AON1 | RCLI | RCLR | RCLG | RCLB | EBKGD: Background function | | 001 A7 | CITICL | LDIOD | LADL | AOIVZ | AOIVI | KOLI | KOLK | KOLO | KOLD | EXBL: Full-raster blanking | | | | | | | | | | | | AON2: Area 2 plane display | | | | | | | | | | | | AON1: Area 1 plane display | | | | | | | | | | | | RCLI/R/G/B: Raster plane color | | | | | | | | | | | | Set RCLI to 1, when PISEL: 1 | | 00FA8 | ORAHS1 | AHS17 | AHS16 | AHS15 | AHS14 | AHS13 | AHS12 | AHS11 | AHS10 | AHSx: Area 1 plane horizontal start position (n: 0 to 8) | | 00FA9 | | ī | ī | - | - | - | - | - | AHS18 | | | 00FAA | ORAHE1 | AHE17 | AHE16 | AHE15 | AHE14 | AHE13 | AHE12 | AHE11 | AHE10 | AHE1x: Area 1 plane horizontal end position (n: 0 to 8) | | 00FAB | | - | - | - | - | - | - | - | AHE18 | | | 00FAC | ORAVS1 | AVS17 | AVS16 | AVS15 | AVS14 | AVS13 | AVS12 | AVS11 | AVS10 | AVS1x: Area 1 plane vertical start position (n: 0 to 8) | | 00FAD | | - | - | - | - | - | - | - | AHS18 | | | 00FAE | ORAVE1 | AVE17 | AVE16 | AVE15 | AVE14 | AVE13 | AVE12 | AVE11 | AVE10 | AVE1x: Area 1 plane vertical end position (n: 0 to 8) | | 00FAF | | - | - | - | - | - | - | - | AVE18 | | | 00FB0 | ORAHS2 | AHS27 | AHS26 | AHS25 | AHS24 | AHS23 | AHS22 | AHS21 | AHS20 | AHS2x: Area 2 plane horizontal start position (n: 0 to 8) | | 00FB1 | | - | - | - | - | - | - | - | AHS28 | | | 00FB2 | ORAHE2 | AHE27 | AHE26 | AHE25 | AHE24 | AHE23 | AHE22 | AHE21 | AHE20 | AHE2x: Area 2 plane horizontal end position (n: 0 to 8) | | 00FB3 | | - | - | - | - | - | - | - | AHE28 | | | 00FB4 | ORAVS2 | AVS27 | AVS26 | AVS25 | AVS24 | AVS23 | AVS22 | AVS21 | AVS20 | AVS2x: Area 2 plane vertical start position (n: 0 to 8) | | 00FB5 | | - | - | - | - | - | - | - | AHS28 | | | 00FB6 | ORAVE2 | AVE27 | AVE26 | AVE25 | AVE24 | AVE23 | AVE22 | AVE21 | AVE20 | AVE2x: Area 2 plane vertical end position (n: 0 to 8) | | 00FB7 | | - | - | - | - | - | - | - | AVE28 | | | 00FB8 | ORETC | VDSMD | PISEL | BKMF | ESMZ | "0" | MFYWR | MBK | RDWRV | VDSMD: Scan mode select | | | | | | | | | | | | PISEL: I pin function select | | | | | | | | | | | | BKMF: Blinking master | | | | | | | | | | | | ESMZ: Smoothing MFYWR: Display memory read mode select | | | | | | | | | | | | MBK: Display memory bank switching select | | | | | | | | | | | | RDWRV: Read/write mode select at normal mode | | 00FB9 | ORIRC | - | - | - | SVD | | IS | DC | | SVD: Interrupt source select | | | 2 | | | | | | | | | ISDC: Interrupt generation line select | | 00FB9 | ORIRC | - | - | - | - | | DC | TR | | DCTR: Display line counter | | 00FBA | ORP6S | P67S | P66S | P65S | P64S | PIDS | YBLCS | MF | XS | P6xS: P6 port output select (x: 4 to 7) | | | | | | | | | | | | | | | | | | | | | | | | PIDS: I pin output select | | | | | | | | | | | | PIDS: I pin output select<br>YBLCS: Y/BL signal select | Figure 2.15-31OSD Control Register List (2/2) | Register | Register | | | Re | gister Bit ( | Configurat | ion | | | Bit Contents | | | |----------|----------|-------|-------|-------|--------------|------------|-------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Address | Name | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | Bit Contents | | | | 00FBB | ORIV | VDPOL | HDPOL | YBLII | RGBII | YIV | BLIV | RGBIV | IIV | VDPOL: √D input polarity select HDPOL: HD input polarity select YBLII: YBLIN input polarity select RCBII: RIN, GIN, BIN input select YIV: Y output polarity select BLIV: BL output polarity select RCBIV: R, G, B output polarity select IIV: Ip in polarity select IIV: Ip in polarity select | | | | 00024 | ORDMA | DMA7 | DMA6 | DMA5 | DMA4 | DMA3 | DMA2 | DMA1 | DMA0 | DMAx: Display memory address setting (x: 0 to 8) | | | | 00025 | | - | - | _ | - | - | _ | - | DMA8 | | | | | 0001D | ORDSN | 1 | SLNT | EUL | BLF | IDT | RDT | GDT | BDT | SLNT: Slant EUL: Underline BLF: Blinking IDT/RDT/CDT/BDT: Character color | | | | 0001E | ORCRA | CRA7 | CRA6 | CRA5 | CRA4 | CRA3 | CRA2 | CRA1 | CRA0 | CRAx: Character code (x: 0 to 8) | | | | 0001F | | - | - | - | - | - | - | - | CRA8 | | | | | 00FBC | ORWVSH | WVSH7 | WVSH6 | WVSH5 | WVSH4 | WVSH3 | WVSH2 | WVSH1 | WVSH0 | WVSHx: Window upper limit position (x: 0 to 8) | | | | 00FBD | | - | - | - | - | - | - | - | WVSH8 | | | | | 00FBE | ORWVSI | WVSL7 | WVSL6 | WVSL5 | WVSL4 | WVSL3 | WVSL2 | WVSL1 | WVSL0 | WVSL: Window lower limit position (x: 0 to 8) | | | | 00FBF | | - | - | - | - | - | - | - | WVSL8 | | | | | 00F80 | ORDON | ı | ı | ı | ı | _ | RGWR | EWDW | DON | RGWR: Writing data transfer control<br>EWDW: Window enable<br>DON: OSD display ON/OFF | | | Note 1: Except the meshed registers are changed by RGWR. Note 2: Only lower 2 bits of the register in address 00F80H are changed by RGWR (the register in address 00F80H must not be used with any of the read-modify-write instructions as SET, CLR, etc.). ## 2.16 Jitter Elimination Circuit The TMP88CS38/CM38A/CP38A has a built-in jitter elimination circuit which maintains the vertical stability of the OSD even when input of the vertical signal fluctuates. And the field decision information for the OSD circuit is detected by using jitter elimination circuit. ## 2.16.1 Configuration Figure 2.16.1 Jitter Elimination Circuit #### 2.16.2 Control Jitter elimination circuit is controlled by the jitter elimination control register (JECR). Figure 2.16.2 Jitter Elimination Control Register and Jitter Elimination Status Register #### 2.16.3 Jitter Elimination Mode The jitter elimination circuit is to identify the phase of the falling edges of the external $\overline{\text{VD}}$ signal and $\overline{\text{HD}}$ signal. When $\overline{\text{VD}}$ signal is falling within $\overline{\text{HD}}$ signal falling +/-1/4HD, the jitter is automatically eliminated and internal $\overline{\text{VD}}$ signal is set to the stable location. This function is enabled by setting JEEN (Bit2 in JECR) in the jitter elimination control register to "1". #### 2.16.4 Auto Field Line Decision The internal vertical and horizontal sync. signals corrected by the jitter elimination circuit generate the field line decision signals used in the OSD. The OSD display in normal mode - Type A) When the OSD circuit is used on the TV system which has a phase shift in the vertical and horizontal sync. Signals every other filed such as the interlace TV, enable jitter elimination circuit and set "1" to AFLD and VDSEL. At this time, the field lines which have first and second display dot of character are displayed. - Type B) When the OSD circuit is used on the TV system which has no phase shift in the vertical and horizontal sync. Signals every other filed such as the non-interlace TV, enable jitter elimination circuit and clear "0" to AFLD and VDSEL. At this time, the field line which has a second display dot of character is only displayed. The OSD display in double scan mode Type C) Disable jitter elimination circuit and clear "0" to AFLD and VDSEL. At this time, the field lines which have first and second display dot of character are displayed. Figure 2.16.3 Relation with Field Line and VDSEL, AFLD ## 2.17 Data Slicer The TMP88CS38/CM38A/CP38A contains the data slicer to decode the caption data which multiplied during vertical flyback time of the composite video signal. The composite video signal inputs to the data slicer circuit through P32 (VIN1) and P33 (VIN0). The caption data is decoded from the video signal. The composite video signal including negative sync-tip inputs to VIN0 and VIN1 pins. The data slicer 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. Note: When the data slicer is used at fc = 16 MHz, set to "02H" in FC8CR. When the data slicer is used at fc = 8 MHz, set to "00H" in FC8CR. (Refer to Figure 1.4.5) ## 2.17.1 Configuration Figure 2.17.1 Data Slicer #### 2.17.2 Functions #### (1) Video signal input A low pass filter, a voltage amplifier and a condenser of about $0.1~\mu F$ are connected between the video signal and the video signal input pin of VIN1 and VIN0 pins, that is shown as Figure 2.17.3 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 DACL7 to DACL0 of DACLCR are set for the synchronous separation, the sync slice level is capable of setting. DACL7 to DACL4 set the slice level at the rising edge of the sync signal clamped data, and DACL3 to DACL0 set the slice level at the falling edge of the sync-tip clamped data. (Refer to section 2.17.5) #### (3) Data separator The data separator replaces the caption data piled on the video signal with the digital signal. When SLVL5 to SLVL0 of SLVLCR are set to get the digital signal, the Initial value of the caption data slice level is capable of setting. (Refer to section 2.17.5) ## (4) Sync-tip clamp circuit The sync-tip 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) DA converter This converter gets the DA changed slice level of the clamp circuit to the comparator. #### (7) Comparator This comparator replaces the composite video signal with the digital value while inputting to the comparator. #### (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 horizontal synchronous signal from C.Sync signal separated synchronously from the video signal, and provides line 21 detection signal to take out caption signal to the slice level control part. #### (10) Slice level control circuit This circuit detects CRI (Clock run in) signal from VIDEO signal with line 21 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 revises 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 Interrupts are generated by a rise in the caption line detection signal. Figure 2.17.2 Interrupt Generation Timing See the description of the on-screen display circuit interrupt vectors for details of interrupt vectors. #### (14) C.Sync external input mode The external C.Sync signal can be used internally by setting EXSYNC (SIFSMS1 bit5) to "1". As shown in Figure 2.17.3 (b), insert a low-pass filter ( $f_T = 503 \text{ kHz}$ ), voltage amplifier $(\times\,2$ voltage amplification), and a capacitor of approximately 0.1 $\mu F$ between the video signal and the video signal input pin VIN1 and input an external C.Sync signal to CSIN. The polarity of the C.Sync signal is selected by SYNCINV (SIFSMS1 bit6). (Internally used as $\overline{\text{C.Sync}}$ .) | CSIN (P32) | SYNCINV | |---------------|---------| | C.Sync ( T ) | "0" | | C.Sync (_TT_) | "1" | ## 2.17.3 Video Signal Connection Figure 2.17.3 Video Signal Connection Figure 2.17.4 Data Slicer Control (I) Figure 2.17.5 Data Slicer Control (II) Figure 2.17.6 Data Slicer Control (III) | SIFS1R<br>(00FDFH) | 7<br>[] | 6 5 4 3<br>- GOODV FLINE4 FLINE3 F | 2 1 0 FLINE2 FLINE1 FLINE0 | | |--------------------|---------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------| | | GOODV | Monitor signal of synchronization | O: Out of synchronization (One or more) V timing synchronizing | | | | FLINE | Field scanning line (Standard 262.5 = -1) Two's complement | 00000: 0 263.5<br>00001: 1 264.5<br>00010: 2<br>00011: 3<br>00100: 4<br>00101: 5<br>00110: 6<br>00111: 7<br>01000: 8<br>01001: 9<br>01010: 10<br>01011: 11<br>01100: 12<br>01101: 13<br>01110: 14<br>01111: 15 278.5<br>10000: V synchronizing adjustment<br>10001: - 15 248.5<br>10010: - 14<br>10011: - 13<br>10100: - 12<br>10101: - 11<br>10110: - 10<br>10111: - 9<br>11000: - 8<br>11001: - 7<br>11101: - 6<br>11011: - 3<br>11110: - 2 261.5<br>11111: - 1 262.5 | Read only | Figure 2.17.7 Data Slicer Control (IV) The explanation of the monitor signals (GOODV, FLINE) are as follows. - 1.GOODV 0: Data slicer can not synchronize video signal. - 1: Data slicer can synchronize video signal. - 2.FLINE The number of field signal scanning line which the data slicer is detecting or monitor flag of detecting state. Example: FLINE = 1FH: NTSC signal FLINE = 10H: V synchronizing adjustment Figure 2.17.8 Data Slicer Control (V) ## 2.17.4 Clamp and Data Slicer Operation The slicer uses the following steps to obtain the caption signals: The data slicer has two separation circuits: - a. Sync signal (sync tip clamp + sync signal slice) separation. - b. Caption data (pedestal clamp + data slice) separation. The two circuits are described briefly below. - a. Sync signal (sync tip clamp + sync signal slice) - a-1 Sync tip clamp (Pin 40) ...... The sync tip is clamped at (204/512) VDD [V] as shown in Figure 2.17.9. Figure 2.17.9 Sync Signal Slice #### a-2 Method of sync signal slice The sync signal is separated as shown in Figure 2.17.9. Sync signal separation is accomplished by comparing the voltage of the sync tip-clamped video signal with the sync tip slice level. For a $1 \rightarrow 2$ video signal change, if the sync signal after separation is high, the slice level A is selected; if low, the slice level B is selected. (Sync tip slice level) Slice level = $VSCLAMP + \{(3 + 3X)/512\} VDD$ V<sub>DD</sub>: Power supply voltage VSCLAMP: Sync tip clamp voltage = (204/512) VDD X: Setup data (4 bits) ## b. Caption data (pedestal clamp + data slice) b-1 Pedestal clamp (Pin 41) ...... Clamped at (1/2) VDD [V] as shown in Figure 2.17.10. Figure 2.17.10 Pedestal Clamp #### b-2 Method of data slice The data slice level constitutes a level at which the CCD data is differentiated. The slice level's setup value is indicated by the following: Slice level = VPCLAMP + (X/256) VDD [V] V<sub>DD</sub>: Power supply voltage VPCLAMP: Pedestal clamp voltage = (1/2) VDD X: Setup data (6 bits) #### b-3 Automatic slice level correction circuit The slice level is corrected to the appropriate value during the CRI period. Slice level correction always begins with the setup value of SLVL (Bit5 to bit0 of SLVLCR). If you want the last value to become the initial value of the next slice level, set it to SLVL (Bit5 to bit0 of SLVLCR). # Input/Output Circuit ## (1) Control pins The input/output circuitries of the TMP88CS38/CM38A/CP38A control pins are shown below. | Control Pin | I/O | Input/Output Circuitry | Remarks | |----------------------|-------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | XIN<br>XOUT | I/O | Osc. enable fc | Resonator connection pins (High frequency) $R_f=1.2~M\Omega~(typ.)$ $R_O=0.5~k\Omega~(typ.)$ | | RESET | I/O | Address-trap-reset Watchdog-timer-reset System-clock-reset | Sink open-drain output Hysteresis input Pull-up resistor $R_{IN} = 220 \text{ k}\Omega \text{ (typ.)}$ $R = 1 \text{ k}\Omega \text{ (typ.)}$ | | STOP / INT5<br>(P20) | Input | P20/STOP / INT5 | Hysteresis input $R=1 \ k\Omega \ (typ.)$ | | TEST | Input | RIN | Pull-down resistor $R_{\text{IN}} = 70 \text{ M}\Omega \text{ (typ.)}$ $R = 1 \text{ k}\Omega \text{ (typ.)}$ | ## (2) Input/Output ports | Port | I/O | Input/Output Circuitry | Remarks | |------------------------------------------------|-----|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | P20 | I/O | Initial "High-Z" | Sink open-drain output Hysteresis input $R=1\ k\Omega\ (typ.)$ | | P30<br>to<br>P33<br>P50,<br>P57<br>P70,<br>P71 | I/O | Initial "High-Z" Disable | Tri-state I/O Hysteresis input $R=1\ k\Omega\ (typ.)$ | | P34,<br>P35,<br>P51,<br>P52 | I/O | Open-drain output enable Disable | Tri-state I/O or open-drain output programmable Hysteresis input $R=1\ k\Omega\ (typ.)$ | | P40<br>to<br>P47 | I/O | Initial "High-Z" Disable | Tri-state I/O $R = 1 \text{ k}\Omega \text{ (typ.)}$ | | P53<br>to<br>P56 | I/O | Initial "High-Z" Disable Disable RA Key-on wakeup | Tri-state I/O Hysteresis input Key-on wakeup input ( $V_{IL4}=0.65 \times V_{DD}$ ) $R=1 k\Omega (typ.)$ $R_A=5 k\Omega (typ.)$ $C_A=22 pF (typ.)$ | | Port | I/O | Input/Output Circuitry | Remarks | |----------------------|-----|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P60,<br>P61 | I/O | Initial "High-Z" Disable CA RA Key-on wakeup | Sink open-drain output High current output $I_{OL} = 20$ mA (typ.) $R = 1 \text{ k}\Omega \text{ (typ.)}$ $R_A = 5 \text{ k}\Omega \text{ (typ.)}$ $C_A = 22 \text{ pF (typ.)}$ Key-on wakeup input $(V_{IL4} = 0.65 \times V_{DD})$ | | P62<br>(at<br>CSOUT) | I/O | Initial "High-Z" Disable | Tri-state I/O High current output I <sub>OL</sub> = 20 mA (typ.) $R = 1 \text{ k}\Omega \text{ (typ.)}$ | | P62,<br>P63 | I/O | Initial "High-Z" Disable | Sink open-drain output High current output $I_{OL}=20 \text{ mA (typ.)}$ $R=1 \text{ k}\Omega \text{ (typ.)}$ | | P64<br>to<br>P67 | I/O | Initial "High-Z" Disable | Tri-state I/O $R=1\ k\Omega\ (typ.)$ | ## **Electrical Characteristics** Absolute Maximum Ratings (V<sub>SS</sub> = 0 V) | Parameter | Symbol | Pins | Ratings | Unit | |---------------------------------|---------------------|--------------------------------------|------------------------------------------------------|------| | Supply voltage | $V_{DD}$ | - | -0.3 to 6.5 | | | Input voltage | V <sub>IN</sub> | - | -0.3 to V <sub>DD</sub> + 0.3 | V | | Output voltage | V <sub>OUT1</sub> | - | -0.3 to V <sub>DD</sub> + 0.3 | | | Output ourrent (Por 1 pin) | louT1 | Ports P2, P3, P4, P5, P64 to P67, P7 | 3.2 | | | Output current (Per 1 pin) | I <sub>OUT2</sub> | Ports P60 to P63 | 30 | mA | | Output ourrent (Total) | Σ l <sub>OUT1</sub> | Ports P2, P3, P4, P5, P64 to P67, P7 | 120 | IIIA | | Output current (Total) | Σ Ιουτ2 | Ports P60 to P63 | 120 | | | Power dissipation [Topr = 70°C] | PD | - | TMP88CS38NG: 600<br>TMP88CS38FG/<br>CP38A/CM38A: 400 | mW | | Soldering temperature (Time) | Tsld | - | 260 (10 s) | | | Storage temperature | Tstg | - | -55 to 125 | °C | | Operating temperature | Topr | - | -30 to 70 | | Note: The absolute maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded. Recommended Operating Conditions (V<sub>SS</sub> = 0 V $(V_{SS} = 0 \text{ V}, \text{Topr} = -30 \text{ to } 70^{\circ}\text{C})$ | Parameter | Symbol | Pins | Conditions | | Min | Max | Unit | | |--------------------|-----------|-------------------------|----------------------------------------|--------|------------|----------------------|----------------------|-----| | | | | Fc = 16 MHz | NORN | MAL mode | | | | | Supply voltage | $V_{DD}$ | | Fc = 16 MHz | IDLE 1 | mode | 4.5 | 5.5 | | | | | | | STOP | o mode | | | | | Input high voltage | $V_{IH1}$ | Except hysteresis input | V <sub>DD</sub> = 4.5 to 5.5V | | | $V_{DD} \times 0.70$ | \/ | V | | Input high voltage | $V_{IH2}$ | Hysteresis input | $V_{DD} = 4.5 \text{ to } 5$ | ).5V | | $V_{DD} \times 0.75$ | | V | | | $V_{IL1}$ | Except hysteresis input | \\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | | $V_{DD} \times 0.30$ | | | Input low voltage | $V_{IL2}$ | Hysteresis input | $V_{DD} = 4.5 \text{ to } 5.5V$ | | | 0 | $V_{DD}\times 0.25$ | | | | $V_{IL4}$ | Key-on wakeup input | $V_{DD} = 4.5 \text{ to } 5$ | 5.5V | | | $V_{DD} \times 0.65$ | | | | fc | XIN, XOUT | $V_{DD} = 4.5 \text{ to } 5$ | 5.5V | | 8.0 | 16.0 | | | Clock frequency | f | Internal clock | V <sub>DD</sub> = 4.5 to 5 | f 5\/ | c = 8 MHz | 8.0 | 12.0 | MHz | | | fosc | internal GOCK | V <sub>DD</sub> = 4.5 to 5 | f.50 | c = 16 MHz | 16.0 | 24.0 | | - Note 1: The recommended operating conditions for a device are operating conditions under which it can be guaranteed that the device will operate as specified. If the device is used under operating conditions other than the recommended operating conditions (Supply voltage, operating temperature range, specified AC/DC values etc.), malfunction may occur. Thus, when designing products which include this device, ensure that the recommended operating conditions for the device are always adhered to. - Note 2: Clock frequency fc: Supply voltage range is specified in NORMAL mode and IDLE mode. - Note 3: Smaller value is alternatively specified as the maximum value. DC Characteristics $(V_{SS} = 0 \text{ V}, \text{Topr} = -30 \text{ to } 70^{\circ}\text{C})$ | Parameter | Symbol | Pins | Conditions | Min | Тур. | Max | Unit | |-------------------------------|-------------------|----------------------------------|----------------------------------------------------------|-----|------|-----|------| | Hysteresis voltage | $V_{HS}$ | Hysteresis inputs | | - | 0.9 | - | ٧ | | | I <sub>IN1</sub> | TEST | V <sub>DD</sub> = 5.5 V, V <sub>IN</sub> = 5.5 V/0 V | - | - | ±2 | | | Input ourront | I <sub>IN2</sub> | Open-drain ports | V <sub>DD</sub> = 5.5 V, V <sub>IN</sub> = 5.5 V/0 V | - | - | ±2 | | | Input current | I <sub>IN3</sub> | Tri-state ports | $V_{DD} = 5.5 \text{ V}, V_{IN} = 5.5 \text{ V/0 V}$ | - | - | ±2 | μА | | | I <sub>IN4</sub> | RESET, STOP | $V_{DD} = 5.5 \text{ V}, V_{IN} = 5.5 \text{ V/0 V}$ | - | - | ±2 | | | Input resistance | R <sub>IN2</sub> | RESET | $V_{DD} = 5.5 \text{ V}, V_{IN} = 0 \text{ V}$ | 100 | 220 | 450 | kΩ | | Output lookage current | I <sub>LO1</sub> | Sink open-drain ports | $V_{DD} = 5.5 \text{ V}, V_{OUT} = 5.5 \text{ V}$ | - | - | 2 | μА | | Output leakage current | I <sub>LO2</sub> | Tri-state ports | $V_{DD} = 5.5 \text{ V}, V_{OUT} = 5.5 \text{ V/0 V}$ | - | - | ±2 | μΑ | | Output high voltage | V <sub>OH2</sub> | Tri-state ports | $V_{DD} = 4.5 \text{ V}, I_{OH} = -0.7 \text{ mA}$ | 4.1 | _ | _ | | | Output low voltage | V <sub>OL</sub> | Except XOUT and ports P60 to P63 | $V_{DD} = 4.5 \text{ V}, I_{OL} = 1.6 \text{ mA}$ | - | - | 0.4 | V | | Output low current | I <sub>OL3</sub> | Port P60 to P63 | $V_{DD} = 4.5 \text{ V}, V_{OL} = 1.0 \text{ V}$ | - | 20 | _ | | | Supply current in NORMAL mode | | | V <sub>DD</sub> = 5.5 V<br>fc = 16 MHz (Note 3) | - | 25 | 30 | mA | | Supply current in IDLE mode | I <sub>DD</sub> – | | $V_{IN} = 5.3 \text{ V/0.2 V}$ | _ | 20 | 25 | | | 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 | μА | Note 1: Typical values show those at Topr = $25^{\circ}$ C, $V_{DD} = 5$ V. Note 2: Input Current $I_{\mbox{\scriptsize IN3}}$ : The current through resistor is not included. Note 3: Supply Current $I_{DD}$ : The current (Typ. 0.5 mA) through ladder resistors of ADC is included in NORMAL mode and IDLE mode. AD Conversion Characteristics $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ V} \text{ to } 5.5 \text{ V}, \text{Topr} = -30 \text{ to } 70^{\circ}\text{C})$ | Parameter | Symbol | Conditions | ions Min Typ. Max | | Unit | | |--------------------------------|-------------------|------------------------------------|-------------------|----------|----------|-----| | Analog reference voltage | V <sub>AREF</sub> | supplied from V <sub>DD</sub> pin. | - | $V_{DD}$ | _ | | | Analog reference voltage | V <sub>ASS</sub> | supplied from V <sub>SS</sub> pin. | _ | 0 | _ | V | | Analog reference voltage range | $\Delta V_{AREF}$ | $=V_{DD}-V_{SS}$ | _ | $V_{DD}$ | - | V | | Analog input voltage | $V_{AIN}$ | | V <sub>SS</sub> | _ | $V_{DD}$ | | | Nonlinearity error | | | _ | _ | ±1 | | | Zero point error | | V <sub>DD</sub> = 5.0 V | - | - | ±2 | LSB | | Full scale error | | ν <sub>DD</sub> = 3.0 ν | _ | _ | ±2 | LSB | | Total error | | | _ | _ | ±3 | | Note: The total error means all error except quanting error. | AC Characteristic | s | $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ V})$ | to 5.5 V, Topr = $-3$ | 0 to 70°C) | | | |------------------------------|------------------|--------------------------------------------------|-----------------------|------------|-----|------| | Parameter | Symbol | Conditions | Min | Тур. | Max | Unit | | Machine cycle time | t | in NORMAL mode | 0.5 | | 1.0 | μS | | Machine Cycle time | t <sub>cy</sub> | in IDLE mode | 0.5 | _ | | | | High level clock pulse width | T <sub>WCH</sub> | for external clock operation | 31.25 | | | ns | | Low level clock pulse width | T <sub>WCL</sub> | (XIN input), fc = 16 MHz | 31.23 | _ | _ | 115 | Recommended Oscillating Conditions $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ V} \text{ to } 5.5 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C})$ | Parameter | Oscillator | Oscillation<br>Frequency | Recom | nmended Oscillator | Recommended<br>Constant | | |----------------|-------------------|--------------------------|--------|--------------------|-------------------------|----------------| | | | rrequericy | | | C <sub>1</sub> | C <sub>2</sub> | | High-frequency | Ceramic resonator | 8 MHz | Murata | CSA 8.00MTZ | 30 pF | 30 pF | | oscillation | | 16 MHz | Murata | CSA 16.00MXZ040 | 5 pF | 5 pF | High-frequency oscillation - Note 1: 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). - Note 2: The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following URL; http://www.murata.co.jp/search/index.html ## Notice of ROM Entry When you make a ROM data entry for TMP88CS38 and TMP88CM38A/CP38A, Please transfer one file including program area, vector table area and OSD font area. The ROM area must be transferred is as follows. Flow of ROM data entry ## Package P-SDIP42-600-1.78 Unit: mm P-QFP44-1414-0.80K Unit: mm