TOSHIBA TMP93C071 # CMOS 16-Bit Microcontroller TMP93C071F ### 1. Outline and Feature TMP93C071F is a high-speed advanced 16-bit microcontroller developed for application with VCR system control, software servo motor control and timer control. In addition to basics such as I/O ports, the TMP93C071F has high-speed/high-precision signal measuring circuit, PWM (Pulse-Width-Modulator) and high-precision real timing pulse generator. The device characteristics are as follows: - (1) Original 16-bit CPU (900L CPU) - TLCS-90 instruction mnemonic upward compatible - 16 Mbvte linear address space - · General-purpose registers and register bank system - · 16-bit multiplication/division and bit transfer/arithmetic instructions - High-speed micro DMA: 4 channels (1.6 µs / 2 byte at 20 MHz) - Minimum instruction execution time: 200 ns at 20 MHz - Internal ROM: ROMless (3) - (4) Internal RAM: 8 Kbyte - External memory expansion - Can be expanded up to 16 Mbyte (for both programs and data) - AM8/16 pin (select the external data bus width) - · Can be mixed 8 and 16bit external data buses. - ... Dynamic data bus sizing. - 20-bit time-base-counter (TBC) - · free running counter - · accuracy: 100 ns (at 20 MHz) - overflow: 105 ms (at 20 MHz) - 8-bit timer (TC0): 1 channel - · for CTL linear time counter - 16-bit timer (TC1-5): 5 channels - C-sync count, capstan FG count, general: (3 channels) - Timing pulse generator (TPG): 2 channels - (16-bit timing data + 6-bit-output data) with 8-stages FIFO: 1 channel - (16-bit timing data + 4-bit-output data): 1 channel - · accuracy: 400 ns (at 20 MHz) - (10) Pulse width modulation outputs (PWM) - · 14-bit PWM: 3 channels (for controlling capstan, drum and tuner) - 8-bit PWM: 9 channels (for controlling volume) - · carrier frequency: 39.1 kHz (at 20 MHz) - 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. - and Reliability Assurance / Handling Precautions. TOSHIBA is continually working to improve the quality and the 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 observe standards of safety, and to avoid situations in which a malfunction or failure of a TOSHIBA product could cause loss of human life, bodily injury or damage to property. In developing your designs, please ensure that - TOSHIBA product could cause loss of numan life, bodily injury of 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 products specifications. Also, please keep in mind the precautions and conditions set forth in the TOSHIBA Semiconductor Reliability Handbook. The products described in this document are subject to the foreign exchange and foreign trade laws. The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA CORPORATION for any infringements of intellectual property or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any intellectual property or other rights of TOSHIBA CORPORATION or others. - The information contained herein is subject to change without notice. Purchase of TOSHIBA I2C components conveys a license under the Philips I2C 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. (25) Package (11) 24-bit time base counter capture circuit (Capture 0) • (18-bit timing data + 6-bit trigger data) with 8-stages FIFO: 1 channel capture input sources: Remote-control-input (RMTIN), V-sync, CTL, Drum-PG. general (1 channel) accuracy: 400 ns (at 20 MHz) (12) 17-bit time base counter capture circuit (Capture 1/2) (16-bit timing data + 1-bit trigger data): 2 channel · capture input sources: Drum-FG, Capstan-FG accuracy: 100 ns (at 20 MHz) (13) VISS/VASS detection circuit (VISS/VASS) · CTL duty detection · VASS data 16-bit latch (14) Composite-sync-signal (C-sync) input (C-sync In) Vertical-sync-signal (V-sync) separation (V-sepa) (15) Head Amp switch/Color Rotary control (HA/CR) (16) Pseudo-V/H generator (PV/PH) (17) 8-bit A/D converter (ADC): 16 channels Conversion speed: 95states (9.5 µs at 20 MHz) (18) Serial bus I/F 8-bit synchronous (SIO0, 1): 2 channels UART: 1 channel I<sup>2</sup>CBUS: 1 channel/2 ports Multi - Master function/Master transfer with micro DMA. (19) Watch dog timer (WDT) (20) Interrupt controller (INTC) CPU: 2 sources • • • SWI instruction, and illegal instruction Internal: 20 sources 7-level priority can be set. External: 5 sources (21) I/O ports 57 I/O ports (multiplexed functional pins) • 8 Input ports (P40/AIN3-P47/AIN10: These pins are used as analog input for A/D converter.) 4 Output ports (P24/A20-P27/A23: These pins are also used as address bus outputs.) (22) Standby function: 4 halt modes (RUN, IDLE2, IDLE1, STOP) (23) System clock function Dual clock operation 20 MHz (High-speed: normal)/32 kHz(Low-speed: slow) 17-bit Real Time Counter built in (24) Operating Voltage Vcc = 2.7 to 5.5 V (at 32 kHz) • Vcc = 4.5 to 5.5 V (at 20 MHz) 120 pin QFP 28 mm × 28 mm (Pin pitch: 0.8 mm) Type name QFP120-P-2828-0.80A Figure 1 TMP93C071 Block Diagram ## 2. Pin Assignment And Functions The assignment of input and output pins for the TMP93C071, their names and functions are described below. #### 2.1 Pin Assignment Figure 2.1.1 shows pin assignment of the TMP93C071. Figure 2.1.1 Pin Assignment (120-pin QFP) # 2.2 Pin Names and Functions The names of input/output pins and their functions are described below. Table 2.2.1 Pin Names and Function (1/5) | Pin name | Number of pins | I/O | Functions | |-----------------------|----------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D0 to D15 | 16 | I/O (3-state) | data: 0 to 15 for data bus | | A0 to A19 | 20 | Output | Address: 0 to 19 for address bus | | A20 to A23/ | 4 | Output | Address: 20 to 23 for address bus | | P24 to P27 | | Output | Port 2: Output port | | RD | 1 | Output | Read: strobe signal for reading external memory | | AM8/16 | 1 | Input | data bus width select input (only 8 bit or 8 bit/16 bit) | | PC3, 4/ <del>16</del> | 2 | I/O | Port C3, 4: I/O port that allows selection of I/O on a bit basis. | | AIN14, 15 | | Input | Analog Input: Analog input signal for A/D converter | | ĒĀ | 1 | Input | External access: Always set to _0 | | RESET | 1 | Input | Reset: Initializes LSI.(with pull-up R) | | X1/X2 | 2 | I/O | High Frequency Oscillator connecting pins (20 MHz) | | PB0/ | 1 | I/O | Port B0: I/O port (Open Drain Output) | | XT1 | | Input | Low Frequency Oscillator connecting pin (32 kHz) | | PB1/ | 1 | I/O | Port B1: I/O port (Open drain Output) | | XT2 | | Output | Low Frequency Oscillator connecting pin | | ADREF | 1 | Input | A/D reference Voltage input | | P40 to P47/ | 8 | Input | Port 4: Input ports | | AIN3 to AIN10 | | Input | Analog input: Analog input signal for A/D converter | | PC0 to PC2/ | 3 | I/O | Port C: PC0 to PC2 I/O port that allows selection of I/O on a bit basis. | | AIN11 to AIN13 | | Input | Analog input: Analog input signal for A/D converter | | P57/ | 1 | I/O | Port 57: I/O port | | TIO/ | | Input | 8-bit timer0 (TC0) Input 0 | | | | (schmitt) | | | AIN2 | | Input | Analog input: Analog input signal for A/D converter | | P56/ | 1 | I/O | Port 56: I/O port | | TI4/ | | Input | 16-bit timer4 (TC4) Input 4 | | | | (schmitt) | | | AIN1 | | Input | Analog input: Analog input signal for A/D converter | | P55/ | 1 | 1/0 | Port 55: I/O port | | TI5/ | | Input | 16-bit timer5 (TC5) Input 5 | | | | (schmitt) | | | AIN0 | | Input | Analog input: Analog input signal for A/D converter | | P54/ | 1 | I/O | Port 54: I/O port | | INT0 | | Input | External Interrupt request input 0: Rising edge/ Level selectable | | | | (schmitt) | | | P53/ | 1 | I/O<br> | Port 53: I/O port | | INT1 | | Input | External Interrupt request input 1: Rising edge/ Level selectable | | | | (schmitt) | _/ \J | | P52/ | 1 | I/O | Port 52: I/O port | | INT2/ | | Input | External Interrupt request input 2 Rising edge/Falling edge selectable | | TI1 | | Input | At the state of th | | | | (schmitt) | 16-bit timer1(TC1) Input 1 | Table 2.2.1 Pin Names and Function (2/5) | Pin name | Number of pins | 1/0 | Functions | |---------------------------------------|----------------|------------|------------------------------------------------------------------------| | P51/ | 1 | 1/0 | Port 51: I/O port | | INT3/ | | Input | External Interrupt request input 3 Rising edge/Falling edge selectable | | TI2 | | Input | <i>_</i> <b>_ _ _ _</b> | | | | (schmitt) | 16-bit timer2 (TC2) Input 2 | | P50/ | 1 | I/O | Port 50: I/O port | | INT4/ | | Input | External Interrupt request input 4 Rising edge/Falling edge selectable | | TI3 | | Input | <i></i> | | | | (schmitt) | 16-bit timer3 (TC3) Input 3 | | PWM0 | 1 | Output | PWM (14 bit) output 0: PWM0 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | PWM1 | 1 | Output | PWM (14 bit) output 1: PWM1 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | PA3/ | 1 | 1/0 | Port A3: I/O port | | PWM2 | | 3-state | PWM (14 bit ) output 2: PWM2 output | | | | Open Drain | push/pull or open drain output selectable | | PA4/ | 1 | 1/0 | Port A4: I/O port | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | | | | | | WR | | Output | Write: Strobe signal for writing data on pins D0 to D7 | | PA5/ | 1 | 1/0 | Port A5: I/O port | | PWM3/ | | Output | 8-bit PWM output 3: PWM3 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | HWR | | Output | High write: Strobe signal for writing data on pins D8 to D15 | | P60/ | 1 | I/O | Port 60: I/O port | | PWM4/ | l' | Output | 8-bit PWM output 4: PWM4 output | | , , , , , , , , , , , , , , , , , , , | | 3-state | push/pull or open drain output selectable | | | | Open Drain | passing an open drain earpar eclestable | | | | Opo 2 | | | <del>CS0</del> | | Output | Chip select0: Output _0_ when address is within specified address | | | | | area. | | P61/ | 1 | I/O | Port 61: I/O port | | PWM5/ | | Output | 8-bit PWM output 5: PWM5 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | | | | | | CS1 | | Output | Chip select1: Output _0_ when address is within specified address | | | | | area. | | P62/ | 1 | 1/0 | Port 62: I/O port | | PWM6/ | | Output | 8-bit PWM output 6: PWM6 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | | | | | | CS2 | | Output | Chip select2: Output _0_ when address is within specified address | | | | | area. | Table 2.2.1 Pin Names and Function (3/5) | Pin name | Number of pins | I/O | Functions | |-------------|----------------|---------------------|-------------------------------------------| | P63/ | 1 | I/O | Port 63: I/O port | | PWM7 | | Output | 8-bit PWM output7: PWM7 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | P64/ | 1 | 1/0 | Port 64: I/O port | | PWM8 | | Output | 8-bit PWM output8: PWM8 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | P65/ | 1 | I/O | Port 65: I/O port | | PWM9 | | Output | 8-bit PWM output9: PWM9 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | P66/ | 1 | 1/0 | Port 66: I/O port | | PWM10 | | Output | 8-bit PWM output 10: PWM10 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | P67/ | 1 | I/O | Port 67: I/O port | | PWM11 | | Output | 8-bit PWM output 11: PWM11 output | | | | 3-state | push/pull or open drain output selectable | | | | Open Drain | | | P73/ | 1 | 1/0 | Port 73: I/O port | | SDA0 | | I/O | I <sup>2</sup> CBUS SDA line 0 | | | | (schmitt) | push/pull or open drain output selectable | | | | Open Drain | | | P74/ | 1 | 1/0 | Port 74: I/O port | | SCL0 | | I/O | I <sup>2</sup> CBUS SCL line 0 | | | | (schmitt) | auch/outlon anan dusin authout aslastable | | D75 / | 4 | , | push/pull or open drain output selectable | | P75/<br>SO0 | 1 | I/O | Port 75: I/O port<br>SIO0 send data 0 | | 800 | | Output<br>(schmitt) | | | | | Open Drain | push/pull or open drain output selectable | | P76/ | 1 | I/O | Port 76: I/O port | | SIO | ' | Input | SIO0 receive data 0 | | | | (schmitt) | olog reserve data o | | P77/ | 1 | 1/0 | Port 77: I/O port | | SCK0 | [ | 1/0 | SIO0 transfer clock input/output 0 | | | | (schmitt) | | | | | Open Drain | push/pull or open drain output selectable | | P70/ | 1 | i/O | Port 70: I/O port | | TXD | | Output | UART send data | | | | (schmitt) | push/pull or open drain output selectable | | | | Open Drain | [ · · · · · · | | P71/ | 1 | 1/0 | Port 71: I/O port | | RXD | | Input | UART receive data | | | | (schmitt) | | | P72/ | 1 | 1/0 | Port 72: I/O port | | CTS | | Input | UART clear to send | | | | (schmitt) | | | P80/ | 1 | I/O | Port 80: I/O port | | CTLIN | | Input | Capture input for Control signal (CTL) | | | | (schmitt) | | Table 2.2.1 Pin Names and Function (4/5) | Pin Name | Number of pins | I/O | Functions | | | | | | |------------|----------------|------------|-------------------------------------------------------------|--|--|--|--|--| | P81/ | 1 | I/O | Port 81: I/O port | | | | | | | DFGIN | | Input | Capture input for Drum-FG signal (DFG) | | | | | | | | | (schmitt) | | | | | | | | P82/ | 1 | I/O | Port 82: I/O port | | | | | | | RMTIN | | Input | Capture input for Remote Control Input signal | | | | | | | | | (schmitt) | | | | | | | | P83/ | 1 | 1/0 | Port 83: I/O port | | | | | | | EXT | | Input | External Capture input (Rising edge only) | | | | | | | | | (schmitt) | | | | | | | | P84/ | 1 | 1/0 | Port 84: I/O port | | | | | | | DPGIN | | Input | Capture input for Drum-PG signal (DPG) | | | | | | | | | (schmitt) | | | | | | | | P85/ | 1 | I/O | Port 85: I/O port | | | | | | | CFGIN | | Input | Capture input for Capstan-FG signal (CFG) | | | | | | | | | (schmitt) | | | | | | | | P86/ | 1 | 1/0 | Port 86: I/O port | | | | | | | CSYNC IN | | Input | Capture input for C-sync | | | | | | | | | (schmitt) | | | | | | | | P87/ | 1 | 1/0 | Port 87: I/O port | | | | | | | COMPIN | | Input | Envelope Comparator Input (to HA/CR) | | | | | | | | | (schmitt) | | | | | | | | P90/ | 1 | 1/0 | Port 90: I/O port | | | | | | | TPG12 | l' | Output | TPG12: TPG output 12 | | | | | | | | | Open Drain | • | | | | | | | P91/ | 1 | I/O | Port 91: I/O port | | | | | | | TPG01 | l' | Output | TPG01: TPG output 01 | | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | | P92/ | 1 | 1/0 | Port 92: I/O port | | | | | | | TPG02 | l' | Output | TPG02: TPG output 02 (Internally connected to PV/PH Logic) | | | | | | | 432 | | Open Drain | push/pull or open drain output selectable | | | | | | | P93/ | 1 | I/O | Port 93: I/O port | | | | | | | TPG03 | l' | Output | TPG03: TPG output 03 | | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | | P94/ | 1 | I/O | Port 93: I/O port | | | | | | | TPG04 | l' | Output | TPG04: TPG output 04 (Internally connected to PV/PH Logic ) | | | | | | | 11 004 | | Open Drain | push/pull or open drain output selectable | | | | | | | P95/ | 1 | I/O | Port 95: I/O port | | | | | | | TPG13 | ' | Output | TPG13: TPG output 13 | | | | | | | 11 010 | | | push/pull or open drain output selectable | | | | | | | P96/ | 1 | I/O | Port 96: I/O port | | | | | | | TPG10 | l' | Output | TPG10: TPG output 10 | | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | | P97/ | 1 | I/O | Port 97: I/O port | | | | | | | TPG11 | ' | Output | TPG11: TPG output 11 | | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | | PA0/ | 1 | I/O | Port PA0: I/O Port | | | | | | | PV-PH | [' | Output | | | | | | | | | | 3-state | Pseudo-Vsync/Pseudo-Hsync (PV/PH) output (controlled by | | | | | | | DA4/ | | | TPG02/04.) | | | | | | | PA1/ | 1 | 1/0 | Port PA1: I/O Port | | | | | | | HA (TPG05) | | Output | HA: Head amp switch output (are also used as TPG05 output.) | | | | | | | PA2/ | 1 | 1/0 | Port PA2: I/O Port | | | | | | | CR (TPG00) | | Output | CR: Colour Rotary output (are also used as TPG00 output.) | | | | | | Table 2.2.1 Pin Names and Function (5/5) | Pin name | Number of pins | I/O | Functions | | | | | |-----------------------|----------------|---------------|-------------------------------------------------------------------|--|--|--|--| | PB2/ | 1 | I/O | Port PB2: I/O Port | | | | | | SO1/SI1 | | I/O (schmitt) | SIO1 send data 1 and receive data 1 (Internally connected) | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | PB3/ | 1 | 1/0 | Port PB3: I/O Port | | | | | | SCK1 | | 1/0 | SIO1 transfer clock input/output 1 | | | | | | | | (schmitt) | itt) | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | PB4/ | 1 | I/O | Port PB4: I/O Port | | | | | | SDA1 | | 1/0 | I <sup>2</sup> CBUS SDA line 1 | | | | | | | | (schmitt) | t) | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | PB5/ | 1 | I/O | Port PB5: I/O Port | | | | | | SCL1 | | 1/0 | I <sup>2</sup> CBUS SCL line 1 | | | | | | | | (schmitt) | | | | | | | | | Open Drain | push/pull or open drain output selectable | | | | | | DVCC1, 2, 3 | 3 | | Power supply pins All of these pins should be connected to power | | | | | | | | | source. | | | | | | DGND1, DGND2 (ADGND), | 3 | | GND pins (0 V) All of these pins should be connected to GND (0 V) | | | | | | DGND3 | | | line. | | | | | | | | | DGND2 are also used as ADGND for A/D converter. | | | | | TOSHIBA TMP93C071 ## 3. Operation This section describes the functions and basic operational blocks of TMP93C071 devices. See the "7. Points of Concern and Restrictions" for the using notice and restrictions for each block. ### 3.1 CPU TMP93C071 devices have a built-in high-performance 16-bit CPU (900 / L CPU). (For CPU operation, see TLCS-900 / L CPU in the previous section). This section describes CPU functions unique to the TMP93C071 that are not described in the previous section. #### 3.1.1 Reset To reset the TMP93C071, the RESET input must be kept at 0 for at least 10 system clocks. (1 µs at 20 MHz) within the operating voltage range and with a stable oscillation. When reset is accepted, the CPU sets as follows: Program Counter (PC) according to Reset Vector that is stored FFFF00H to FFFF02H. ``` PC (7 to 0) ← stored data in location FFFF00H PC (15 to 8) ← stored data in location FFFF01H ← stored data in location FFFF02H ``` - · Stack pointer (XSP) for system mode to 100H. - IFF2 to 0 bits of status register to 111. (Sets mask register to interrupt level 7.) - MAX bit of status register to 1. (Sets to maximum mode) - Bits RFP2 to 0 of status register to 000. (Sets register banks to 0.) When reset is released, instruction execution starts from PC (reset vector). CPU internal registers other than the above are not changed. When reset is accepted, processing for built-in I/Os, ports, and other pins is as follows - · Initializes built-in I/O registers as per specifications. - Sets port pins (including pins also used as built-in I/Os) to general-purpose input / output port mode. Note: By resetting, register in the CPU except program counter (PC), status register (SR) and stack pointer (XSP) and the data in internal RAM are not changed. Figure 3.1.1 show the reset timing chart of TMP93C071. ## 3.1.2 AM8/16 pin With fixed 16-bit data bus, external 16-bit data bus or 8-bit data bus is selectable Set this pin to "L". The external data bus width is set by the chip select/wait control register which is described in section 3.6.3. It is necessary to set the program memory to be accessed to 16-bit data bus after reset. ② With fixed external 8-bit data bus Set this pin to "H". The values of bit 4 <B0BUS>, <B1BUS> and <B2BUS> in the chip select/wait control register described in section 3.6.3 are invalid. The external 8-bit data bus is fixed. Figure 3.1.1 TMP93C071 Reset Timing Chat ## 3.2 Memory Map Figure 3.2.1 is a memory map of the TMP93C071. Figure 3.2.1 Memory map ### 3.3 Dual Clock, Standby Function Dual Clock, Stand by Control Circuits consist of (1) System clock Controller, 2 Timing clock Generator for I/O Block, 3 Real Time Clock Generator and 4 Standby Controller. The Oscillator operating mode is classified to (a) Single Clock mode (only X1, X2 pin), and (b) Dual Clock mode (X1, X2, XT1, XT2 pin). Figure 3.3.1 shows a transition figure. Figure 3.3.2 shows the block diagram. Figure 3.3.3 shows I/O registers. Table 3.3.1 shows the internal operation and system clock. (a) Single Clock mode transition figure (b) Dual Clock mode transition figure Figure 3.3 1 Transition Figure The Clock Frequency input from X1, X2 pin is called fc, and the Clock Frequency input from XT1, XT2 pin is called fs. The clock frequency selected by SYSCR1<SYSCK> is called system clock $f_{\text{FPH}}$ . The devided clock of $f_{\text{FPH}}$ is called system clock $f_{\text{SYS}}$ , and the 1 cycle of $f_{\text{SYS}}$ is called 1 state. Table 3.3.1 Internal operation and system clock | Op | erating | Oscillator | | CPU | internal I/O | System clock | |--------|---------|------------------------|-----------------------|---------|---------------|------------------| | ľ | Mode | High<br>Frequency (fc) | Low<br>Frequency (fs) | | | f <sub>SYS</sub> | | | RESET | | | reset | reset | | | | NORMAL | | | operate | operate | | | Single | RUN | oscillation | stop | | | fc/ <sub>2</sub> | | Clock | IDLE2 | | | stop | stop only A/D | | | | IDLE1 | | | | stop | | | | STOP | stop | | | | stop | | | RESET | oscillation | stop | reset | reset | fc/ <sub>2</sub> | | | NORMAL | | progamable | operate | operate | | | Dual | SLOW | programable | oscillation | | | fs/ <sub>2</sub> | | Clock | RUN | Oscillator being u | sed as system | | | programable | | | IDLE2 | clock: oscillation | | stop | stop only A/D | $(fc/_2, fs/_2)$ | | | IDLE1 | Other oscillator: p | rogrammable | | stop | | | | STOP | st | ор | | | stop | The TMP93C071 has not a clock gear circuit. Figure 3.3.2 Block Diagram of Dual Clock, Standby circuits | SYSCR0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|--------------------------|---------------------------|----------------------------------------------------------------------|--------------------------|----------------------|-----------------------|------------------------------------------|----------------------|----------------| | (006EH) | bit Symbol | XEN | XTEN | RXEN | RXTEN | RSYSCK | WUEF | | | | | Read/Write | | | R | W | | | | | | | After reset | 1 | 0 | 1 | 0 | 0 | 0 | | | | | Function | High | | High | | | Warm-Up | | | | | | | | Frequency | | after | Timer | | | | | | | oscillator (fs) | oscillator (fc)<br>after | | released<br>STOP mode | 0 write: | | | | | | 0: stop<br>1: oscillation | 0: stop | released | after<br>released | 0: fc | 1 write: | | | | | | 1. OSCIIIALION | i. Oscillation | STOP mode | | 1: fs | start timer | | | | | | | | 0: stop | 0: stop | | 0 read: end | | | | | | | | 1: oscillation | 1: oscillation | | warm-up | | | | | | | | | | | 1 read: not | | | | | | | | | | | end warm- | | | | 01/0004 | | - | | | 4 | | up | | | | SYSCR1 | hit Cumbal | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | (006FH) | bit Symbol<br>Read/Write | (R/W) | | | | SYSCK<br>R/W | | (R/W) | | | | After reset | (0) | | | | 0 | (0) | (0) | (0) | | | Function | Always set | | | | select | Always set to | | ; (0) | | | diction | to "0" | | | | system | Always set to | U | | | | | | | | | clock | | | | | | | | | | | 0: fc | | | | | | | | | | | 1: fs | | | _ | | SYSCR2 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | (006CH) | bit Symbol | (5.44) | (5.146) | | RTCCK | RTCST | RTCIS1 | RTCIS0 | | | | Read/Write | (R/W) | (R/W) | | R/W<br>0 | R/W | | <u>W</u> | | | | After reset<br>Function | (0) | (0) | | | 0<br>RTC count | Interval time | | | | | Function | | | | source select | | RTC interrup | | | | | | | | | 0: fs (32 kHz) | Counter | 00: f <sub>SYS</sub> /2 <sup>17</sup> or | | | | | | | | | 1: fc (20 MHz) | Clear | (6.55 ms) | (1 s) | | | | | | | | | 1: Start | 01: f <sub>sys</sub> /2 <sup>18</sup> ó | r fs/2 <sup>16</sup> | | | | | | | | | | (131 ms) | (2 s) | | | | | | | | | | 10: f <sub>SYS</sub> /2 <sup>16</sup> 0 | r fs/214 | | | | | | | | | | (328 ms)<br>11: Reserved | (0.8 S) | | | | | | | | | | TT. INCOCIVED | [Hz] | | | SYSCR3 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | (006DH) | bit Symbol | | | | | | | | CLKEN | | | Read/Write | (set to "1") | (set to "1") | (set to "1") | (set to "1") | (set to "0") | (set to "0") | | R/W | | | After reset | 1 | 1 | 1 | 1 | 0 | 0 | | 0 | | | Function | | | | | | | | 0: Disable | | WENDE | | _ | | <del></del> | 4 | | | | 1: Enable | | WDMOD | 1:40 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | (005CH) | bit Symbol<br>Read/Write | WDTE | WDTP1 | WDTP0 | WARM<br>R/V | HALTM | HALTM0 | RESCR | DRVE | | | After reset | 1 | 0 | 0 | 0 | <u>v</u><br>: 0 | 0 | 0 | . 0 | | | Function | WDT | WDT Detection | Ţ., | - | HALTmode | - | 0: Don't | Pin status | | | I anodon | control | . AD A Detection | IIIIG | Timer | , te i illoue | | care | controlling | | | | 0: disable | 00: 215/f <sub>SYS</sub> | | 0: 2 <sup>14</sup> / | | | | STOP mode | | | | 1: enable | ole 01: 2 <sup>17</sup> /f <sub>sys</sub> frequency 00: RUN mode WDT | | | 0: I/O off | | | | | | | | 10: 2 <sup>19</sup> /f <sub>SYS</sub> | | | 01: STOP mo | | | 1: Remains | | | | | 11: 2 <sup>21</sup> /f <sub>SYS</sub> | | 1: 2 <sup>16</sup> / | 10: IDLE1 mo | | RESET | the state | | | | | | | | 11: IDLE2 m | oae | pin<br>internally | before<br>HALT | | | L | <u> </u> | | | inputted | | | internally | ; IIALI | Note1: SYSCR1 <br/> SysCR1 <br/> Note2: Writing "0" to SYSCR1 <SYSCK> enables the high-frequency oscillator regardless of the value of SYSCR0 <XEN>. Additionally, writing "1" to <SYSCK> register enables the low-frequency oscillator regardless of the value of SYSCR0 Additionally, mining a second seco Figure 3.3.3 I/O registers about Dual Clock, Standby #### 3.3.1 System Clock Controller The system clock controller generates system clock (fSYS) for CPU core and internal I/O. It contains two oscillation circuits. The register SYSCR1<SYSCK> changes system clock to either fc or fs, SYSCR0<XEN>, <XTEN> controls enable / disable each oscillator. The system clock (fSYS) is set to fc/2 because of <XEN>="1", <XTEN>="0", <SYSCK>="0" by resetting. For example, fSYS is set to 10 MHz by resetting the case of 20 MHz oscillator is connected to X1, X2 pins. The high frequency (fc) and low frequency (fs) clocks can be easily obtained by connecting a resonator to the X1 / X2, XT1 / XT2 pins, respectively. Clock input from an external oscillator is also possible. The XT1, XT2 pins have also Port PB0, PB1 function. Therefore the case of single clock mode, the XT1, XT2 pins can be used as I/O port pins. Figure 3.3.4 Examples of Resonator Connection Note: Note on using the low frequency oscillation circuit. In connecting the low frequency resonator to ports PB0 and PB1, it is necessary to make the following settings to reduce the power consumption. (connecting with resonators) PBCR <PB0C, PB1C> = "11", PB <PB0, PB1> = "00" (connecting with oscillators) PBCR <PB0C, PB1C> = "11", PB <PB0, PB1> = "10" ## (1) Switching from NORMAL to SLOW mode When the resonator is connected to X1, X2, or XT1, XT2 pin, the warm-up timer is used to change the operation frequency after getting stabilized oscillation. The warm-up time can be selected by WDMOD<WARM>. This starting and ending of warm-up timer are performed like the following example 1, 2 by program. - Note 1: The warm-up timer is also used as a watchdog timer. So, when it is used as a warm-up timer, the watchdog timer must be disabled. - Note 2: The case of using oscillator (not resonator) with stabilized oscillation, a warm-up timer is not need. - Note 3: The warm-up timer is operated by a oscillation clock. Therefore, warm-up time has an error. Table 3.3.2 Warm-up Time | | · · · · · · · · · · · · · · · · · · · | | |--------------------------------|---------------------------------------|----------------| | Warm-up Time | Change to NORMAL | Change to SLOW | | WDMOD <warm></warm> | | | | 0 (214/frequency) | 0.8192 (ms) | 500 (ms) | | 1 (2 <sup>16</sup> /frequency) | 3.2768 (ms) | 2000 (ms) | at fc = 20 MHz, fs= 32 768 kHz ## Clock Setting Example 1: Changing from the high frequency (fc) to the low frequency (fs). | SYSCR0 | EQU | 006EH | |--------|-----|-------------------------------------------------------------------| | SYSCR1 | EQU | 006FH | | WDCR | EQU | 005DH | | WDMOD | EQU | 005CH | | | RES | 7, (WDMOD); Disables Watchdog Timer. | | | LD | (WDCR),B1H; | | | SET | 4, (WDMOD); Sets Warm-up Time to 216/fs. | | | SET | 6, (SYSCR0); Enables Low Frequency (fs). | | | SET | 2, (SYSCR0); Clears and stars Warm-up Timer. | | WUP: | BIT | 2, (SYSCR0); NZ,WUP; Detects End of Warm-up Timer. | | | JR | NZ,WUP; Detects End of vvarin-up Timer. | | | SET | 3, (SYSCR1); Changes $f_{\text{SYS}}$ from Frequency Oscillation. | | | RES | 7, (SYSCR0); Disables High Frequency Oscillation. | | | SET | 7, (WDMOD); Enables Watchdog Timer. | | | | | ## Clock Setting Example 2: changing from the low frequency (fs) to the high frequency (fc). | SYSCR0 | EQU | 006EH | |--------|-----|--------------------------------------------------------| | SYSCR1 | EQU | 006FH | | WDCR | EQU | 005DH | | WDMOD | EQU | 005CH | | | RES | 7, (WDMOD); Disables Watchdog Timer. | | | LD | (WDCR),B1H; Disables Watchdog Timer. | | | RES | 4, (WDMOD); Sets Warm-up Time to 214/fc. | | | SET | 7, (SYSCR0); Enables High Frequency (fc). | | | SET | 2, (SYSCR0); Clears and stars Warm-up Timer. | | WUP: | BIT | 2, (SYSCR0); | | | JR | 2, (SYSCR0);<br>NZ, WUP; Detects End of Warm-up Timer. | | | RES | 3, (SYSCR1); Changes f <sub>SYS</sub> from fs to fc. | | | RES | 6, (SYSCR0); Disables Low Frequency Oscillation. | | | SET | 7, (WDMOD); Enables Watchdog Timer. | #### 3.3.2 Timing Clock Generator The timing clock generator generates sorts of system clock from the basic clock (fc or fs), providing for CPU core and peripheral hardwares. ### (1) Architecture The timing clock generator consists of the system clock generator and the time base counter (TBC) which generates system clock for peripheral hardwares. After resetting, the system clock is generated from high frequency clock (fc) (NORMAL mode). Both Executing the instruction and operating the internal hardwares are synchronized by this system clock. ## (2) Time Base Counter The time base counter consists of a 20-bit up-counter counted by a basic clock divided-by 2 (fc/2 or fs/2), 16-bit data register and control register. Figure 3.3.5 Shows the structure of the time-base counter (TBC). Figure 3.3.5 Shows the structure of the time-base counter (TBC). Time Base Counter.Control Register TBCMOD (0023H) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---|---|-------|-------|-------|-------|-------|-------|--------------|------------| | | | TBC1E | TBC0E | INT | INT | INT | INT | (Reset Value | **00 0000) | | | | | | TBC11 | TBC10 | TBC01 | TBC00 | [` | ′ | | TBC1E | INTTBC Interrupt | 00: INTTBC Interrupt Disable 01: INTTBC0 Interrupt Enable | | |----------|------------------------|---------------------------------------------------------------------|-----| | TBC0E | Enable / Disable | 10: INTTBC1 Interrupt Enable 11: INTTBC0 / INTTBC1 Interrupt Enable | | | INTTBC11 | INTTBC1 Interrupt | 00: TBC12<br>01: TBC14 | R/W | | INTTBC10 | Source Clock Selection | 10: TBC16<br>11: TBC18 | | | INTTBC01 | INTTBC0 Interrupt | 00: TBC11<br>01: TBC13 | | | INTTBC00 | Source Clock Selection | 10: TBC15<br>11: TBC17 | | Time Base Counter Data register 0 Time Base Counter Data Register 1 Time Base Counter Interrupt Request Flag Register TBCIF 7 6 5 4 3 2 1 0 (0026H) TBC1F TBC0F | TBC1E | INTTBC1 Interrupt Request Flag | 0 (W): Clear 1 (W): (Inhibit) 0 (R): No interrupt request 1 (R): Interrupt request | | |-------|--------------------------------|------------------------------------------------------------------------------------|-----| | TBC0F | INTTBC0 Interrupt Request Flag | 0 (W): Clear 1 (W): (Inhibit) 0 (R): No interrupt request 1 (R): Interrupt request | R/W | #### ① Operation The time-base counter outputs (TBC1 to TBC20) are used as clock source or timing data for Timer/Counter, Capture (CAP0/CAP1/CAP2), timing pulse generator (TPG), and other peripheral I/O blocks. The contents of time-base counter outputs TBC5 to TBC20 can be read by reading the time-base counter data registers, TBCDR0 and TBCDR1. Note that the data registers must be read in order of TBCDR0 and then TBCDR1. Time-base counter interrupt requests (INTTBC) can be generated on the rising edges of counter outputs TBC11 to TBC18. The interrupt source is selected by the time-base counter control register TBCMOD <INTTBC11, INTTBC10, INTTBC01, and INTTBC00>. The INTTBC interrupt requests are comprised of two interrupt request signals INTTBC0 and INTTBC1 that are logical OR' ed to generate an interrupt request. Which interrupt is requested can be identified by reading the time base counter interrupt request flag register TBCIF <TBC0F> and <TBC1F>. The INTTBC0 flag <TBC0F> and INTTBC1 flag <TBC1F> can be cleared by writing "0" in the register. Table 3.3.3 lists the interval time of time-base counter outputs. Table 3.3.3 interval time of Time-base Counter (f = fc) | | TBC1 | TBC2 | TBC3 | TBC4 | TBC5 | TBC6 | TBC7 | TBC8 | TBC9 | TBC10 | |----------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|--------------------|--------------------| | Interval Time<br>[s] | 2 <sup>2</sup> /f | 2 <sup>3</sup> /f | 2 <sup>4</sup> /f | 2 <sup>5</sup> /f | 2 <sup>6</sup> /f | 2 <sup>7</sup> /f | 2 <sup>8</sup> /f | 2 <sup>9</sup> /f | 2 <sup>10</sup> /f | 2 <sup>11</sup> /f | | at 20 MHz<br>[µs] | 0.2 | 0.4 | 0.8 | 1.6 | 3.2 | 6.4 | 12.8 | 25.6 | 51.2 | 102.4 | | 1 | TBC11 | TBC12 | TBC13 | TBC14 | TBC15 | TBC16 | TBC7 | TBC18 | TBC19 | TBC20 | |---|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------| | | 2 <sup>12</sup> /f | 2 <sup>13</sup> /f | 2 <sup>14</sup> /f | 2 <sup>15</sup> /f | 2 <sup>16</sup> /f | 2 <sup>17</sup> /f | 2 <sup>18</sup> /f | 2 <sup>19</sup> /f | 2 <sup>20</sup> /f | 2 <sup>21</sup> /f | | | 204.8 | 409.6 | 819.2 | 1638.4 | 3276.8 | 6553.6 | 13107.2 | 26214.4 | 52428.8 | 104857.6 | TOSHIBA TMP93C071 ## 3.3.3 Real Time Counter (RTC) The TMP93C071 has the real time counter (RTC) which generates a periodic interrupt request. The RTC is controlled by System Control Register2 (SYSCR2). The RTC is a 17bit binary counter and its clock source is selected either low frequency clock (fs) or system clock ( $f_{SYS}/2$ ). To start/stop the counter is controlled by <RTCST>. The period of interrupt request INTRTC is selected from 3 types by setting <RTCIS1, RTCIS0>. Table 3.3.4 shows the period of interrupt request INTRTC. SYSCR2 (006CH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------|-------|---|----------------------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|---| | bit Symbol | | | | RTCCK | RTCST | RTCIS1 | RTCIS0 | | | Read/Write | (R/W) | (R/W) | | R/W | R/W | R/ | W | | | After reset | (0) | (0) | | 0 | 0 | ( | ) | | | Function | | | | source<br>select<br>0: fs(32KHz) | 0: Stop &<br>Counter<br>Clear | Interval time<br>RTC interrup<br>00: f <sub>SYS</sub> /2 <sup>16</sup> o<br>(1sec)<br>01: f <sub>SYS</sub> /2 <sup>17</sup> o<br>(0.5sec)<br>11: Inhibit | ot<br>or fs/2 <sup>15</sup> | | Table 3.3.4 INTRTC Interrupt Interval | Table 6.5.4 INTERFERENCE | | | | | | | |-----------------------------------------------------------------------|-----------------|------------------|--|--|--|--| | <rtcck></rtcck> | <rtcis></rtcis> | INTRTC interrupt | | | | | | | | interval | | | | | | 0 | 00 | 1 s | | | | | | (fs = 32.768 kHz) | 01 | 2 s | | | | | | | 10 | 0.5 s | | | | | | 1 | 00 | 6.55 ms | | | | | | $\begin{pmatrix} f_{SYS} = fc/2 \\ fc = 20 \text{ MHz} \end{pmatrix}$ | 01 | 13.1 ms | | | | | | 【 fc = 20 MHz / │ | 10 | 3.28 ms | | | | | #### 3.3.4 Standby Controller #### (1) Halt mode When the HALT instruction is executed, the operating mode changes RUN, IDLE2, IDLE1 or STOP mode depending on the contents of the HALT mode setting register WDMOD<HALTM1,0>. Figure 3.3.6 shows the alternative states of watchdog timer mode registers. Figure 3.3.6 Watchdog timer mode register The features of RUN, IDLE2, IDLE1 and STOP modes are as follows. - ① RUN: Only the CPU halts; power consumption remains unchanged. - ② IDLE2: The built-in oscillator and the specified I/O operates. The Power Consumption is redced to 1/2 than that during NORMAL operation. - ③ IDLE1: Only the built-in oscillator operates, while all other built-in circuits stop. The Power Consumption is reduced to 1/5 or less than that during NORMAL operation. - STOP: All internal circuits including the built-in oscillator stop. This greatly reduces power consumption. | Halt mode | RUN | IDLE2 | IDLE1 | STOP | | | | |----------------------------------|-------------------|------------------------|-------------------|-----------------|--|--|--| | WDMOD <haltm1,0></haltm1,0> | 00 | 11 | 10 | 01 | | | | | CPU | Stop | | | | | | | | I/O port | Keep the state wh | en the "HALT" instruct | ion was executed. | See table 3.3.8 | | | | | 8bit Timer(TC0) | | | | | | | | | 16-bit Timer (TC 1,2,3,4,5) | | | | | | | | | Dual Clock | | | | | | | | | Watchdog Timer | | | | | | | | | Interrupt controller | Ope | rate | St | ор | | | | | Chip select / Wait counter | | | | | | | | | SIO 0,1 | | | | | | | | | 12CBUS | | | | | | | | | UART | | | | | | | | | 8-bit PWM | | | | | | | | | 14-bit PWM | | | | | | | | | Timing Pulse Generator (TPG 0,1) | | | | | | | | | Color Rotary | | | | | | | | | VISS / VASS | | | | | | | | | CSYNC | | | | | | | | | PV / PH | | | | | | | | | Capture input (RMTIN) | | | | | | | | | Capture 0 | | | | | | | | | Remote Control Input (RMTIN) | | | | | | | | | Time Base Counter (TBC) | | | | | | | | | A/D Converter | | | | | | | | | Read Time Counter (RTC) | | | | | | | | Table 3.3.5 I/O Operation During Halt mode ### (2) How to Release the Halt mode These HALT states can be released by resetting or requesting an interrupt. The halt release sources are determined by the combinations between the states of interrupt mask register <IFF2 to 0> and the halt modes. The details for releasing the HALT status are shown in Table 3.3.6. ### · Released by requesting an interrupt The operating released from the halt mode depends on the interrupt enabled status. When the interrupt request level set before executing the HALT instruction exceeds the value of the interrupt mask register, the interrupt due to the source is processed after releasing the halt mode, and CPU starts executing an instruction that follows the HALT instruction. When the interrupt request level set before executing the HALT instruction is less than the value of the interrupt mask register, releasing the halt mode is not executed. (in non-maskable interrupts, interrupt processing is processed after releasing the halt mode regardless of the value of the mask register.) However only for INT0 and INT1 interrupts, even if the interrupt request level set before executing the HALT instruction is less than the value of the interrupt mask register, releasing the halt mode is executed. In this case, interrupt processing is not processed, and CPU starts executing the instruction next to the HALT instruction, but the interrupt request flag is held at "1". · Release by resetting Releasing all halt status is executed by resetting. When the STOP mode is released by RESET, it is necessary enough resetting time (3 ms or more) to set the operation of the oscillator to be stable. When releasing the halt mode by resetting, the internal RAM data keeps the state before the "HALT" instruction is executed. However the other setting contents are initialized. (Releasing due to interrupts keep the state before the "HALT" instruction is executed.) Table 3.3.6 Halt releasing source and Halt releasing operation | | Interrupt | receiving status | Interrupt enable<br>(Interrupt level)≥(Interrupt mask) | | | | Interrupt disable<br>(Interrupt level)<(Interrupt mask) | | | | |-----------|-----------|-------------------|--------------------------------------------------------|-------|-------|------|---------------------------------------------------------|-------|-------|------| | Halt mode | | | RUN | IDEL2 | IDEL1 | STOP | RUN | IDEL2 | IDEL1 | STOP | | | | INTWD | • | × | × | × | _ | _ | _ | _ | | | | INTO, 1 | • | • | • | ⊙*1 | 0 | 0 | 0 | O*1 | | Halt | Interrupt | INTCAP0, 1 | • | • | × | × | × | × | × | × | | releasing | | INTTTG0, 1 | • | • | × | × | × | × | × | × | | source | | INT12CB, INT12DMA | • | • | × | × | × | × | × | × | | | | INTTBC | • | • | × | × | × | × | × | × | | | | INTSIO0, 1 | • | • | × | × | × | × | × | × | | | | INTRX, INTTX | • | • | × | × | × | × | × | × | | | | INTVA | • | • | × | × | × | × | × | × | | | | INT2, 3, 4 | • | 0 | × | × | × | × | × | × | | | | INTT0-5 | • | • | × | × | × | × | × | × | | | | INTAD | • | • | × | × | × | × | × | × | | | | INTRTC | • | • | × | × | × | × | × | × | | | | Reset Input | | • | • | • | • | 0 | • | • | **<sup>©</sup>**: After releasing the halt mode, CPU starts interrupt processing (RESET initializes LSI) Note: When releasing the halt mode is executed by INT0 or INT1 interrupt of the level mode in the interrupt enabled status, hold level "H" until starting interrupt processing. If level "L" is set before starting interrupt processing, interrupt processing is incorrectly started. O: After releasing the halt mode, CPU starts executing an instruction that follows the HALT instruction. $<sup>\</sup>times$ : It can not be used to release the halt mode. <sup>—:</sup> This combination type does not exist because the priority level (interrupt request level) of non-maskable interrupts is fixed to highest priority level "7". <sup>\*1:</sup> Releasing the halt mode is executed after passing the warming-up time. (Example releasing "RUN" mode) INT0 interrupt releases HALT state when the RUN mode is on. | Address | : | | | |---------|------|----------------|------------------------------------------| | 8200H | LD | (IIMC0), 01H | ; INTO interrupt input enable | | 8203H | LD | (IIMC1), 00H | ; Selects interrupt rising edge for INT0 | | 8206H | LD | (INT0CP1), 06H | ; Sets interrupt level to '6' for INT0 | | 8209H | El | 5 | ; Sets interrupt level to '5' for CPU | | 820BH | LD | (WDMOD),00H | ; Sets HALT mode to 'RUN' | | 820EH | HALT | | ; halts CPU | | | : | | | | I | NTO | $\setminus$ — | → INT0 Interrupt routine | | | Ţ | | | | 820FH | LD | XX, XX | RETI | | | | | | | | | | | When halt is released by reset, the states (including those of the internal RAM) before halt state was entered can be maintained. However, if the HALT instruction is executed within the internal RAM, the contents of the RAM way not be maintained. In this case, we recommend releasing the halt state using INTO. ## (3) Operation #### ① RUN mode In the RUN mode, the system clock continues to operate even after a HALT instruction is executed. Only the CPU stops executing the instruction. In the HALT state, an interrupt request is sampled with the falling edge of the internal "CLK" signal. Releasing the RUN mode is executed by the external/internal interrupts. (See Table 3.3.6 Halt releasing source and Halt releasing operation.) Figure 3.3.7 shows the interrupt timing for releasing the HALT state by interrupts in the RUN/IDLE2 mode. Figure 3.3.7 Timing Chart for Releasing the HALT State by Interrupt in RUN/IDLE2 modes ### ② IDLE2 mode In the IDLE2 mode, the system clock is supplied to only specific internal I/O devices, and the CPU stops executing the current instruction. In the IDLE2 mode, the HALT state is released by an interrupt with the same timing as in the RUN mode. The IDLE2 mode is released by external/internal interrupt, except INTWD/INTAD interrupts. (See table 3.3.6 Halt releasing source and Halt releasing operation.) In the IDLE2 mode, the watchdog timer should be disabled before entering the halt status to prevent the watchdog timer interrupt occurring just after releasing the halt mode. #### 3 IDLE1 mode In the IDLE1 mode, only the internal oscillator operates. The system clock in the MCU stops. In the HALT state, and interrupt request is sampled aynchronunsly with the system clock, however the HALT release (restart of operation) is performed synchronously with it. IDLE1 mode is released by external interrupts (INT0, INT1). (See table 3.3.6 Halt releasing source and Halt releasing operation.) Figure 3.3.8 illustrates the timing for releasing the HALT state by interrupts in the IDLE1 mode. Figure 3.3.8 Timing Chart of HALT Released by Interrupts in IDLE1 Mode #### STOP mode The STOP mode is selected to stop all internal circuits including the internal oscillator. The pin status in the STOP mode depends on setting of a bit in the watchdog timer mode register WDMOD<DRVE>. (See Figure 3.3.6 for setting of WDMOD <DRVE>.) Table 3.3.8 summarizes the state of these pins in the STOP mode. The STOP mode is released by external interrupts (INT0, INT1). When the STOP mode is released, the system clock output starts after warm-up time required to attain stable oscillation. The warm-up time can be set using WDMOD<WARM>. See the example of warm-up time (Table 3.3.7). Figure 3.3.9 illustrates the timing for releasing the HALT state by interrupts during the STOP mode. Figure 3.3.9 Timing Chart of HALT State Release by Interrupts in STOP Mode Table 3.3.7 The example of Warm-up time after releasing the stop mode | Clock operation frequency | Warm-up | Clock frequency | | |---------------------------|-------------------------|-------------------------|-----------------| | after the stop mode | WDMOD <warm> = 0</warm> | WDMOD <warm> = 1</warm> | | | fc | 0.8192 | 3.2768 | fc = 20 MHz | | fs | 500 | 2000 | fs = 32.768 kHz | How to calculate the warm-up time WDMOD<WARM> = "0": Clock operation frequency after the 214/STOP mode WDMOD<WARM> = "1": Clock operation frequency after the 2<sup>16</sup>/STOP mode The NORMAL / SLOW mode selection is possible after released STOP mode. This is selected by SYSCR0 <RSYSCK>. Therefore, Setting to <RSYSCK>, <RXEN>, <RXTEN> is necessary before "HALT" instruction is executed. (Setting Example) The STOP mode is entered when the low frequency (fs) operates, and after that high frequency operates after releasing by INT0. Note: When different modes are used before and after STOP mode as the above mentioned, there is possible to release the HALT mode without changing the operation mode by acceptance of the halt release interrupt request during execution of "HALT" instruction (during 8 states). In the system which accepts the interrupts during execution "HALT" instruction, set the same operation mode before and after the STOP mode. Table 3.3.8 Pin states in STOP mode | | | TMP93C071F | | | | |-------------------------------------|--------|----------------------------|----------------------------|--|--| | Pin Name | I/O | WDMOD | WDMOD | | | | | | <drve> = "0"</drve> | <drve> = "1"</drve> | | | | D0 to D15 | 1/0 | Hz | Hz | | | | A16 to A19 | Output | Hz | Output | | | | A20 to A23/P24 to P27 | | | | | | | A0 to A15 | Output | Hz | Output | | | | RD | Output | Hz | "H" Level Output | | | | X1 | Input | | _ | | | | X2 | Output | "H" Level Output | "H" Level Output | | | | PB0/PB1 | 1/0 | — / Hz | — / Output | | | | XT1 | Input | _ | _ | | | | XT2 | Output | "H" Level Output | "H" Level Output | | | | P40 to P47/AIN3 to AIN10 | Input | | _ | | | | P50 to P52, P55 to P57, P60 to P67, | Input | _ | _ | | | | P70 to P77, P80 to P87, | Output | Hz | Output | | | | P90 to P97, PA0 to PA5, PB2 to PB5, | | | | | | | PC0 to PC4 | | | | | | | PWM0, 1 | Output | Hz | Output | | | | P53/INT1, P54/INT0 | Input | Input | Input | | | | | Output | Hz | Output | | | | AM8/16 | Input | Input | Input | | | | ĒĀ | Input | "L" Level fixed | "L" Level fixed | | | | RESET | Input | Input | Input | | | | ADREF | Input | (Open status is available) | (Open status is available) | | | <sup>—:</sup> Inputs is not accepted. Input: Input gate in operation. Fix input voltage level to 0 or 1 so that the input pin stays constant. Output: Output state Hz: High Impedance ### 3.4 Interrupts TLCS-900 interrupts are controlled by the CPU interrupt mask flip-flop <IFF2 to 0> and the built-in interrupt controller. Altogether the TMP93C071 has the following 34 interrupt sources: Internal interrupts ......29 - Software interrupts: 8 (Illegal instruction execution is included: 1) - · Interrupts from built-in I/Os: 21 External instructions ......5 External pins (INT0, INT1, INT2 to INT4) A fixed individual interrupt vector number is assigned to each interrupt source; six levels of priority can also be assigned to each maskable interrupt. Non-maskable interrupts have a fixed priority of 7. When an interrupt is generated, the interrupt controller sends the value of the priority of the interrupt source to the CPU. When more than one interrupt is generated simultaneously, the interrupt controller sends the value of the highest priority (7 for non-maskable interrupts is the highest) to the CPU. The CPU compares the value of the priority sent with the value in the CPU interrupt mask register (IFF2 to 0). If the value is greater than that the CPU interrupt mask register, the interrupt is accepted. The value in the CPU interrupt mask register (IFF2 to 0) can be changed using the EI instruction (Executing EI n changes the contents of <IFF2 to 0> to n). For example, programming EI 3 enables acceptance of maskable interrupts with a priority of 3 or greater, and non-maskable interrupts which are set in the interrupt controller. The DI instruction (<IFF2 to 0> = 7) operates in the same way as the EI 7 instruction. Since the priority values for maskable interrupts are 0 to 6, the DI instruction is used to disable acceptance of maskable interrupts. The EI instruction becomes effective immediately after execution (With the TLCS-90, the EI instruction becomes effective after execution of the subsequent instruction). In addition to the general-purpose interrupt processing mode described above, there is also a Micro DMA processing mode. Micro DMA is a mode used by the CPU to automatically transfer byte or word data. It enables the CPU to process interrupts such as data saves to built-in I/Os at high speed. Figure 3.4.1 Interrupt Processing Flowchart ### 3.4.1 General-Purpose Interrupt Processing When accepting an interrupt, the CPU operates as follows: - (1) The CPU reads the interrupt vector from the interrupt controller. When more than one interrupt with the same level is generated simultaneously, the interrupt controller generates interrupt vectors in accordance with the default priority (which is fixed as follows: the smaller the vector value, the higher the priority), then clears the interrupt request. - (2) The CPU pushes the program counter and the status register to the system stack area (area indicated by the system mode stack pointer (XSP)). - (3) The CPU sets a value in the CPU interrupt mask register <IFF2 to 0> that is higher by 1 than the value of the accepted interrupt level. However, if the value is 7, 7 is set without an increment. - (4) The CPU increments the INTNEST (Interrupt Nesting Counter). - (5) The CPU jumps to address stored at FFFF00H + interrupt vector, then starts the interrupt processing routine. The following diagram shows all the above processing state number. | Bus Width of Stack Area | Bus Width of Interrupt Vector Area | Interrupt processing state number | | | |-------------------------|------------------------------------|-----------------------------------|--|--| | 8 bit | 8 bit | 35 | | | | | 16 bit | 31 | | | | 16 bit | 8 bit | 29 | | | | | 16 bit | 25 | | | To return to the main routine after completion of the interrupt processing, the RETI instruction is usually used. Executing this instruction restores the contents of the program counter and the status registers and decrements INTNEST (Interrupt Nesting Counter). Though acceptance of non-maskable interrupts cannot be disabled by program, acceptance of maskable interrupts can. A priority can be set for each source of maskable interrupts. The CPU accepts an interrupt request with a priority higher than the value in the CPU mask register <IFF2 to 0>. The CPU mask register <IFF2 to 0> is set to a value higher by 1 than the priority of the accepted interrupt. Thus, if an interrupt with a level higher than the interrupt being processed is generated, the CPU accepts the interrupt with the higher level, causing interrupt processing to nest. The interrupt request with a priority higher than the accepted now interrupt during the CPU is processing above (1) to (5) is accepted before the 1'st instruction in the interrupt processing routine, causing interrupt processing to nest. (This is the same case of over lapped each Non-Maskable interrupt (level "7").) The CPU does not accept an interrupt request of the same level as that of the interrupt being processed. Resetting initializes the CPU mask registers <IFF2 to 0> to 7; therefore, maskable interrupts are disabled. The following (1) to (5) show a flowchart of interrupt processing. ### (1) Maskable interrupt During execution of the main program, the CPU accepts an interrupt request. The CPU increments the IFF so that the interrupts of level 1 are not accepted during processing the interrupt routine. ### (3) Interrupt nesting During processing the interrupts of level 3, the IFF is set to 4. When an interrupt with a level higher then level 4 is generated, the CPU accepts the interrupt processing to nest. # (5) Interrupt sampling timing If an interrupt with a level higher than the interrupt being processed is generated, the CPU accepts the interrupt with the higher level. The program counter which returns at \$ is the start address of INTTO interrupt routine. ### (2) Non-maskable interrupt DI instruction is executed In the main program, so that the interrupts of only level 7 are accepted. The CPU does not increment the IFF even if the CPU accepts an interrupt request of level 7. ### (4) Software interrupt The CPU accepts the software interrupt request during DI status(IFF=7) because of the level 7. The IFF not changed by the software interrupts. The address FFFF00H to FFFFFH (256 byte) of the TMP93C071 are assigned for interrupt vector area. Table 3.4.1 TMP93C071 Interrupt Table | | | Table 6.4.1 Tivil 66667 Filler | | | | | |----------|----------|-------------------------------------------------|----------------|----------|--------------|-------------| | | | | Vector | Address | High-speed | Input | | Default | Туре | Interrupt source | value "V" | refer to | micro DMA | Level/ | | priority | | | value v | vector | start vector | Edge | | 1 | non- | Reset, or SWI0 instruction | 0000H | FFFF00H | _ | | | 2 | maskable | SWI1 instruction | 0004H | FFFF04H | _ | | | 3 | | INTUNDEF: illegal instruction, or SWI2 | 0008H | FFFF08H | _ | | | 4 | | SWI3 instruction | 000CH | FFFF0CH | _ | | | 5 | | SWI4 instruction | 0010H | FFFF10H | | | | 6 | | SWI5 instruction | 0014H | FFFF14H | _ | | | 7 | | SWI6 instruction | 0018H | FFFF18H | | | | 8 | | SWI7 instruction | 001CH | FFFF1CH | | | | 9 | | (Reserved: NMI) | 0020H | FFFF20H | _ | Edge | | 10 | | INTWD: watchdog timer | 0024H | FFFF24H | 09H | Edge | | 11 | maskable | INT0 pin: External interrupt input 0 | 0028H | FFFF28H | 0AH | Edge/Level | | 12 | | INTCAP1: Capture 1 interrupt | 002CH | FFFF2CH | 0BH | Level | | 13 | | INTCAP0: Capture 0 interrupt | 0030H | FFFF30H | 0CH | Level | | 14 | | INTTPG0: Timing Pulse Generator0 interrupt | 0034H | FFFF34H | 0DH | Edge (note) | | 15 | | INTTPG1: Timing Pulse Generator1 interrupt | 0038H | FFFF38H | 0EH | Edge | | 16 | | INTI2DMA: I2CBUS micro DMA Activation Interrupt | 003CH | FFFF3CH | 0FH | Edge | | 17 | | INTI2CB: I2CBUS interrupt | 0040H | FFFF40H | 10H | Edge | | 18 | | INTTBC: Time Base Timer interrupt | 0044H | FFFF44H | 11H | Edge | | 19 | | INTSIO0: Serial I/O 0 interrupt | 00 <b>4</b> 8H | FFFF48H | 12H | Level | | 20 | | INTSIO1: Serial I/O 1 interrupt | 004CH | FFFF4CH | 13H | Level | | 21 | | INTRX: UART receive interrupt | 0050H | FFFF50H | 14H | Level | | 22 | | INTTX: UART transmit interrupt | 0054H | FFFF54H | 15H | Edge | | 23 | | INTVA: VISS/VASS detection | 0058H | FFFF58H | 16H | Edge | | 24 | | INT1 pin: External interrupt input 1 | 005CH | FFFF5CH | 17H | Edge/Level | | 25 | | INT2 pin: External interrupt input 2 | 0060H | FFFF60H | 18H | Edge | | 26 | | INT3 pin: External interrupt input 3 | 0064H | FFFF64H | 19H | Edge | | 27 | | INT4 pin: External interrupt input 4 | 0068H | FFFF68H | 1AH | Edge | | 28 | | INTT0: 8-bit Timer TC0 | 006CH | FFFF6CH | 1BH | Edge | | 29 | | INTT1: 16-bit Timer TC1 | 0070H | FFFF70H | 1CH | Edge | | 30 | | INTT2: 16-bit Timer TC2 | 0074H | FFFF74H | 1DH | Edge | | 31 | | INTT3: 16-bit Timer TC3 | 0078H | FFFF78H | 1EH | Edge | | 32 | | INTT4: 16-bit Timer TC4 | 007CH | FFFF7CH | 1FH | Edge | | 33 | | INTT5: 16-bit Timer TC5 | 0080H | FFFF80H | 20H | Edge | | 34 | | INTAD: A/D conversion completion | 0084H | FFFF84H | 21H | Level | | 35 | | INTRTC: Real Time Counter | 0088H | FFFF88H | 22H | Edge | | | | (Reserved) | 008CH | FFFF8CH | 23H | | | to | | to | to | to | to | | | I — | | (Reserved) | 00FCH | FFFFFCH | 3FH | | Note: The INTTPG0 signal is generated as a level signal (FIFO empty) or as an edge signal (TPG03 output), but the interrupt controller receives the INTTPG0 only as an edge signal. When the INTTPG0 is used for a FIFO empty interrupt (a level signal), the interrupt controller also leaves a request flag (Flip/Flop) after clearing FIFO empty by setting next TPG0 data in an interrupt routine. Therefore, in this case, the INTTPG0 request flag has to be cleared before executing RETI instruction. Setting to Reset / Interrupt Vector ① Reset Vector | FFFF00H | PC (7 to 0) | |---------|---------------| | FFFF01H | PC (15 to 8) | | FFFF02H | PC (23 to 16) | | FFFF03H | XX | | | | The vector base addresses are depended on the products. | T | ype No. | Vector base address | PC setting sequence after reset | Notes | |----|---------|---------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | TM | P93C071 | FFFF00H | PC (7 to 0) ← address FFFF00H<br>PC (15 to 8) ← address FFFF01H<br>PC (23 to 16) ← address FFFF02H | P27 to P24 / A23 to A20 are used as address bus: A23 to A20 after reset. | ② Interrupt Vector (except Reset Vector) XX: don't care # (Setting Example) Sets the Reset Vector: FF0000H, INTWD Vector: FF9ABCH, INTAD Vector: FE3456H. ORG FFFF00H DL FF0000H; Reset = FF0000H ORG FFFF24H DL FF9ABCH; INTWD = FF9ABCH ORG FFFF84H DL FE3456H; INTAD = FE3456H ORG FF0000H LD A, B Note: ORG, DL are Assembler Directives. ORG FF9ABCH ORG: control location counter LD B, C DL: defines long word (32-bits) data ORG FE3456H LD C, A : ### 3.4.2 Micro DMA In addition to the conventional interrupt processing, the TLCS-900 also has a Micro DMA function. When an interrupt is accepted, in addition to an interrupt vector, the CPU receives data indicating whether processing is Micro DMA mode or general-purpose interrupt. If Micro DMA mode is requested, the CPU performs Micro DMA processing. The TLCS-900 can process at very high speed because it has transfer parameters in dedicated registers in the CPU. Since those dedicated registers are assigned as CPU control registers, they can only be accessed by the LDC instruction. ### (1) Micro DMA operation Micro DMA operation starts when the accepted interrupt vector value matches the Micro DMA start vector value. The Micro DMA has four channels so that it can be set for up to four types of interrupt source. When a Micro DMA interrupt is accepted, data is automatically transferred from the transfer source address to the transfer destination address set in the control register, and the transfer counter is decremented. If the value in the counter after decrementing is other than 0, Micro DMA processing is completed; if the value in the counter after decrementing is 0, general-purpose interrupt processing is performed. 32-bit control registers are used for setting transfer source / destination addresses. However, the TLCS-900 has only 24 address pins for output. A 16 Mbyte space is available for the Micro DMA. There are two data transfer modes: one-byte mode and one-word mode. Incrementing, decrementing, and fixing the transfer source / destination address after transfer can be done in both modes. Therefore data can easily be transferred between I/O and memory and between I/Os. For details of transfer modes, see the description of transfer mode registers. The transfer counter has 16 bits, so up to 65536 transfers (the maximum when the initial value of the transfer counter is 0000H) can be performed for one interrupt source by Micro DMA processing. When the transfer counter is decremented to "0" after data is transferred with micro DMA, general-purpose interrupt processing is performed. After processing the general-purpose interrupt, starting the interrupts of the same channel restarts the transfer counter from 65536. If necessary, reset the transfer counter. Interrupt sources processed by Micro DMA processing are those with the Micro DMA start vectors listed in Table 3.4.1. The following timing chart is a Micro DMA cycle of the Transfer Address INC rement mode (Condition: 16 bit Bus width for 16 MByte, 0 waits). Note 1: These 2 states are added in the case that the bus width of the source address area is 8 bits. Note 2: These 2 states are added in the case that the bus width of the destination address area is 8 bits. Note 3: This may be a dummy cycle with an instruction queue buffer Figure 3.4.1 Micro DMA cycle (COUNT $\neq$ 0) Figure 3.4.2 Micro DMA cycle (COUNT = 0) # (2) Register configuration (CPU control register) # Channel 1 DMAS1 DMAD1 Transfer source address register 1 Transfer destination address register 1 Transfer counter register 1 DMAM1 Transfer mode register 1 | Chanr | nel 2 | | |-------|-------|-----------------------------------------| | DMA | NS2 | Transfer source address register 2 | | DMA | ND2 | Transfer destination address register 2 | | | DMAC2 | Transfer counter register 2 | | _ | DMAM2 | Transfer mode register 2 | These Control Register can not be set only "LDC cr, r" instruction. # Example: LD XWA, 100H LDC DMAS0, XWA LD XWA, 50H LDC DMAD0, XWA LD WA, 40H LDC DMAC0, WA LD A, 05H LDC DMAM0, A ## (3) Transfer mode register details (1 states = 100 ns at 20 MHz, High frequency mode) Note1: n: corresponds to micro DMA channels 0 to 3. DMADn + / DMASn +: Post-increment (Increments register value after transfer.) DMADn - / DMASn -: Post-decrement (Decrement register value after transfer.) Note2: Execution time: When setting source address/destination address area to 16-bit bus, 0 WAIT. Clock condition: fc = 20 MHz Note3: Do not use the codes other than the above mantioned codes for transfer mode register. ### 3.4.3 Interrupt Controller Figure 3.4 (2) is a block diagram of the interrupt circuits. The left half of the diagram shows the interrupt controller; the right half includes the CPU interrupt request signal circuit and the HALT release signal circuit. Each interrupt channel (total of 26 channels) in the interrupt controller has an interrupt request flip-flop, and interrupt priority setting register. The interrupt controller also has registers for storing the Micro DMA start vector. The interrupt request fip-flop is used to latch interrupt requests from peripheral devices. The flip-flop is cleared to 0 at reset, when the CPU reads the interrupt channel vector after the acceptance of interrupt, or when the CPU executes an instruction that clears the interrupt of that channel (writes 0 in the clear bit of the interrupt priority setting register). For example, to clear the INT0 interrupt request, set the register after the DI instruction as follows. The status of the interrupt request flip-flop is detected by reading the clear bit. Detects whether there is an interrupt request for an interrupt channel. The interrupt priority can be set by writing the priority in the interrupt priority setting register (eg, INT0CP1, INTCP0TG0, etc.) provided for each interrupt source. Interrupt levels to be set are from 1 to 6. Writing 0 or 7 as the interrupt priority disables the corresponding interrupt request. The priority of the non-maskable interrupt (watchdog timer, etc.) is fixed to 7. If interrupt requests with the same interrupt level are generated simultaneously, interrupts are accepted in accordance with the default priority (the smaller the vector value, the higher the priority). The interrupt controller sends the interrupt request with the highest priority among the simultaneous interrupts and its vector address to the CPU. The CPU compares the priority value <IFF2 to 0> set in the Status Register by the interrupt request signal with the priority value sent; if the latter is higher, the interrupt is accepted. Then the CPU sets a value higher than the priority value by 1 in the CPU SR<IFF2 to 0>. Interrupt requests where the priority value equals or is higher than the set value are accepted simultaneously during the previous interrupt routine. When interrupt processing is completed (after execution of the RETI instruction), the CPU restores the priority value saved in the stack before the interrupt was generated to the CPU SR<IFF2 to 0>. The interrupt controller also has four registers used to store the Micro DMA start vector. These are I/O registers; unlike other Micro DMA registers (DMAS, DMAD, DMAM, and DMAC). Writing the start vector of the interrupt source for the Micro DMA processing (see Table 3.4.1), enables the corresponding interrupt to be processed by Micro DMA processing. The values must be set in the Micro DMA parameter registers (eg, DMAS and DMAD) prior to the Micro DMA processing. Figure 3.4.2 Block Diagram of Interrupt Controller # (1) Interrupt priority setting register (1/2) | | | | | | | | | (Proh | ibit read-m | odify-write) | - | | |-----------|-----------|----------|---------|-----------------|---------|---------|--------|---------|-------------|--------------|---------------------|--| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | INT0CP1 | INT0/ | 0070H | | INTO | CAP1 | | | IN | T0 | | ← Interrupt sou | | | | CAP1 | | ICAP1C | ICAP1M2 | ICAP1M1 | ICAP1M0 | IOC | I0M2 | I0M1 | 10M0 | ← bit Symbol | | | | Interrupt | Prohibit | R/W | W | W | W | R/W | W | W | W | <b>←</b> Read/Write | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ← After reset | | | INTCP0TG0 | CAP0/ | 0071H | | INT | ΓPG0 | | | INTCAP0 | | | | | | | TPG0 | | ITPG0C | ITPG0M2 | ITPG0M1 | ITPG0M0 | ICAP0C | ICAP0M2 | ICAP0M1 | ICAP0M0 | | | | | Interrupt | Prohibit | R/W | w | W | W | R/W | W | W | W | ĺ | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | INTTG1DMA | TPG1/ | 0072H | | INTI | 2DMA | | | INT | TPG1 | | | | | | I2DMA | | II2DMAC | II2DMAM | II2DMAM | II2DMAM | ITPG1C | ITPG1M2 | ITPG1M1 | ITPG1M0 | ĺ | | | | | | | 2 | 1 | 0 | | | | | | | | | Interrupt | Prohibit | R/W | W | W | W | R/W | W | W | W | ĺ | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | INTI2CTBC | I2CBUS/ | 0073H | | INT | TBC | | | INT | I2CB | | | | | | TBC | | ITBCC | ITBCM2 | ITBCM1 | ITBCM0 | II2CC | II2CM2 | II2CM1 | II2CM0 | | | | | Interrupt | Prohibit | R/W | W | W | W | R/W | W | W | W | | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | INTSI0SI1 | SIO0/ | 0074H | INTSIO1 | | | | | INT: | SIO0 | | | | | | SIO1 | | ISIO1C | ISIO1M2 | ISIO1M1 | ISIO1M0 | ISIO0C | ISIO0M2 | ISIO0M1 | ISIO0M0 | | | | | Interrupt | Prohibit | R/W | W | W | W | R/W | W | W | W | | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | INTRXTX | RX/ | 0075H | | IN | ГТХ | | INTRX | | | | | | | | TX | | ITXC | ITXM2 | ITXM1 | ITXM0 | IRXC | IRXM2 | IRXM1 | IRXM0 | ĺ | | | | Interrupt | Prohibit | R/W | w | W | W | R/W | W | W | W | ĺ | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ĺ | | | INTVA1 | VA/ | 0076H | | IN | T1 | | | IN | ΓVA | | | | | | INT1 | | I1C | I1M2 | I1M1 | I1M0 | IVAC | IVAM2 | IVAM1 | IVAM0 | ĺ | | | | Interrupt | Prohibit | R/W | w | W | W | R/W | W | W | W | ĺ | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ĺ | | | INT23 | INT2/ | 0077H | | IN | T3 | | | IN | T2 | • | | | | | INT3 | | I3C | 13M2 | I3M1 | 13M0 | I2C | I2M2 | I2M1 | 12M0 | ĺ | | | | Interrupt | Prohibit | R/W | w | W | W | R/W | W | W | W | | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | INT4T0 | INT4/ | 0078H | | IN <sup>-</sup> | ТТО | | | IN | T4 | • | | | | | Timer0 | | IT0C | IT0M2 | IT0M1 | IT0M0 | I4C | I4M2 | I4M1 | 14M0 | | | | | Interrupt | Prohibit | R/W | w | W | W | R/W | w | w | W | | | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Interrupt priority setting register (2/2) Note 1: Read-modify-write is prohibited. ### Note 2: Note about clearing interrupt request flag. The interrupt request flag of INTCAP1, INTCAP0, INTSIO0, INTSIO1, INTRX and INTAD are not cleared by writing 0 to IxxC because of they are level interrupts. They can be cleared only by resetting, reading captured data / ADREG /SC2BUF or reading/writing SC0BUF / SC1BUF. ### Note 3: Note about clearing interrupt request flag. When the INTTPG0 is used for a FIFO empty interrupt (a level signal), the interrupt controller also leaves a request flag (Flip/Flop) after clearing FIFO empty by setting next TPG0 data in an interrupt routin. Therefore, in this case, the INTTPG0 request flag has to be cleared before executing RETI instruction. # (2) External interrupt control # Interrupt Input Mode Control Register 1 IIMC0 (005EH) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---|-------------|---|-----|--------|-----------------------------------------|---------|----------|--------|--------|--| | | bit Symbol | _ | _ | _ | I4IE | I3IE | I2IE | I1IE | IOIE | | | I | | | | | (INT4) | (INT3) | (INT2) | (INT1) | (INT0) | | | ١ | Read/Write | | l | | | | W | | | | | | After reset | | i I | | 0 | 0 ¦ | 0 ¦ | 0 ¦ | 0 | | | | Function | | | 1 | External interrupt input enable/disable | | | | | | | | | | | l<br>I | l<br>I | 0: Disa | ble 1: E | nable | | | Prohibit read-modify-write Interrupt Input Mode Control Register 1 IIMC1 (005FH) | | | | | | Control 10 | 9 | | | |-------------|------------|------------|-------------|------------|------------|--------|-------------|-----------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | . 0 | | bit Symbol | I4EG | 13EG | I2EG | I1EG | I0EG | . – | INTTPG0E | INTTPG0 | | , | | | | 1 | | | ,<br>! | s | | Read/Write | | | W | | | | R/W | R/W | | After reset | 0 | 0 | 0 | 0 | 0 | 1 | ¦ 0 | ¦ 0 | | Function | INT4 edge | INT3 edge | INT2 edge | INT1 | ¦INT0 | | ¦INTTPG0 | ¦INTTPG0 | | | selection | selection | selection | edge/level | edge/level | !<br>! | interrupt | interrupt | | | | !<br>! | !<br>! | selection | selection | <br> | TPG03 | selection | | | 0: Rising | 0: Rising | 0: Rising | 1<br>1 | 1 1 | !<br>! | edge | !<br>! | | | 1: Falling | 1: Falling | ¦1: Falling | 0: Rising | 0: Rising | l<br>I | selection | ¦0:FIFO | | | | !<br>! | !<br>! | edge | edge | <br> | !<br>! | empty | | | | !<br>! | !<br>! | 1: Level | 1: Level | l<br>I | 0: Rising | inter- | | | | 1<br>1 | !<br>! | I<br>I | ! !<br>! | !<br>! | ¦1: Falling | rupt | | | | !<br>! | !<br>! | 1<br>1 | 1 | !<br>! | <br> | ¦1: FIFO | | | | 1<br>1 | !<br>! | 1<br>1 | 1 1 | 1<br>1 | <br> | empty/ | | | | : | !<br>! | ! | | | <br> | ¦ TPG03 | | | | : | <u> </u> | !<br>! | : | i | !<br>! | inter- | | | | !<br>! | !<br>! | l<br>I | !<br>! | l<br>I | l<br>I | rupt | Prohibit read-modify-write Note1: The INT0 and INT1 pins can also be used for standby release as described later. When these pins are not used for standby release, setting IIMC0<I1IE, I0IE> to 00 maintain the port function during standby mode. Note2: When the active edge is changed by the IIMC1<I4EG, I3EG, I2EG, I1EG, I0EG>, they must be changed after disabling interrupt. # Execution example: LD (INTOCP1) , XXXX0000B; Disable the INT0 interrupt, Clear the INT0 interrupt request flag. LD (IIMC0) , XXXXXXX0B; Disable the INT0 input LD (IIMC1) , XXXX1XXXB; Change the active edge to Level from Rising edge. LD (INTOCP1) , XXXX0nnnB; Set interrupt level "nnn" for INT0, Clear the interrupt request flag. Note3: The minimum pulse width for the active edge is 4/fc [s] (200 ns at fc = 20 MHz). # Setting of External Interrupt Pin Functions | Interrupt | Shared pin | | Mode | Setting method | | | | | | | | | |-----------|------------|------------------------------------|--------------|-------------------------------------------------|--|--|--|--|--|--|--|--| | INT0 | P54 | | Rising edge | IIMC1 <i0eg> = 0, IIMC0<i0ie> = 1</i0ie></i0eg> | | | | | | | | | | | | <b>プ</b> て | Level | IIMC1 <i0eg> = 1, IIMC0<i0ie> = 1</i0ie></i0eg> | | | | | | | | | | INT1 | P53 | | Rising edge | IIMC1 <i1eg> = 0, IIMC0<i1ie> = 1</i1ie></i1eg> | | | | | | | | | | | | $\mathcal{I}^{\bullet}\mathcal{I}$ | Level | IIMC1 <i1eg> = 1, IIMC0<i1ie> = 1</i1ie></i1eg> | | | | | | | | | | INT2 | P52 | | Rising edge | IIMC1 <i2eg> = 0, IIMC0<i2ie> = 1</i2ie></i2eg> | | | | | | | | | | | | 7 | Falling edge | IIMC1 <i2eg> = 1, IIMC0<i2ie> = 1</i2ie></i2eg> | | | | | | | | | | INT3 | P51 | | Rising edge | IIMC1 <i3eg> = 0, IIMC0<i3ie> = 1</i3ie></i3eg> | | | | | | | | | | | | لم | Falling edge | IIMC1 <i3eg> = 1, IIMC0<i3ie> = 1</i3ie></i3eg> | | | | | | | | | | INT4 | P50 | | Rising edge | IIMC1 <i4eg> = 0, IIMC0<i4ie> = 1</i4ie></i4eg> | | | | | | | | | | | | | Falling edge | IIMC1 <i4eg> = 1, IIMC0<i4ie> = 1</i4ie></i4eg> | | | | | | | | | ## (3) Micro DMA start vector When the CPU reads the interrupt vector after accepting an interrupt, it simultaneously compares the interrupt vector with each channel's Micro DMA start vector (bits 3 to 8 of the interrupt vector). When the two match, the interrupt from the channel whose value matched is processed in Micro DMA mode. If the interrupt vector matches more than one channel, the channel with the lower channel number has a higher priority. ### Micro DMA0 Start Vector DMA0V (007CH) Prohibit readmodifywrite | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|--------------------------------------------------------------------------------|---|--------|---------|--------|--------|--------|--------|--| | bit Symbol | | | DMA0V5 | DMA0V 4 | DMA0V3 | DMA0V2 | DMA0V1 | DMA0V0 | | | Read/Write | _ | | | W | | | | | | | After reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Function | Micro DMA channel 0 processed by matching bits 3 to 8 of the interrupt vector. | | | | | | | | | ### Micro DMA1 Start Vector DMA1V (007DH) Prohibit readmodifywrite | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|-------------------------------------------------------------------------------------|---|--------|---------|--------|--------|--------|--------|--|--|--| | bit Symbol | | | DMA1V5 | DMA1V 4 | DMA1V3 | DMA1V2 | DMA1V1 | DMA1V0 | | | | | Read/Write | | | | W | | | | | | | | | After reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Function | tion Micro DMA channel 1 processed by matching bits 3 to 8 of the interrupt vector. | | | | | | | | | | | ### Micro DMA2 Start Vector DMA2V (007EH) Prohibit readmodifywrite | | Miloto Bitti 12 Ottate 1 Ottate | | | | | | | | | | | |-------------|--------------------------------------------------------------------------------|---|--------|---------|--------|--------|--------|--------|--|--|--| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | bit Symbol | | | DMA2V5 | DMA2V 4 | DMA2V3 | DMA2V2 | DMA2V1 | DMA2V0 | | | | | Read/Write | | | | W | | | | | | | | | After reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Function | Micro DMA channel 2 processed by matching bits 3 to 8 of the interrupt vector. | | | | | | | | | | | ### Micro DMA3 Start Vector DMA3V (007FH) Prohibit readmodifywrite | | MICTO DIMAS Start Vector | | | | | | | | | | | | | |-------------|--------------------------|---------------|-------------|--------------|---------------|---------------|--------|--------|--|--|--|--|--| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | bit Symbol | | | DMA3V5 | DMA3V 4 | DMA3V3 | DMA3V2 | DMA3V1 | DMA3V0 | | | | | | | Read/Write | | | | W | | | | | | | | | | | After reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | Function | Micro DMA | channel 3 pro | cassad by m | atching hite | to 8 of the i | nterrunt vect | or | | | | | | | **TOSHIBA** TMP93C071 ### (4) Notes The instruction execution unit and the bus interface unit of this CPU operate independently of each other. Therefore, if the instruction used to clear an interrupt request flag of an interrupt is fetched before the interrupt is generated, it is possible that the CPU might execute the fetched instruction to clear the interrupt request flag while reading the interrupt vector after accepting the interrupt. If so, the CPU would read the default vector FFFF28H and start the interrupt processing from the address FFFF28H. To avoid this, make sure that the instruction used to clear the interrupt request flag comes after the DI instruction. Execute the POP SR instruction, which modifies the IFF value, during DI. # 3.5 Functions of ports The TMP93C071 has 57 bits for I/O ports, 8 bits for Input ports and 4 bits for Output ports. These port pins have I/O functions for the built-in CPU and internal I/Os as well as general-purpose I/O port functions. Table 3.5 lists the function of each port pin. Resetting makes the pins listed below function as general-purpose I/O ports. I/O pins programmable for input or output are set to input ports including PB0/XT1, PB1/XT2. To set port pins for built-in functions, a program is required. Table 3.5.1 Functions of ports | | | | | pie 3.5.1 Functions of po | Direction / | | |-----------|---------------|-----------|------------|------------------------------------|--------------|-----------------------| | Port Name | Pin Name | Pin No. | Direction | Output Mode | Output Mode | Pin name for built-in | | 1 of Hame | 1 III IVallic | 1 111110. | Direction | Catput Mode | setting unit | function | | Port 2 | P24 to P27 | 4 | Output | Push-Pull | (fixed) | A20 to A23 | | | P40 to P47 | 8 | Input | | (fixed) | AIN3 to AIN10 | | | P50 | 1 | I/O | Push-Pull | Bit | INT4/TI3 | | | P51 | 1 | 1/0 | Push-Pull | Bit | INT3/TI2 | | | P52 | 1 | 1/0 | Push-Pull | Bit | INT2/TI1 | | | P53 | 1 | 1/0 | Push-Pull | Bit | INT1 | | | P54 | 1 | 1/0 | Push-Pull | Bit | INT0 | | | P55 | 1 | I/O | Push-Pull | Bit | TI5/AIN0 | | | P56 | 1 | I/O | Push-Pull | Bit | TI4/AIN1 | | | P57 | 1 | I/O | Push-Pull | Bit | TI0/AIN2 | | Port 6 | P60 | 1 | I/O | Push-Pull/Open-Drain | Bit | PWM4/CS0 | | | P61 | 1 | I/O | Push-Pull/Open-Drain | Bit | PWM5/CS1 | | | P62 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | PWM6/CS2 | | | P63 to P67 | 5 | 1/0 | Push-Pull/Open-Drain | Bit | PWM7 to PWM11 | | | P70 | 1 | I/O | Push-Pull/Open-Drain | Bit | TXD | | | P71 | 1 | 1/0 | Push-Pull | Bit | RXD | | | P72 | 1 | 1/0 | Push-Pull | Bit | CTS | | | P73 | | 1/0 | | Bit | SDA0 | | | | | | Push-Pull/Open-Drain | | | | | P74 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | SCL0 | | | P75 | 1 | I/O | Push-Pull/Open-Drain | Bit | SO0 | | | P76 | 1 | 1/0 | Push-Pull | Bit | SIO | | | P77 | 1 | I/O | Push-Pull/Open-Drain | Bit | SCK0 | | | P80 | 1 | I/O | Push-Pull | Bit | CTLIN | | | P81 | 1 | I/O | Push-Pull | Bit | DFGIN | | | P82 | 1 | 1/0 | Push-Pull | Bit | RMTIN | | | P83 | 1 | 1/0 | Push-Pull | Bit | EXT | | | P84 | 1 | 1/0 | Push-Pull | Bit | DPGIN | | | P85<br>P86 | 1 1 | I/O<br>I/O | Push-Pull | Bit<br>Bit | CFGIN<br>CSYNCIN | | | P87 | | 1/0 | Push-Pull<br>Push-Pull | Bit | COMPIN | | | P90 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | TPG12 | | | P91 to P94 | 4 | 1/0 | Push-Pull/Open-Drain | Bit | TPG01 to TPG04 | | | P95 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | TPG13 | | | P96 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | TPG10 | | | P97 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | TPG11 | | Port A | PA0 | 1 | I/O | Push-Pull | Bit | PV-PH | | | PA1 | 1 | 1/0 | Push-Pull | Bit | HA(TPG05) | | | PA2 | 1 | 1/0 | Push-Pull | Bit | CR(TPG00) | | | PA3 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | PWM2 | | | PA4 | '1 | 1/0 | | Bit | WR | | | | | | Push-Pull/Open-Drain | | | | | PA5 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | PWM3/HWR | | | PB0<br>PB1 | 1 | 1/0 | Open-Drain | Bit<br>Bit | XT1<br>XT2 | | | PB1<br>PB2 | 1 1 | I/O<br>I/O | Open-Drain<br>Push-Pull/Open-Drain | Bit<br>Bit | SO1/SI1 | | | PB3 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | SCK1 | | | PB4 | | 1/0 | Push-Pull/Open-Drain | Bit | SDA1 | | | PB5 | 1 | 1/0 | Push-Pull/Open-Drain | Bit | SCL1 | | | PC0 to PC4 | 5 | 1/0 | Push-Pull | Bit | AIN11 to AIN15 | # 3.5.1 Port 2 (P24 to P27) Port 2 is an 4-bit general-purpose Output port. In addition to functioning as a general-purpose Output port, Port 2 also shares functions as an address bus (A20 to A23) output. All bits of the output latch P2 and function register P2FC are set to "1" by reset, and then Port 2 works as the address bus (A20 to A23) output. Switching of the general-purpose output port function and the address bus output function can be done on bit basis by function register P2FC. Figure 3.5.1 Port 2 (P24 to P27) | | | | Port 2 Register | | | | | | | | | | | | |---------|-------------|---------|---------------------------------------------------------|-----------|------------|-----------|--------|--------|--------|--|--|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | P2 | bit Symbol | P27 | P26 | P25 | P24 | I<br>I | 1<br>1 | I<br>I | l<br>I | | | | | | | (0006H) | Read/Write | | | | R/ | W | | | | | | | | | | | After reset | (Outp | (Output latch register is set to 1) 1 (Always set to 1) | | | | | | | | | | | | | | | | | F | Port 2 Fu | nction re | gister | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | bit Symbol | P27F | P26F | P25F | P24F | !<br>! | 1<br>1 | !<br>! | I<br>I | | | | | | | P2FC | Read/Write | | | | ٧ | 1 | | | | | | | | | | (0009H) | After reset | | 1 | 1 (Alway | set to 1) | | | | | | | | | | | | Function | 0: PORT | 1: ADDRES | SS BUS (A | 23 to A20) | i<br>I | _ | _ | | | | | | | Figure 3.5.2 Registers for Port 2 # 3.5.2 Port 4 (P40 to P47) Port 4 is an 8-bit input port, also used as an analog input pin (AIN3 to AIN10) for the internal A/D converter. Figure 3.5.3 Port 4 | | Port, SRegister | | | | | | | | | | | | | | |---------|-----------------|-----------------|------------|-----|-----|-----|-----|-----|-----|--|--|--|--|--| | | | 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | | P4 | bit Symbol | P47 | P46 | P45 | P44 | P43 | P42 | P41 | P40 | | | | | | | (000AH) | Read/Write | | R | | | | | | | | | | | | | | After reset | | Input mode | | | | | | | | | | | | Figure 3.5.4 Register for Port 4 Note: The input channel selection of A/D converter is set by A/D converter mode register ADMOD. # 3.5.3 Port 5(P50 to P57) Port 5 is an 8-bit general-purpose I/O port. I/O can be set on bit basis using the control register P5CR. All bits of the output latch P5 are set to 1 by reset, and all bits of P5CR are cleared to 0. Therefore, Port 5 becomes the input mode port. Port 5 also shares functions as an external interrupt input pin (INT0 to INT4), an external input pin for timer counter (TI0 to TI5) and an analog input pin (AIN0 to AIN2) for A/D converter. In the output mode (P5CR<bit> = 1), the output latch data are read from the P5 register. In the input mode (P5CR<bit> = 0), the pin data are read from P5 register. Note: TI0, TI4 and TI5 are permitted to input when these inputs are selected by the timer counter control registers: TCR10 TCCR54. When P55/TI5/AIN0, P56/TI4/AIN1 and P57/TI0/AIN2 are used as an analog input (AIN0, AIN1 and AIN2), TI5, TI4 and TI0 for timer counter must be disabled by TCCR54 and TCCR10. (Select another clock source for timer counter.) Figure 3.5.5 Port ,T (P50, P51, P52) | | | | Port 5 Register | | | | | | | | | |---------|-------------|-----|-----------------|-----|------------|-----|-----|-----|-----|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | ; o | | | | P5 | bit Symbol | P57 | P56 | P55 | !<br>! P54 | P53 | P52 | P51 | P50 | | | | (000BH) | Read/Write | | R/W | | | | | | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | . 1 | 1 1 | 1 | | | | | | | Port 5 Control Register | | | | | | | | | | | | |---------|-------------|------|------------------------------|------|------|------|------|------|------|--|--|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | 5505 | bit Symbol | P57C | P56C | P55C | P54C | P53C | P52C | P51C | P50C | | | | | | | P5CR | Read/Write | | W | | | | | | | | | | | | | (000CH) | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | Function | | 0: Input mode 1: Output mode | | | | | | | | | | | | Figure 3.5.7 Registers for Port 5 ### 3.5.4 Port 6 (P60 to P67) Port 6 is an 8-bit general-purpoe I/O port. I/O can be set on bit basis using the control register P6CR. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register ODCR0. Port 6 becames the input mode by reset. ## (1) P60/PWM4/CS0, P61/PWM5/CS1, P62/PWM6/CS2 P60, P61 and P62 also share functions as an 8-bit PWM output (PWM4 to PWM6) and a chip select output. Switching of the output port function and the PWM output function can be done by the function register P6FC. In addition, switching of the chip select output function and the function selected by P6FC can be done by chip select/wait control register bits B0CS<CS0EN>, B1CS<CS1EN> and B2CS<CS2EN>. In the output mode (P6CR<bit> = 1), the output data selected by B0CS<CS0EN> to B2CS<CS2EN> are read from the P6 register. In the input mode P6CR<bit> = 0), the pin data are read from P6 register. Figure 3.5.8 Port 6 (P60, P61, P62) # (2) P63/PWM7,P64/PWM8,P65/PWM9,P66/PWM10,P67/PWM11 P63 to P67 also share functions as an 8-bit PWM output (PWM7 to PWM11). Switching of the output port function and the PWM output function can be done by the function register P6FC. In the output mode (P6CR<bit> = 1), the output latch data are read from the P6 register. In the input mode (P6CR<bit> = 0), the pin data are read from P6 register. Figure 3.5.9 Port 6 (P63, P64, P65, P66, P67) | | | | Port 6 Register | | | | | | | | | | | | |---------|-------------|-----|-------------------------------|-----|-----|-----|-----|-----|-----|--|--|--|--|--| | | | 7 | 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | P6 | bit Symbol | P67 | P66 | P65 | P64 | P63 | P62 | P61 | P60 | | | | | | | (000EH) | Read/Write | | RW | | | | | | | | | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | Port 6 Control Register | | | | | | | | | | | | |---------|-------------|------|------------------------------|------|------|------|------|------|------|--|--|--|--|--| | | | 7 | 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | P6CR | bit Symbol | P67C | P66C | P65C | P64C | P63C | P62C | P61C | P60C | | | | | | | (0010H) | Read/Write | | W | | | | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | Function | | 0: Input mode 1: Output mode | | | | | | | | | | | | Port 6 Function Register 7 6 5 3 2 0 1 P67F P66F P65F P64F P63F P62F P61F P60F bit Symbol P6FC Read/Write W (0012H)After reset 0 0 0 0 0 0 0 0 B1CS B0CS Function 0: PORT67 0: PORT66 0: PORT65 0: PORT64 0: PORT63 B2CS <CS2EN> = 0<CS1EN> = 0<CS0EN> = 0i1: PWM7 1: PWM11 i1: PWM10 i1: PWM9 1: PWM8 0: PORT62 0: PORT61 0: PORT60 1: PWM6 1: PWM5 1: PWM4 Prohibit read-modify-write Open Drain Output Control Register 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |---------|-------------|-------|-------|-------|---------|---------|-------|-------|-------|--|--|--|--| | ODCR0 | bit Symbol | POD67 | POD66 | POD65 | POD64 | POD63 | POD62 | POD61 | POD60 | | | | | | (0014H) | Read/Write | | W | | | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | Function | · | | 0: Pu | sh-Pull | 1: Open | Drain | | | | | | | Prohibit read-modify-write Chip select/Wait Control Register 0 6 0 CS0EN **B0BUS** B0W1 B0W0 B0C1 B0C0 bit Symbol B0CS Read/Write W W W W (0068H)After reset 0 0 0 0 0: Port60 00: 2090H to 3FFFFFH **Function** BUS Width Wait Control /PWM4 Control 100: 0 WAIT 101: 400000H to 7FFFFF (P6FC 101: 1 WAIT 10: 800000H to BFFFFF '0: 16-bit <P60F>) Bus 10: 1 WAIT 11: C00000H to FFFFFF 11: 2 WAIT 1: 8-bit 1: CS0 Bus Prohibit read-modify-write Chip select/Wait Control Register 1 6 3 1 0 CS1EN **B1BUS** B1W1 B1W0 B1C1 B1C0 bit Symbol **B1CS** Read/Write W W W W (0069H) After reset 0 0 Function 0: Port61 BUS Width Wait Control 00: 2090H to 3FFFFFH /PWM5 100: 0 WAIT 101: 400000H to 7FFFFF Control (P6FC 0: 16-bit 101: 1 WAIT 10: 800000H to BFFFFF <P61F>) Bus 10: 1 WAIT 11: C00000H to FFFFFF 1: 8-bit 11: 2 WAIT i1: CS1 Bus Chip select/Wait Control Register 2 | | Chip select/vvait Control Register 2 | | | | | | | | | | | | |---------|--------------------------------------|---|---------------------------|---|-----------|------------|------|-----------------------|-------------|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | B2CS | bit Symbol | | CS2EN | | B2BUS | B2W1 | B2W0 | B2C1 | B2C0 | | | | | (0070H) | Read/Write | | W | | w | į v | V | ; v | v | | | | | | After reset | | 0 | | 0 | . ( | ) | !<br>! | ) | | | | | | Function | | 0: Port62 | | BUS Width | Wait Contr | ol . | ¦00: 2090H to | 3FFFFFH | | | | | | | | PWM6 | | Control | 00: 0 WAI | Т | 01: <b>4</b> 00000H | I to 7FFFFF | | | | | | | | (P6FC<br>' <p62f>)</p62f> | | 0: 16-bit | 01: 1 WAIT | | 10: 800000H to BFFFFF | | | | | | | | | 1 1 0 <b>2</b> 1 1 1 | | Bus | 10: 1 WAI | Т | 11: C00000H | to FFFFFF | | | | | | | | 1: CS2 | | 1: 8-bit | 11: 2 WAI | Т | !<br>! | | | | | | | | | l<br>I | i | Bus | !<br>! | | !<br>! | | | | | Figure 3.5.10 Registers for Port 6 ### 3.5.5 Port 7 (P70 to P77) Port 7 is an 8-bit general-purpoe I/O port. I/O can be set on bit basis using the control register P7CR. Port 7 also shares functions as a I<sup>2</sup>C-bus I/F (I<sup>2</sup>CBUS), a synchronous-SIO (SIO0) and an asynchronous serial I/F (UART). Port 7 becames the input mode by reset. ### (1) P73/SDA0, P74/SCL0 P73 and P74 are also used for a SDA bus line 0 (SDA0) and a SCL bus line 0 (SCL0) of the I²CBUS block. Switching of the general-purpose I/O port function and the I²CBUS function can be done by the function register P7FC. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register ODCR1. When these pin are used for the I2CBUS function, firstly, set P7FC<P73F> and <P74F> to 1, secondly, set ODCR1<POD73> and <POD74> to 1, finally, set P7CR<P73> and <P74C> to 1. By Read data selection register bits PRDSEL<PR73> and <PR74>, the data read from P7 register can be chosen one of which the output data selected by P7FC or the pin data. Figure 3.5.11 Port 7 (P73, P74) **TOSHIBA** ## (2) P70/TXD, P75/SO0, P77/SCK0 P70, P75 and P77 are also used as a transmission data output (TXD) for the UART block, a transmission data output (SO0) for the SIO0 block and a transfer clock input/output (SCK0) for the SIO0 block. Switching of the general-purpose I/O port function and the UART/SIO0 function can be done by the function register P7FC. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register ODCR1. By Read data selection register PRDSEL, the data read from P7 register can be chosen one of which the output data selected by P7FC or the pin data. Figure 3.5.12 Port 7 (P70, P75, P77) # (3) P71/RXD, P72/CTS, P76/SI0 P71, P72 and P76 are also used as a reception data input (RXD) and a $\overline{\text{CTS}}$ input for the UART block and a reception data input(SI0) for the SIO0 block. In the output mode (P7CR<bit> = 1), the output latch data are read from the P7 register. In the input mode (P7CR<bit> = 0), the pin data are read from P7 register. Figure 3.5.13 Port 7 (P71, P72, P76) | | | | Port 7 Register | | | | | | | | | | | | |---------|-------------|-----|-----------------|-----|----------|----------|----------|----------|-----|--|--|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | P7 | bit Symbol | P77 | P76 | P75 | P74 | P73 | P72 | P71 | P70 | | | | | | | (000FH) | Read/Write | | R/W | | | | | | | | | | | | | | After reset | 1 | . 1 | 1 | ! 1 | 1 1 | <u> </u> | <u> </u> | 1 1 | | | | | | | | | | | | Dort 7.0 | ontrol D | | | | | | | | | | | | | Port / Control Register | | | | | | | | | | | | |---------|-------------|------|------------------------------|------|------|------|------|------|------|--|--|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | P7CR | bit Symbol | P77C | P76C | P75C | P74C | P73C | P72C | P71C | P70C | | | | | | | (0011H) | Read/Write | | W | | | | | | | | | | | | | | After reset | 0 | . 0 | . 0 | . 0 | 0 | 0 | . 0 | 0 | | | | | | | | Function | | 0: Input mode 1: Output mode | | | | | | | | | | | | Port 7 Function Register | | | Tott / Tallottoli Register | | | | | | | | | | | |---------|-------------|----------------------------|---|-----------|-----------|-----------|---|--------|-----------|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | P7FC | bit Symbol | P77F | | P75F | P74F | P73F | | | P70F | | | | | (0013H) | Read/Write | w | | !<br>! | W | į | | i | w | | | | | | After reset | 0 | | 0 | 0 | 0 | | | 0 | | | | | | Function | 0: PORT77 | | 0: PORT75 | 0: PORT74 | 0: PORT73 | | i<br>I | 0: PORT70 | | | | | | | 1: SCK0 | | 1: SO0 | 1: SCL0 | 1: SDA0 | | | 1: TXD | | | | Prohibit read-modify-write Open Drain Output Control Register 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | i o | |---------|-------------|-------------------|----------|-----------------|-------|-------|--------|--------|----------| | ODCR1 | bit Symbol | POD77 | ! | POD75 | POD74 | POD73 | i<br>I | | POD70 | | (0015H) | Read/Write | W | <br> | | W | | | | . w | | | After reset | 0 | I | 0 | 0 | 0 | | i<br>I | 0 | | | Function | 0: Push-<br>Pull | <br> | 0: Push-Pull | | | <br> | <br> | 0: Push- | | | | | I <br>I | 1: Open-Drain ¦ | | | l | !<br>! | ¦ Pull | | | | 1: Open-<br>Drain | <br> | !<br>! | | | | !<br>! | 1: Open- | | | | | !<br> | | | | | | Drain | Prohibit read-modify-write Port Read Data Selection Register 6 0 PR75 | PR74 | PR73 bit Symbol PR77 PR70 PRDSEI Read/Write W W W (000DH) After reset Function 0: Pin 0: Pin value 0: Pin Value 1: Output Value value 1: Output 1: Output Value Value Figure 3.5.14 Registers for Port 7 # 3.5.6 Port 8 (P80 to P87) Port 8 is an 8-bit general-purpose I/O port. I/O can be set on bit basis using the control register P8CR. All bits of the output latch P8 are set to "1" by reset, and all bits of P8CR are cleared to "0". Therefore, Port 8 becames the input mode port. Port 8 also shares functions as a capture input pin (CTLIN, DFGIN, RMTIN, EXT, DPGIN, CSYNCIN) and a comparator signal input pin (COMPIN) for controlling an output of Head Amp Switch/Color Rotary. In the output mode (P8CR < bit > = 1), the output latch data are read from the P8 register. In the input mode (P8CR < bit > = 0), the pin data are read from P8 register. Figure 3.5.15 Port 8 (P80 to P87) | | | | | | Port | 8 Registe | er | | | | | | |---------|---------------|-------------|------|---------|-----------|---------------|-------------|------|------|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | P8 | bit Symbol | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | | | | (0016H) | Read/Write | | R/W | | | | | | | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | 7 | 6 | 5 | Port 8 Co | ontrol Re | gister<br>2 | 1 | 0 | | | | | P8CR | bit Symbol | P87C | P86C | P85C | P84C | P83C | P82C | P81C | P80C | | | | | (0018H) | Read/Write | W | | | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Function | | | 0:Input | t mode | 1:Output mode | | | | | | | | | Prohibit read | l-modify-wr | rite | | | | | | | | | | Figure 3.5.16 Registers for Port 8 ### 3.5.7 Port 9 (P90 to P97) Port 9 is an 8-bit general-purpoe I/O port. I/O can be set on bit basis using the control register P9CR. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register ODCR2. Port 9 becames the input mode by reset. ### (1) P90/TPG12, P91/TPG01 to P94/TPG04, P95/TPG13 P90 and P95 are also used as output pins of TPG12 and TPG13 for the timing pulse generator 1 (TPG1) block. P91 to P94 are also used as output pins of TPG01 to TPG04 for the timing pulse generator 0 (TPG0) block. Switching of the output port function and the TPG output function can be done by the function register P9FC. In the output mode (P9CR<bit> = 1), the output latch data are read from the P9 register. In the input mode (P9CR<bit> = 0), the pin data are read from P9 register. Figure 3.5.17 Port 9 (P90 to P95) ### (2) P96/TPG10, P97/TPG11 P96 and P97 are also used as output pins of TPG10 and TPG11 for the timing pulse generator 1(TPG1) block. Switching of the output port function and the TPG output function can be done by the function register P9FC. In the output mode (P9CR<bit> = 1), the output latch data are read from the P9 register. In the input mode (P9CR<bit> = 0), the pin data are read from P9 register. In addition to output from P96, the TPG10 also controls 3-state-output of P97. When P9CR<P97C> is set to 0, P97 is an output mode at TPG10 = 1, and is a high-impedance (Hz) output mode at TPG10 = 0. | | | | Port 9 Register | | | | | | | | | |---------|-------------|-----|-----------------|-----|-----|-----|-----|-----|-----|--|--| | P9 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | (0017H) | bit Symbol | P97 | P96 | P95 | P94 | P93 | P92 | P91 | P90 | | | | | Read/Write | | R/W | | | | | | | | | | | After reset | 1 | 1 | . 1 | 1 | 1 | 1 | 1 | 1 | | | | | | Port 9 Control Register | | | | | | | | | | |---------|-------------|-------------------------|------|---------------|------|--------|---------|------|------|--|--| | | | 7 | 6 | 5 | 4 | ;<br>3 | 2 | 1 | 0 | | | | P9CR | bit Symbol | P97C | P96C | P95C | P94C | P93C | P92C | P91C | P90C | | | | (0019H) | Read/Write | W | | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | . 0 | 0 | | | | | Function | | | 0: Input mode | | | ut mode | | | | | Prohibit read-modify-write | | | Port 9 Function Register | | | | | | | | | | | |---------|-------------|--------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | P9FC | bit Symbol | P97F | P96F | P95F | P94F | P93F | P92F | P91F | P90F | | | | | (001AH) | Read/Write | | W | | | | | | | | | | | | After reset | 0 | . 0 | . 0 | 0 | . 0 | 0 | 0 | . 0 | | | | | | Function | 0: PORT97 | 0: PORT96 | 0: PORT95 | 0: PORT94 | 0: PORT93 | 0: PORT92 | 0: PORT91 | 0 :PORT90 | | | | | | | 1: TPG11 | 1: TPG10 | 1: TPG13 | 1: TPG04 | 1: TPG03 | 1: TPG02 | 1: TPG01 | 1: TPG12 | | | | Prohibit read-modify-write ### Open Drain Output control Register 2 ODCR2 POD94 | POD93 | POD92 | POD91 | POD90 bit Symbol POD97 | POD96 | POD95 (001BH) Read/Write W 0 0 0 0 0 0 After reset 0 0 Function 0: Push-Pull 1: Open Drain Prohibit read-modify-write Figure 3.5.19 Registers for Port 9 ### 3.5.8 Port A (PA0 to PA5) Port A is an 6-bit general-purpoe I/O port. I/O can be set on bit basis using the control register PACR. Port A also shares functions as a Pseudo-Vsync/Pseudo-Hsync output (PV-PH), Head Amp Switch/Color Rotary output (HA (TPG05), CR (TPG00)) by TPG0 block, a 14-bit PWM output (PWM2), an 8-bit PWM output (PWM3) and write strobe output for external memory ( WR, HWR). Port A becames the input mode by reset. ## (1) PA0/PV-PH PA0 is also used as a Pseudo-Vsync/Pseudo-Hsync output (PV-PH). Switching of the output port function and the PV-PH output function can be done by the function register PAFC. In the output mode (PACR<bit> = 1), the output latch data are read from the PA register. In the input mode (PACR<bit> = 0), the pin data are read from PA register. Figure 3.5.20 Port A (PA0) ## (2) PA1/HA (TPG05), PA2/CR (TPG00) PA1 and PA2 are also used as Head Amp Switch output (HA (TPG05)) and Color Rotary output (CR (TPG00)). Switching of the output port function and the output of the HA (TPG05) and CR (TPG00) can be done by the function register PAFC. In the output mode (PACR<bit> = 1), the output latch data are read from the PA register. In the input mode (PACR<bit> = 0), the pin data are read from PA register. Figure 3.5.21 Port A (PA1, PA2) ## (3) PA3/PWM2, PA4/WR PA3 and PA4 are also used as 14-bit PWM output (PWM2) and write strobe for lower byte of external memory ( $\overline{\text{WR}}$ ). Switching of the output port function and the output of the PWM and $\overline{\text{WR}}$ can be done by the function register PAFC. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register ODCR3. In the output mode (PACR<bit> = 1), the output latch data are read from the PA register. In the input mode (PACR<bit> = 0), the pin data are read from PA register. Figure 3.5.22 Port A (PA3, PA4) ## (4) PA5/PWM3/HWR PA5 is also used as 8-bit PWM output (PWM3) or write strobe for higher byte of external memory (HWR). Switching of the output port function and the PWM output can be done by the function register bit PAFC<PA5F0>. In addition, Switching of the $\overline{HWR}$ output and the output selected by PAFC<PA5F0> can be done by the function register bit PAFC<PA5F1>. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register bit ODCR3<PODA5>. In the output mode (PACR<bit> = 1), the output data selected by PAFC is read from the PA register. In the input mode (PACR<bit> = 0), the pin data is read from PA register. Figure 3.5.23 Port A (PA5) | | | Port A Register | | | | | | | | | | | |----------|-------------|-----------------|--------|--------|------------|------------|-----|-----|-----|--|--|--| | PA | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | . 0 | | | | | (001CH) | bit Symbol | | 1<br>1 | PA5 | PA4 | PA3 | PA2 | PA1 | PA0 | | | | | (00.01.) | Read/Write | | i | i<br>i | | R | w | | | | | | | | After reset | | 1<br>1 | . 1 | <u>.</u> 1 | <u>.</u> 1 | . 1 | . 1 | 1 | | | | | | | | | | Port A Co | ontrol Re | gister | | | | |-----------------|-------------|---|--------|--------|-----------|-----------|---------|---------|------|--| | DAOD | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PACR<br>(001EH) | bit Symbol | | l<br>! | PA5C | PA4C | PA3C | PA2C | PA1C | PA0C | | | (OUTER) | Read/Write | | i<br>i | W | | | | | | | | | After reset | | I<br>I | 0 | 0 | 0 | 0 | 0 | 0 | | | | Function | | i<br>I | i<br>i | 0: Input | mode | 1: Outp | ut mode | | | Prohibit read-modify-write | | Open Drain Output Control Register 3 | | | | | | | | | | | |---------|--------------------------------------|--------|---|-------------|--------------|-----------|------------|-------------|----------|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | ODCR3 | bit Symbol | ! | | 1 | PWMOD1 | PWMOD0 | PODA5 | PODA4 | PODA3 | | | | (0021H) | | i<br>1 | | i<br>1<br>1 | :<br>(PWM1) | (PWM0) | (PortA5) | (PortA4) | (PortA3) | | | | | Read/Write | <br> | | <br> | ! | ٧ | !<br>! | W | | | | | | After reset | i<br>1 | | i<br>I | ; o | 0 | ;<br>0 | ; o | 0 | | | | | Function | 1 | | 1 | PWM0,1 Op | oen drain | Port A Ope | en drain ou | tput | | | | | | i | | i<br>1 | output conti | rol | control | | | | | | | | 1 | | 1 | 0: Push-Pul | I | 0: Push-P | ull | | | | | | | i | | i | 1: Open Dra | ain | 1: Open di | rain | | | | | | | ! | | ! | ! | | ! | | | | | Prohibit read-modify-write #### Port A Function Register 7 6 5 4 3 2 0 PAFC PA5F1 PA5F0 PA4F PA3F PA2F PA1F PA0F bit Symbol (006BH) Read/Write W After reset Function 10: PORTA5 10: PORTA5 10: PORTA4 10: PORTA3 10: PORTA2 10: PORTA1 10: PORTA0 (<<u>PA5</u>F0>) 1: PWM3 /PWM3 1: WR 1: PWM2 1: CR 1: HA 1: PV/PH (TPG00) ¦ (TPG05) 1: HWR Prohibit read-modify-write Figure 3.5.24 Registers for Port A ### 3.5.9 Port B(PB0 to PB5) Port B is an 6-bit general-purpoe I/O port. I/O can be set on bit basis using the control register PBCR. Port B also shares functions as a low-frequency oscillator connecting pin (XT1, XT2), a transmission/reception data input/output pin (S01/SI1) and a transfer clock input/output pin (SCK1) for the synchronous SIO1 block, SDA bus line 1 (SDA1) and SCL bus line 1 (SCL1) for I<sup>2</sup>CBUS block. Port B becames the input mode by reset. ## (1) PB0/XT1, PB1/XT2 PB0 and PB1are also used as a low-frequency oscillator connecting pin (XT1, XT2). In the output mode, these pin are an open drain output. In the output mode (PBCR<bit> = 1), the output latch data are read from the PB register. In the input mode (PBCR<bit> = 0), the pin data is read from PB register. Connecting with resonators for a low-frequency oscillator pin is necessary to set PBCR<PB0C, PB1C> to "11" and PB<PB0, PB1> to 00. Figure 3.5.25 Port B (PB0, PB1) **TOSHIBA** #### (2) PB2/SO1/SI1, PB3/SCK1 PB2 and PB3 are also used as an transmission/reception data input/output pin (SO1/SI1) and a transfer clock input/output pin (SCK1) for the synchronous SIO1 block. Switching of the output port function and the SIO1 function can be done by the function register PBFC. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register bit ODCR4<PODB2, PODB3>. By ODCR4<PRB2, PRB3>, the data read from PB register can be chosen one of which the output data selected by PBFC or the pin data. Figure 3.5.26 Port B (PB2, PB3) ### (3) PB4/SDA1, PB5/SCL1 PB4 and PB5 are also used for a SDA bus line 1 (SDA1) and a SCL bus line 1 (SCL1) of the I2CBUS block. Switching of the general-purpose I/O port function and the I<sup>2</sup>CBUS function can be done by the function register PBFC. In the output mode, switching of the push-pull-output mode and the open-drain-output mode can be done on bit basis by open drain output control register bit ODCR4<PODB4,PODB5>. When these pin are used for the I<sup>2</sup>CBUS function, firstly, set PBFC<PB4F> and <PB5F> to 1, secondly, set ODCR4<PODB4> and <PODB5> to 1, finally, set PBCR<PB4C> and <PB5C> to 1. By ODCR4<PRB4, PRB5>, the data read from PB register can be chosen one of which the output data selected by PBFC or the pin data. Figure 3.5.27 Port B (PB4, PB5) | | | | | | Port | B Regist | er | | | |---------|-------------|---|--------|--------|------|----------|--------|-----|--------------------| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | РВ | bit Symbol | | 1<br>1 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | | (001DH) | Read/Write | | i<br>I | i<br>I | R/ | | ;<br>; | R/W | | | | After reset | | 1<br>1 | 1 | 1 | 1 | 1 | 1 | 1 1 | | | | | i | | | | | | <xten> = 0)</xten> | | | | | Port 8 Control Register | | | | | | | | | | | | |---------|-------------|---|-------------------------|------|--------|----------|----|------|--------|------|------|--------|---|------| | | | 7 | 6 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | | PBCR | bit Symbol | İ | | PB5C | i | PB4C | | PB3C | i<br>i | PB2C | - | PB1C | i | PB0C | | (001FH) | Read/Write | | | | W | | | | | | | . W | | | | | After reset | i | | 0 | i<br>! | 0 | i | 0 | i<br>I | 0 | i | 0 | i | 0 | | | Function | | | | ( | ): Input | mo | ode | | 1: O | utpu | t mode | • | | Prohibit read-modify-write | | | | | Po | ort B Func | tion Regist | er | | | |---------|-------------|---|--------|-----------|------------|-------------|------------|---|---| | | | 7 | 6 | 5 | . 4 | 3 | . 2 | 1 | 0 | | PBFC | bit Symbol | | İ | PB5F | PB4F | PB3F | PB2F | | | | (0020H) | Read/Write | | !<br>! | !<br>! | 1 | | | | | | | After reset | | İ | 0 | 0 | 0 | 0 | | | | | Function | | l<br> | 0: PORTB5 | 0: PORTB4 | 0: PORTB3 | 0: PORTB2 | | | | | | | I | 1: SCL1 | 1: SDA1 | 1: SCK1 | 1: SO1/SI1 | | | Prohibit read-modify-write | | | | | Open D | rain Out | out Contr | ol Regist | ter 4 | | | |-----------------|----------------------------|-------------|--------------|--------|----------|----------------------------------|-----------|----------|----------|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ODCR4 | bit Symbol | PRB5 | PRB4 | PRB3 | PRB2 | PODB5 | PODB4 | PODB3 | PODB2 | | | (0022H) | (PortB5) (PortB4) (PortB3) | | | | | (PortB5) | (PortB4) | (PortB3) | (PortB2) | | | ` ' | Read/Write | | ٧ | ٧ | | l w | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Function | Port B Inpi | ut data sele | ection | | Port B Open drain output control | | | | | | | | 0։ Pin Valւ | ie | | | ı<br>¦0: Push-Pเ | ıll | | | | | 1: Output Value | | | | | | 1: Open Drain | | | | | | • | Prohibit read | d-modify-wi | rite | | | | | | | | Figure 3.5.28 Registers for Port B ## 3.5.10 Port C (PC0 to PC4) Port C is an 5-bit general-purpoe I/O port. I/O can be set on bit basis using the control register PCCR. All bits of the output latch PC are set to 1 by reset, and all bits of PCCR are cleared to 0. Therefore, Port c becames the input mode port. Port C also shares functions as an analog input pin (AIN11 to AIN15) for A/D converter. In the output mode (PCCR<bit> = 1), the output latch data are read from the PC register. In the input mode (PCCR<bit> = 0), the pin data are read from PC register. Figure 3.5.29 Port C (PC0 to PC4) Port C Register | | | | | | | o i togioto | <u> </u> | | | |---------|---------------|------------|--------|---------|-----------|-------------|----------|------------|------| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PC | bit Symbol | | 1<br>1 | l <br> | PC4 | PC3 | PC2 | PC1 | PC0 | | (0087H) | Read/Write | | | | !<br>! | | R/W | | | | | After reset | | | | 1 | 1 | 1 | 1 | 1 | | | | | T | | Port C Co | ontrol Re | gister | • | | | | | 7 | ¦ 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PCCR | bit Symbol | | !<br>! | l<br>! | PC4C | РС3С | PC2C | PC1C | PC0C | | (H8800) | Read/Write | | | | l<br>I | | W | | | | | After reset | | | | 0 | 0 | 0 | 0 | 0 | | | Function | | | | 0: | Input mode | e 1: 0 | Output mod | le | | | Prohibit read | l-modify-w | rite | | | | | | | Figure 3.5.30 Registers for Port C ## 3.6 Chip select / Wait Controller, AM8 / 16 pin TMP93C071 has a built-in controller used to control chip select ( $\overline{CS0}$ to $\overline{CS2}$ ), wait and data bus size (8 or 16 bits) for any of the three block address areas. And AM8 / $\overline{16}$ pin selects external data bus width for TMP93C071. #### 3.6.1 AM8 / $\overline{16}$ pin With fixed external 16-bit data bus and external 16-bit data bus or 8-bit data bus is selectable Set this pin to "L". The external data bus width is set by the chip select / wait control register which is described in section 3.6.3. It is necessary to set the program memory to be accessed to 16-bit data bus after reset. ② With fixed external 8-bit data bus Set this pin to "H". The values of bit 4: <B0BUS>, <B1BUS>, and <B2BUS>, in the chip select / wait control register described in section 3.6.2 are invalid. The external 8-bit data bus is fixed. #### 3.6.2 Address / Data bus pins D0 to 7, D8 to 15, Port 2/A20 to 23, A16 to 19, A8 to 15 and A0 to 7 function as address / data bus for connecting the external memories and so on. | | | 0 | 2 | | | | | |--------|---------|-------------------|-------------------|--|--|--|--| | Prod | lucts | TMP9 | 3C071F | | | | | | Numb | per of | max24 (to 16 MB) | max24 (to 16 MB) | | | | | | addres | ss bus | | | | | | | | piı | ns | | | | | | | | Numb | per of | 8 | 16 | | | | | | data | bus | | | | | | | | piı | ns | | | | | | | | Numb | per of | 8 | 16 | | | | | | multip | lexed | | | | | | | | piı | ns | | | | | | | | Mode | ĒΑ | \ | /IL | | | | | | pins | | | | | | | | | | AM8/ | VIH | VIL | | | | | | | 16 | | | | | | | | Timing | g chart | A23 to 0 A23 to 0 | A23 to 0 A23 to 0 | | | | | | | | cs \ | <del>cs</del> | | | | | | | | /07 | /07 | | | | | | | | D7 to 0 | D15 to 0 | | | | | | | | RD \ | RD \/ | | | | | ## 3.6.3 Chip select / Wait Control Registers Figure 3.6.1 shows control registers. One block address areas are controlled by 1-byte Chip select / WAIT control registers (B0CS, B1CS, B2CS). #### (1) Selection bit for CS output The control register bit 6: <CS0EN>, <CS1EN> and <CS2EN> are used for the chip select output ( $\overline{CS0}$ to $\overline{CS2}$ ) from port terminals. When these bits are set to 1, the $\overline{CS0}$ to $\overline{CS2}$ are output. When these bits are set to 0, functions of the P60 / PWM4, P61 / PWM5 and P62 / PWM6 are selected. When these terminals are used as $\overline{CS0}$ to $\overline{CS2}$ , the port function must be set to the output mode. These port terminals become the input port mode after reset. Therefore, the external pull-up or pull-down resister is necessary for initialization corresponding to usage. #### (2) Data bus size select Bit 4 (<B0BUS>, <B1BUS>, <B2BUS>) of the control register is used to specify data bus size. Setting this bit to 0 accesses the memory in 16-bit data bus mode; setting it to 1 accesses the memory in 8-bit data bus mode. Changing data bus size depending on the access address is called dynamic bus sizing. Table 3.6.1) shows the details of the bus operation. This bit is changed by the state of AM8 $/\overline{16}$ pin. ## (3) Wait control Control register bits 3 and 2 (<B0W1, 0>, <B1W1, 0>, <B2W1, 0>) are used to specify the number of waits. These bits execute the following operation by setting. "11" A 2-state wait is inserted. "01" A 1-state wait is inserted. "10" A 1-state wait is inserted. "00" The bus cycle is completed without a wait (0 WAIT). These bits are cleared to "00" (0 WAIT mode) by reset. ## (4) Address area specification Control register bits 1 and 0 (<B0C1, 0>, <B1C1, 0>, <B2C1, 0>) are used to specify the target address area. Setting these bits to 00 enables settings as follows: - · B0CS setting enabled when 2090H to 3FFFFFH is accessed. - B1CS setting enabled when 2090H to 3FFFFFH is accessed. - B2CS setting enabled when 2090H to 3FFFFFH is accessed. Setting bits to 01 enables setting for each block when 400000H to 7FFFFH is accessed. Setting bits to 10 enables them 800000H to BFFFFFH is accessed. Setting bits to 11 enables them when C00000H to FFFFFFH is accessed. When the CSWAIT controller (CS0 to CS2) is used, do not set the same area with other CSs. The channel of a smaller number must be set another area than the selected CS regardless of enable/disable (whichever B\*CS<CS\*EN> is 1 or 0). Chip select/Wait Control Register 0 B0CS (0068H) | | | 7 | . 6 | 5 | 4 | 3 | 2 | <u>.</u> 1 | 0 | |----|-------------|---|-----------------------------|--------|-----------|------------|------|---------------------|-------------| | | bit Symbol | | CS0EN | | B0BUS | B0W1 | B0W0 | B0C1 | B0C0 | | 1) | Read/Write | | ! W | ! | ! w | ! v | ٧ | ! \<br>! | ٧ | | | After reset | | . 0 | | 0 | | ) | !<br>! | 0 | | | Function | | 0: Port60 | | BUS width | Wait contr | ol | 00: 2090H to | 3FFFFFH | | | | | /PWM4 | | control | 00: 0 WAI | Т | 01: <b>4</b> 00000H | to 7FFFFF | | | | | i (P6FC<br>i <p60f>)</p60f> | | 0: 16-bit | 01: 1 WAI | Т | 10: 800000H | to BFFFFF | | | | | 1 41 001 2 / | | Bus | 10: 1 WAI | Т | 11: C00000I | H to FFFFFF | | | | | 1: CS0 | !<br>! | 1: 8-bit | 11: 2 WAI | Т | !<br>! | | | | | | ! | | Bus | : | | !<br>! | | Prohibit read-modify-write Chip select/Wait Control Register 1 B1CS (0069H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-------------|---|-----------------------------------------------|--------|-----------------------|---------------------------------------------------|-------------|------------------|------| | , | bit Symbol | | CS1EN | | B1BUS | B1W1 | B1W0 | B1C1 | B1C0 | | 9H) | Read/Write | | W | | w | į v | ٧ | į , | N | | | After reset | | 0 | !<br>! | . 0 | <u>:</u> ( | ) | !<br>! ! | 0 | | | Function | | 0: Port61<br>/PWM5<br>(P6FC<br><p61f>)</p61f> | | 0: 16-bit<br>Bus | Wait contr<br>00: 0 WAI<br>01: 1 WAI<br>10: 1 WAI | Т<br>Т<br>Т | ! | | | | | | ¦1: CS1<br>¦ | | '1: 8-bit<br>'<br>Bus | TITE Z VVAL | I | !<br>!<br>!<br>! | | Prohibit read-modify-write Chip select/Wait Control Register 2 B2CS (0070H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----|-------------|---|-------------------------|--------|-----------|--------------|------|---------------------|-------------|--| | | bit Symbol | | CS2EN | | B2BUS | B2W1 | B2W0 | B2C1 | B2C0 | | | I) | Read/Write | | W | | . W | W | | !<br>! | ٧ | | | | After reset | | 0 | | 0 | 0 | | 0 | | | | | Function | | 0: Port62 | | BUS width | Wait control | | 00: 2090H to | 3FFFFFH | | | | | | PWM6 | i<br>i | control | 00: 0 WAIT | | 01: <b>4</b> 00000H | to 7FFFFF | | | | | | (P6FC<br><p62f>)</p62f> | | 0: 16-bit | 01: 1 WAI | Т | 10: 800000H | to BFFFFF | | | | | | 1 | i | Bus | 10: 1 WAIT | | 11: C00000I | H to FFFFFF | | | | | | 1: CS2 | !<br>! | 1: 8-bit | 11: 2 WAIT | | <br> | | | | | | | l | | Bus | | | <br> | | | Prohibit read-modify-write Figure 3.6.1 Chip select/Wait Control Registers Table 3.6.1 Dynamic bus sizing | Operand data | Operand start | Memory data | CPU address | CPU d | data | |--------------|---------------|-------------|-------------|------------|------------| | size | address | size | | | | | | | | | D15 to D8 | D7 to D0 | | 8 bits | 2n + 0 | 8 bits | 2n + 0 | xxxxx | b7 to b0 | | | (even number) | | | | | | | | 16 bits | 2n + 0 | xxxxx | b7 to b0 | | | 2n + 1 | 8 bits | 2n + 1 | XXXXX | b7 to b0 | | | (odd number) | | | | | | | | 16 bits | 2n + 1 | b7 to b0 | xxxxx | | 16 bits | 2n + 0 | 8 bits | 2n + 0 | XXXXX | b7 to b0 | | | (even number) | | 2n + 1 | XXXXX | b15 to b8 | | | | 16 bits | 2n + 0 | b15 to b8 | b7 to b0 | | | 2n + 1 | 8 bits | 2n + 1 | XXXXX | b7 to b0 | | | (odd number) | | 2n + 2 | XXXXX | b15 to b8 | | | | 16 bits | 2n + 1 | b7 to b0 | xxxxx | | | | | 2n + 2 | XXXXX | b15 to b8 | | 32 bits | 2n + 0 | 8 bits | 2n + 0 | XXXXX | b7 to b0 | | | (even number) | | 2n + 1 | XXXXX | b15 to b8 | | | | | 2n + 2 | XXXXX | b23 to b16 | | | | | 2n + 3 | XXXXX | b31 to b24 | | | | 16 bits | 2n + 0 | b15 to b8 | b7 to b0 | | | | | 2n + 2 | b31 to b24 | b23 to b16 | | | 2n + 1 | 8 bits | 2n + 1 | xxxxx | b7 to b0 | | | (odd number) | | 2n + 2 | xxxxx | b15 to b8 | | | | | 2n + 3 | xxxxx | b23 to b16 | | | | | 2n + 4 | xxxxx | b31 to b24 | | | | 16 bits | 2n + 1 | b7 to b0 | xxxxx | | | | | 2n + 2 | b23 to b16 | b15 to b8 | | | | | 2n + 4 | XXXXX | b31 to b24 | xxxxx: During a read, data input to the bus is ignored. At write, the bus is at high impedance and the write strobe signal remains non-active. ## 3.6.4 Chip select / Wait control An image of the actual Chip select / Wait control is shown below. The address area can be specified only one of the whole external memory area divided into four parts. | 000000H | | |---------|---------------------------| | 2090H | | | | <b2c1, 0=""> = 00</b2c1,> | | 400000H | <b2c1, 0=""> = 01</b2c1,> | | H000008 | <b2c1, 0=""> = 10</b2c1,> | | C00000H | | | FEFFEFH | <b2c1, 0=""> = 11</b2c1,> | - Note 1: Access priority is highest for built-in I/O, then built-in memory, and lowest for the chip select / wait controller. - Note 2: External areas other than B0CS to B2CS are accessed in 0 wait mode. When the AM8/16 pin is set to "L", the data bus width is fixed to 16-bit. When the AM8/16 pin is set to "H", it is fixed to 8-bit. When using the chip select/wait controller, do not specify the same address area more than once. (The bit 4 to 2 of the B0CS to B2CS must be the same setting respectively when the same address area is specified.) #### 3.7 Timer Counter ## 3.7.1 8-bit Timer Counter 0 (TC0) TC0 is an 8-bit timer counter. The TC0 is counted by a source clock selected by the Timer Counter Control Register10 (TCCR10). The TC0 is composed of an 8-bit Up-counter, Timer register (TREG0), and 8-bit Comparator. #### (1) Block diagram Figure 3.7.1 composition of the timer counter 0 #### ① Up-counter The Up-counter is an 8-bit binary counter. The Up-counter counts the input clock specified with <T0CLK1, 0> of the Timer Counter Control Register 10 (TCCR10). The input clock of the TC0 can be selected from TBC6 (2<sup>7</sup>/fc), TBC10 (2<sup>11</sup>/fc) of the Time Base Counter (TBC), TI0 (P57) of an external input and PCTLA from the Capture Input controller (CAPIN). The Up-counter can be controlled the start and stop of counting by the Timer start control register (TRUN). The value of the Up-counter is cleared by reset and the timer counter stops at the same time.TCCR10<CLBC0> can set the clear enable/disable of the Up-counter by the match output of the comparator. When TCCR10<T0CL> is set to "1", the Up-counter is compulsorily cleared. ### ② Timer register (TREG0) The Timer Register (TREG0) is an 8-bit register for setting the interval time. When a value of the timer register matches to the value of Up-counter, the match signal is output from the comparator. If the value of the timer register is set to "00H", the match signal is output at the time of the up-counter overflow. When a new value is set to the timer register, the new value is forwarded to the comparator at once. Reading the timer register can read the value of the 8-bit up-counter in real time. (The value of the interval time is not read.) Because the timer register is not initialized by the reset operation (The value of the timer register becomes an unknown value), attention is necessary. #### 3 Comparator The 8-bit comparator compares a value of the up-counter and a value of the timer register. When the value of the timer register matches to the value of the Up-counter, the interrupt request (INTT0) is occurred. TCCR10<CLBC0> can set the clear enable/disable of the up-counter by the match output of the comparator. #### (2) Control Register | | | | Timer start control register | | | | | | | | |---------|-------------|---|------------------------------|-------|-------|---------|----------|---------|-------|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TRUN | bit Symbol | | | T5RUN | T4RUN | ¦ T3RUN | T2RUN | ¦ T1RUN | T0RUN | | | _ | Read/Write | | | ! | | R/ | W | | | | | (0027H) | After reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Function | | | | | 0: Stop | 1: Start | | | | Timer Counter Control register10 6 5 4 3 TCCR10 bit Symbol CLBC1 T1CL T1CLK1 T1CLK0 CLBC0 T0CL TOCLK1 TOCLKO Read/Write R/W R/W R/W R/W R/W R/W (0028H) After reset 0 0 0 0 0 TC1 timer/ TC1 source clock TC0 timer/ TC0 source clock Function TC1 TC0 timer/ counter selection timer/ counter selection counter clear counter clear match 00: PCTLA match 00: TI1 01: TBC2 (from CAPIN) clear <u>'0: —</u> ıclear <u>'0: -</u> 01: TIO 1: Clear 1: Clear enable 10: TBC4 enable (One-shot) 11: TBC6 !(One-shot) 10: TBC6 0: Disable 0: Disable 11: TBC10 1: Enable !1: Enable Timer Register 0 TC/TR04 TC/TR03 TC/TR02 TC/TR01 TC/TR00 bit Symbol TC/TR07 TC/TR06 TC/TR05 TREG0 Read/Write R/W (0029H)n 0 Π After reset 0 Function W: Writing TREG0 register R: Reading TC0 counter Figure 3.7.2 Registers for TC0 #### (3) Operation explanation ① Generating interrupts at a constant cycle. First of all, TC0 is stopped. The input clock and the cycle are set to TCCR10 and TREG0 respectively. Next, the TC0 interrupt(INTT0) is enabled. The TC0 is counted at the end. Example: When the TC0 interrupt of each 32 us is generated with fc = 20 MHz, Set each register in the following order. | | MSB LSB | | |--------|-----------------|----------------------------------------------------------| | TRUN | 0 | The count of the TC0 is stopped. | | TCCR10 | 1*10 | The source clock is set to TBC6 (6.4 us). | | TREG0 | 00000101 | 32 us $\div$ 6.4 us = 05 H is set to the timer register. | | INT4T0 | 0 n n n – – – – | INTT0 interrupt is enabled with Level "nnn". | | TRUN | 1 | The count of the TC0 is started. | | | | | (Note) \*:don't care -: no change Table 3.7.1 Interrupt Interval for the TC0 | Interrupt Interval (fc = 20 MHz) | Resolution | Input Clock | |----------------------------------|------------|-----------------------------| | 6.4 us to 1.638 ms | 6.4 us | TBC6 (2 <sup>7</sup> /fc) | | 102.4 us to 26.214 ms | 102.4 us | TBC10 (2 <sup>11</sup> /fc) | #### ② Using the TC0 as an event counter It is a mode to which the count up is done with rising edge of TI0 (P57)input. The INTT0 interrupt request is occurred when the value of the counter matches to the value of the TREGO. The maximum input frequency is $fc/2^4$ [Hz] (1.25 MHz at fc = 20 MHz). The minimum input pulse width is $2^3$ /fc [s] (400 ns at fc = 20 MHz) at both H levels and L levels. #### 3 Using the TC0 for counting of the Play-Back-Control signal (CTL) It is a mode to which the count up is done with rising edge of the PCTLA. The PCTLA is the CTL signal switched polarity with the capture input controller, and the CTL signal is input ted from CTLIN (P80) pin. The INTTO interrupt request is occurred when the value of the counter matches to the value of the TREGO. The maximum input frequency is $fc/2^4$ [Hz] (1.25 MHz at fc = 20 MHz). The minimum input pulse width is 23/fc [s] (400 ns at fc = 20 MHz) at both H levels and L levels. #### 3.7.2 16-bit Timer counter 1, 2, 3, 4, 5 (TC1, TC2, TC3, TC4, TC5) The TC1 to TC5 are the 16-bit timer counter which count with the source clock selected by the Timer counter control register (TCCR10, TCCR32, TCCR54). The TC1 to TC5 are composed of the 16-bit upcounter, the timer register (TREG1L/TREG1H, TREG2L/TREG2H, TREG3L/TREG3H, TREG4L/TREG4H, TREG5L/TREG5H), and the 16-bit comparator. The basic composition of these timer counter are all the same except for the input clock source, and the basic operation are similar to the TC0 operation with 16-bit. ## (1) Block diagram Figure 3.7.3 Composition of the Timer Counter 1 Figure 3.7.4 Composition of the Timer Counter 2 Figure 3.7.5 Composition of the Timer Counter 3 Figure 3.7.6 Composition of the Timer Counter 4 Figure 3.7.7 Composition of the Timer Counter 5 #### (2) Timer Counter 1(TC1) TC1 is the 16-bit timer counter. The TC1 is counted by the source clock selected by <T1CLK1,0> of the Timer counter control register10(TCCR10). The input clock of the TC1 can be selected from TBC2 (2³/fc), TBC4 (2⁵/fc), TBC6 (2⁵/fc) of the Time Base Counter (TBC), TI1 (P52) of an external input. The up-counter can be controlled the start and stop of counting by the Timer start control register (TRUN). The value of the up-counter is cleared by reset and the timer counter stops at the same time. TCCR10<CLBC1> can set the clear enable/disable of the Up-counter by the match output of the comparator. When TCCR10<T1CL> is set to "1", the Up-counter is compulsorily cleared. The timer register are the 8-bit\*2byte registers (TREG1L, TREG1H) for setting the value of the interval time. Set the value in order of TREG1L → TREG1H.When the value of the timer register matches to the value of the Up-counter, the match signal is output from the comparator, and the interrupt request (INTT1) is occurred. If the value of the timer register is set to 0000H, the match signal is output at the time of the up-counter overflow. When a new value is set to the timer register, the new value is forwarded to the comparator at once. Reading the timer register in order of TREG1L → TREG1H can read the value of the 16-bit up-counter in real time. (The value of the interval time is not read.) Because the timer register is not initialized by the reset operation (The value of the timer register becomes an unknown value), attention is necessary. | | Tir | ner Start | Control | Register | |--|-----|-----------|---------|----------| | | | | | | TRUN (0027H) | | 7 | - | 6 | | 5 | ī | 4 | ; | 3 | | 2 | Г | 1 | | 0 | |-------------|---|---|---|------------|------|---|-------|--------|-----|------------|--------|-----|-------|---|------| | bit Symbol | | I | | <u>;</u> T | 5RUN | ! | T4RUN | ; T3F | NUS | <u>;</u> T | 2RUN | | T1RUN | T | 0RUN | | Read/Write | | | | | | | | | R/ | W | | | | | | | After reset | | i | | <u> </u> | 0 | i | 0 | ; ( | ) | | 0 | - | 0 | | 0 | | Function | | 1 | | ! | | | | 0: Sto | p | | 1: Sta | art | | | | | _ | | | | Timer C | ounter C | Control R | egister 10 | | | |---------|-------------|------------|------------|-----------|----------|------------|------------|------------|---------| | | | 7 | 6 | 5 | 4 | 3 | 2 | i 1 | 0 | | | bit Symbol | CLBC1 | T1CL | T1CLK1 | T1CLK0 | CLBC0 | T0CL | T0CLK1 | T0CLK0 | | TCCR10 | Read/Write | R/W | . R/W | . R/ | W | R/W | . R/W | ! R/ | W | | (0028H) | After reset | 0 | 0 | i ( | ) | 0 | 0 | i ( | ) | | (, | Function | TC1 | TC1 timer/ | TC1 sourc | e clock | TC0 | TC0 timer/ | TC0 sourc | e clock | | | | | counter | selection | | !timer/ | counter | selection | | | | | counter | iclear | i | | counter | iclear | i | | | | | match | 1 | 100: TI1 | | !match | ! | 100: PCTLA | | | | | clear | i0: — | i01: TBC2 | | iclear | i0: — | i (from | CAPIN) | | | | enable | 1: Clear | 10: TBC4 | | enable! | 1: Clear | ¦01: TI0 | | | | | | (One-shot) | 11: TBC6 | | i | (One-shot) | i10: TBC6 | | | | | 0: Disable | 1 ' | ! | | 0: Disable | | 11: TBC10 | ) | | | | 1: Enable | i | i | | i1: Enable | i | i | | | | | | | | | | | ımer | Rε | egiste | 1 1 L | | | | | | |-----------|-------------|---------|----|-------|--------|-------|-------|---------|----|---------|-------|--------|-------|-------|----------|--------| | | | 7 | 1. | 6 | Ι | 5 | ! | 4 | ! | 3 | ! | 2 | ! | 1 | Ţ | 0 | | TREG1L | bit Symbol | TC/TR17 | TC | /TR16 | TC. | /TR15 | TC | /TR14 | iΤ | C/TR13 | iTC | )/TR12 | ? ¦ T | C/TR1 | <u> </u> | C/TR10 | | (000 411) | Read/Write | | | | | | | R | /W | | | | | | | | | (002AH) | After reset | 0 | 1 | 0 | ! | 0 | | 0 | ! | 0 | Ţ | 0 | - | 0 | Ţ | 0 | | | Function | | | W: W | ritina | TREC | 31L i | reaiste | r | R: Read | dina | TC1L | cou | nter | | | | | | | | | | Time | r H | tegister | 1H | | | | |---------|-------------|---------|-------|--------|--------|-----------|-----|----------|---------|------|-------|---------| | | | 7 | : 6 | - ! | 5 | ! 4 | 1 | 3 | 2 | ! | 1 | 0 | | TREG1H | bit Symbol | TC/TR1F | TC/TR | 1E T | C/TR1D | TC/TR1 | c¦: | TC/TR1B | TC/TR1/ | A¦TC | /TR19 | TC/TR18 | | • | Read/Write | | | | | | R/V | ٧ | | | | | | (002BH) | After reset | 0 | . 0 | ! | 0 | ! 0 | 1. | 0 | 0 | ! | 0 | 0 | | | Function | | W: | Writin | a TREC | 1H regist | er | R: Read | na TC1H | coun | ter | | Note: Setting and reading in order of TREG1L→TREG1H are necessary. Figure 3.7.8 Registers for TC1 #### (3) Timer Counter 2 (TC2) TC2 is the 16-bit timer counter. The TC2 is counted by the source clock selected by <T2CLK1,0> of the Timer counter control register32(TCCR32). The input clock of the TC2 can be selected from TBC2 (2³/fc), TBC4 (2⁵/fc), TBC6 (2⁵/fc) of the Time Base Counter (TBC), TI2 (P51) of an external input. The up-counter can be controlled the start and stop of counting by the Timer start control register (TRUN). The value of the up-counter is cleared by reset and the timer counter stops at the same time. TCCR10<CLBC2> can set the clear enable/disable of the Up-counter by the match output of the comparator. When TCCR32<T2CL> is set to 1, the Up-counter is compulsorily cleared. The timer register are the 8-bit\*2 byte registers (TREG2L, TREG2H) for setting the value of the interval time. Set the value in order of TREG2L → TREG2H. When the value of the timer register matches to the value of the Up-counter, the match signal is output from the comparator, and the interrupt request (INTT2) is occurred. If the value of the timer register is set to 0000H, the match signal is output at the time of the up-counter overflow. When a new value is set to the timer register, the new value is forwarded to the comparator at once. Reading the timer register in order of TREG2L → TREG2H can read the value of the 16-bit up-counter in real time. (The value of the interval time is not read.) Because the timer register is not initialized by the reset operation (The value of the timer register becomes an unknown value), attention is necessary. Timer start control Register | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | . 0 | |----------|-------------|---|---|-------|-------|---------|----------|-------|-------| | TRUN | bit Symbol | | 1 | T5RUN | T4RUN | T3RUN | T2RUN | T1RUN | TORUN | | (0027H) | Read/Write | | 1 | | | R/ | W | | | | (002711) | After reset | | ı | 0 | ١ 0 | ٠ 0 | 0 1 | 0 | 0 | | | Function | | | | | 0: Stop | 1: Start | | · | Timer Counter Control Register 32 | TOODOO | bit | |-------------------|-----| | TCCR32<br>(002CH) | Re | | (002CH) | Af | | | F | | | | 7 | 6 | 5 | 4 | 3 | 2 | i 1 | 0 | |-----|-------------|--------------------------|--------------------------------|---------------------------------|--------|------------------|--------------------------------|---------------------------------|---------| | 2 | bit Symbol | CLBC3 | T3CL | T3CLK1 | T3CLK0 | CLBC2 | T2CL | T2CLK1 | T2CLK0 | | ۱ ۲ | Read/Write | R/W | ¦ R/W | ! R/ | W | R/W | . R/W | ¦ R/ | W | | 1) | After reset | 0 | ١ 0 | ı ( | ) | · 0 | ١ 0 | 1 ( | ) | | | | TC3<br>timer/<br>counter | TC3 timer/<br>counter<br>clear | TC3 source<br>selection | | timer/ | TC2 timer/<br>counter<br>clear | TC2 source<br>selection | e clock | | | | match<br>clear | 1 | 00: TI3<br>01: TBC2<br>10: TBC4 | | ¦match<br>iclear | 1 | 00: TI2<br>01: TBC2<br>10: TBC4 | | | | | | (One-shot) | 11: TBC6 | | | (One-shot) | 11: TBC6 | | Timer Register 2L | | | 7 | 6 | 5 | <u> </u> | 3 | 2 | ; 1 | 0 | | | | | |-----------|-------------|---------|----------------------------------------------------|---------|----------|---------|---------|---------|---------|--|--|--|--| | TREG2L | bit Symbol | TC/TR27 | TC/TR26 | TC/TR25 | TC/TR24 | TC/TR23 | TC/TR22 | TC/TR21 | TC/TR20 | | | | | | (002EH) | Read/Write | | R/W | | | | | | | | | | | | (00==:.,) | After reset | 0 | 0 | 0 | ¦ 0 | 0 | 0 | ¦ 0 | 0 | | | | | | | Function | | W: Writing TREG2L register R: Reading TC2L counter | | | | | | | | | | | Timer Register 2H TREG2H (002FH) | | | 7 | ¦ 6 | 5 | 4 | 3 | , 2 | <u> </u> | 0 | |----|-------------|---------|------------|------------|-------------|---------|------------|----------|---------| | 2H | bit Symbol | TC/TR2F | TC/TR2E | TC/TR2D | TC/TR2C | TC/TR2B | TC/TR2A | TC/TR29 | TC/TR28 | | 1) | Read/Write | | | | R/ | W | | | | | | After reset | 0 | <u>'</u> 0 | 0 | 0 | 0 | 0 | ¦ 0 | 0 | | | Function | | W: Wr | iting TREG | 2H register | R: Read | ing TC2H c | counter | | Note: Setting and reading in order of TREG2L→TREG2H are necessary. Figure 3.7.9 Registers for TC2 ### (4) Timer Counter 3 (TC3) TC3 is the 16-bit timer counter. The TC3 is counted by the source clock selected by <T3CLK1, 0> of the Timer counter be register32 (TCCR32). The input clock of the TC3 can be selected from TBC2 ( $2^3$ /fc), TBC4 ( $2^5$ /fc), TBC6 ( $2^7$ /fc) of the Time Base Counter (TBC), TI3 (P50) of an external input. The up-counter can be controlled the start and stop of counting by the Timer start control register (TRUN). The value of the up-counter is cleared by reset and the timer counter stops at the same time. TCCR32<CLBC3> can set the clear enable/disable of the Up-counter by the match output of the comparator. When TCCR32<T3CL> is set to 1, the Up-counter is compulsorily cleared. The timer register are the 8-bit\*2byte registers (TREG3L, TREG3H) for setting the value of the interval time. Set the value in order of TREG3L $\rightarrow$ TREG3H. When the value of the timer register matches to the value of the Up-counter, the match signal is output from the comparator, and the interrupt request (INTT3) is occurred. If the value of the timer register is set to 0000H, the match signal is output at the time of the up-counter overflow. When a new value is set to the timer register, the new value is forwarded to the comparator at once. Reading the timer register in order of TREG3L $\rightarrow$ TREG3H can read the value of the 16-bit up-counter in real time. (The value of the interval time is not read.) Because the timer register is not initialized by the reset operation (The value of the timer register becomes an unknown value), attention is necessary. **Timer Start Control Register** TRUN (0027H) | | 7 | 6 | 5 | 4 | 3 | 2 | ¦ 1 | ¦ 0 | |-------------|---|---|-------|-------|---------|---------|---------|---------| | bit Symbol | | | T5RUN | T4RUN | T3RUN | T2RUN | ¦ T1RUN | ' TORUN | | Read/Write | | | | | R | W | | | | After reset | | | 0 | 0 | 0 | 0 | i o | 0 | | function | | | | | 0: Stop | 1: Star | t | | Timer Counter Control Register 32 TCCR32 (002CH) | _ | | | | | | | | | | | | |-----|-------------|------------|------------|-----------|---------|------------|------------|------------|---------|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | ¦ 1 | , 0 | | | | 2 | bit Symbol | CLBC3 | . T3CL | ! T3CLK1 | T3CLK0 | CLBC2 | T2CL | ! T2CLK1 | T2CLK0 | | | | 1) | Read/Write | R/W | R/W | i R/ | W | R/W | R/W | i R | W | | | | " [ | After reset | 0 | 0 | ; ( | ) | , 0 | 0 | <u> </u> | ) | | | | | Function | TC3 | TC3 timer/ | TC3 sourc | e clock | TC2 | TC2 timer/ | TC2 source | e clock | | | | | | timer/ | counter | selection | | itimer/ | icounter | selection | | | | | | | counter | clear | 1 | | counter | clear | 1 | | | | | | | match | i | i00: TI3 | | match | i | i00: TI2 | | | | | | | clear | ¦0: — | 01: TBC2 | | clear | ¦0: — | 01: TBC2 | | | | | | | enable | 11: Clear | 10: TBC4 | | enable | 1: Clear | 10: TBC4 | | | | | | | | (One-shot) | 11: TBC6 | | ! | (One-shot) | 11: TBC6 | | | | | | | 0: Disable | | | | 0: Disable | i` | 1 | | | | | | | 1: Enable | 1 | ! | | 1: Enable | ! | 1 | | | | Timer Register 3L | | | | | | | | _ | | | | |----------|-------------|---------|---------|------------|-------------|---------|------------|---------|---------|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | i 1 | 0 | | | TREG3L | bit Symbol | TC/TR37 | TC/TR36 | TC/TR35 | TC/TR34 | TC/TR33 | TC/TR32 | TC/TR31 | TC/TR30 | | | (0030H) | Read/Write | | R/W | | | | | | | | | (00001.) | After reset | 0 | 0 | 0 | 0 | ٠ 0 | 0 | 0 | 0 | | | | Function | | W: Wr | iting TREG | 3L register | R: Read | ing TC3L o | ounter | | | Timer Register 3H | | | 7 | i 6 | i | 5 | 4 | i | 3 i | 2 | i 1 | i | 0 | |---------|-------------|---------|-------|---------|------|------------|-----|----------|---------|---------|-----|--------| | TREG3H | bit Symbol | TC/TR3F | TC/TR | 3E¦TC/ | TR3D | TC/TR3C | Τ¦C | C/TR3B | TC/TR3A | TC/TR3 | 9¦Τ | C/TR38 | | (0031H) | Read/Write | | R/W | | | | | | | | | | | ` / | After reset | 0 | ۰ 0 | 1 | 0 | ٠ 0 | 1 | ۱ 0 | 0 | ١ 0 | 1 | 0 | | | Function | | W: | Writina | TREG | 3H reaiste | ∍r | R: Readi | na TC3H | counter | | | Note: Setting and reading in order of TREG3L → TREG3H are necessary. Figure 3.7.10 Registers for TC3 #### (5) Timer Counter 4 (TC4) TC4 is the 16-bit timer counter. The TC4 is counted by the source clock selected by <T4CLK1, 0> of the Timer counter control register54(TCCR54). The input clock of the TC4 can be selected from TBC4 ( $2^5$ /fc), TBC6 ( $2^7$ /fc) of the Time Base Counter (TBC), TI4 (P56) of an external input, CFGTM from the capture input controller (CAPIN). The up-counter can be controlled the start and stop of counting by the Timer start control register (TRUN). The value of the up-counter is cleared by reset and the timer counter stops at the same time. TCCR54<CLBC4> can set the clear enable/disable of the Up-counter by the match output of the comparator. When TCCR54<T4CL> is set to 1, the Up-counter is compulsorily cleared. The timer register are the 8-bit\*2 byte registers (TREG4L, TREG4H) for setting the value of the interval time. Set the value in order of TREG4L $\rightarrow$ TREG4H. When the value of the timer register matches to the value of the Up-counter, the match signal is output from the comparator, and the interrupt request (INTT4) is occurred. If the value of the timer register is set to 0000H, the match signal is output at the time of the up-counter overflow. When a new value is set to the timer register, the new value is forwarded to the comparator at once. Reading the timer register in order of TREG4L $\rightarrow$ TREG4H can read the value of the 16-bit up-counter in real time. (The value of the interval time is not read.) Because the timer register is not initialized by the reset operation (The value of the timer register becomes an unknown value), attention is necessary. **Timer Start Control Register** TRUN (0027H) | | 7 | ¦ 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|-----|-------|-------|---------|----------|-------|-------| | bit Symbol | | ! | T5RUN | T4RUN | T3RUN | T2RUN ' | T1RUN | TORUN | | Read/Write | | ! | | | R/ | W | | | | After reset | | 1 | 0 | 0 | ¦ 0 | 0 | 0 | 0 | | Function | | I . | I. | | 0: Stop | 1: Start | 1 | | | | | | | Timer C | ounter C | Control Re | egister 54 | | | |----------|-------------|------------|------------|-----------|----------|-------------|------------|------------|---------| | | | 7 | 6 | 5 | 4 | 3 | 2 | i 1 | 0 | | TCCR54 | bit Symbol | CLBC5 | T5CL | T5CLK1 | T5CLK0 | CLBC4 | T4CL | T4CLK1 | T4CLK0 | | (002DH) | Read/Write | R/W | R/W | ; R/ | W | ! R/W ! R/W | | ¦ R/W | | | (002211) | After reset | 0 | 0 | ١ ( | ) | ٠ 0 | ٠ 0 | ۱ ( | ) | | | Function | TC5 | TC5 timer/ | TC5 sourc | e clock | TC4 | TC4 timer/ | TC4 source | e clock | | | | timer/ | counter | selection | | timer/ | counter | selection | | | | | | iclear | i | | | iclear | i | | | | | match | !<br>! | 100: TI5 | | ¦match | 1 | ¦00: TI4 | | | | | clear | 0: — | 101: CSYN | CA | iclear | i0: — | i01: CFGTI | м | | | | enable | 1: Clear | from V | ′-sepa) | enable | 1: Clear | (from C | CAPIN) | | | | | (One-shot) | 110: TBC4 | | i | (One-shot) | i10: TBC4 | | | | | 0: Disable | i<br>I | 11: TBC6 | | ¦0: Disable | | 11: TBC6 | | | | | 1: Enable | ı | i | | 1: Enable | 1 | 1 | | | | | | Timer Register 4L | | | | | | | | | |---------|-------------|---------|----------------------------------------------------|---------|---------|---------|---------|---------|----------|--|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | ! 1 | <u> </u> | | | | TREG4L | bit Symbol | TC/TR47 | TC/TR46 | TC/TR45 | TC/TR44 | TC/TR43 | TC/TR42 | TC/TR41 | TC/TR40 | | | | (0033H) | Read/Write | | R/W | | | | | | | | | | (, | After reset | 0 | 0 | 0 | 0 | 0 | 0 | . 0 | . 0 | | | | | Function | | W: Writing TREG4L register R: Reading TC4L counter | | | | | | | | | | | | | | | | | | | | | | Note: Setting and reading in order of TREG4L → TREG4H are necessary. Figure 3.7.11 Registers for TC4 #### (6) Timer Counter 5 (TC5) TC5 is the 16-bit timer counter. The TC5 is counted by the source clock selected by <T5CLK1, 0> of the Timer counter control register54 (TCCR54). The input clock of the TC5 can be selected from TBC4 (2⁵/fc), TBC6 (2⁵/fc) of the Time Base Counter (TBC), TI5 (P55) of an external input, CSYNCA from the composit-sync-separation (CSYNC). The up-counter can be controlled the start and stop of counting by the Timer start control register (TRUN). The value of the up-counter is cleared by reset and the timer counter stops at the same time. TCCR54<CLBC5> can set the clear enable/disable of the Up-counter by the match output of the comparator. When TCCR54<T5CL> is set to 1, the Up-counter is compulsorily cleared. The timer register are the 8-bit\*2 byte registers (TREG5L, TREG5H) for setting the value of the interval time. Set the value in order of TREG5L → TREG5H. When the value of the timer register matches to the value of the Up-counter, the match signal is output from the comparator, and the interrupt request (INTT5) is occurred. If the value of the timer register is set to 0000H, the match signal is output at the time of the up-counter overflow. When a new value is set to the timer register, the new value is forwarded to the comparator at once. Reading the timer register in order of TREG5L → TREG5H can read the value of the 16-bit up-counter in real time. (The value of the interval time is not read.) Because the timer register is not initialized by the reset operation (The value of the timer register becomes an unknown value), attention is necessary. Timer Control Register TRUN (0027H) | | 7 | i 6 | 5 | 1 4 | 1 | ; 3 | i | 2 | i | 1 | i | 0 | |-------------|---|-----|--------|-----|----|---------|--------------|---------|------|-----|---|-------| | bit Symbol | | 1 | T5RUN | T4R | UN | T3RUN | ۲ <u>-</u> ۱ | Γ2RUN | ¦ T1 | RUN | - | TORUN | | Read/Write | | 1 | I<br>I | | | | R/W | | | | | | | After reset | | ı | ٠ 0 | ١ ( | ) | ١ 0 | ı | 0 | ı | 0 | ı | 0 | | Function | | 1 | 1 | | | 0: Stop | | 1: Stai | rt | | | | Timer Counter Control Register 54 TCCR54 (002DH) | г | | | ٠ 6 | ı 5 | ٠ 4 | 3 | 1 2 | 1 1 | . 0 ] | |-----|-------------|-----------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------|---------------|-----------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------|--------| | 4 L | bit Symbol | CLBC5 | T5CL | T5CLK1 | T5CLK0 | CLBC4 | T4CL | T4CLK1 | T4CLK0 | | ιE | Read/Write | R/W | ¦ R/W | . R/ | W | R/W | . R/W | ! R/ | W | | ľ | After reset | 0 | ١ 0 | ı ( | ) | · 0 | ١ 0 | ۱ ( | ) | | | | timer/<br>counter<br>match<br>clear<br>enable | counter<br>clear<br>0: —<br>1: Clear<br>(One-shot) | TC5 source<br>selection<br>00: TI5<br>01: CSYNG<br>(from V<br>10: TBC4<br>11: TBC6 | CA<br>⁄-sepa) | timer/<br>counter<br>match<br>clear<br>enable | counter<br>clear<br>0: —<br>1: Clear<br>(One-shot) | TC4 source<br>selection<br>00: TI4<br>01: CFGTI<br>(from C<br>10: TBC4<br>11: TBC6 | M | Timer Register 5L TREG5L (0034H) | | | 7 | 6 | 5 | 4 | 3 | 2 | <u>!</u> 1 | 0 | |----|-------------|---------|---------|------------|-------------|---------|------------|------------|---------| | 5L | bit Symbol | TC/TR57 | TC/TR56 | TC/TR55 | TC/TR54 | TC/TR53 | TC/TR52 | TC/TR51 | TC/TR50 | | 'n | Read/Write | | | | R/ | W | | | | | " | After reset | 0 | 0 | 0 | . 0 | 0 | 0 | . 0 | . 0 | | | Function | | W: Wr | iting TREG | 5L register | R: Read | ing TC5L c | ounter | | Timer Register 5H TREG5H (0035H) | L | | 7 | 6 | 5 | <u>.</u> 4 | <u>.</u> 3 | . 2 | ! 1 | . 0 | | | |---|-------------|---------|----------------------------------------------------|---------|------------|------------|---------|---------|---------|--|--| | ľ | bit Symbol | TC/TR5F | TC/TR5E | TC/TR5D | TC/TR5C | TC/TR5B | TC/TR5A | TC/TR59 | TC/TR58 | | | | | Read/Write | | R/W | | | | | | | | | | Г | After reset | 0 | 0 | 0 | , 0 | , 0 | 0 | ; 0 | 0 | | | | Γ | Function | | W: Writing TREG5H register R: Reading TC5L counter | | | | | | | | | Note: Setting and reading in order of TREG5L→TREG5H are necessary. Figure 3.7.12 Registers for TC5 #### (7) Operation explanation The follows explains a setting method with using an example of the TC1. <Generating interrupts at a constant cycle.> First of all, TC1 is stopped. The input clock and the cycle are set to TCCR10 and TREG1L/ TREG1H respectively. Next, the TC1 interrupt(INTT1) is enabled. The TC1 is counted at the end. Example: When the TC1 interrupt of each 64 ms is generated with fc = 20 MHz, Set each register in the following order. | | MSB | LSB | |---------|----------|-------------------------------------------------------| | TRUN | 1- | The count of the TC1 is stopped. | | TCCR10 | 1 * 1 1 | The source clock is set to TBC6 (6.4 us). | | TREG1L | 00010000 | 64 ms ÷ 6.4 us = 2710 H is set to the timer register. | | TREG1H | 00100111 | | | INTT1T2 | 0 n n n | INTT1 interrupt is enabled with Level "nnn" | | TRUN | 1- | The count of the TC1 is started. | (Note)\*: don't care -: no change Table3.7.2 Interrupt Interval for the TC1 to TC5 | Interrupt Interval (at fc = 20 MHz) | Resolution | Input Clock | | | |-------------------------------------|------------|---------------------------|--|--| | 0.4 us to 26.214 ms | 0.4 us | TBC2 (2 <sup>3</sup> /fc) | | | | 1.6 us to 104.856 ms | 1.6 us | TBC4 (2 <sup>5</sup> /fc) | | | | 6.4 us to 419.424 ms | 6.4 us | TBC6 (2 <sup>7</sup> /fc) | | | <sup>·</sup> The TI1 to TI5, CSYNCA, CFGTM are counted up with the rising edge of each input. <sup>•</sup> The maximum input frequency is $fc/2^4$ [Hz] (1.25 MHz at fc = 20 MHz). The minimum input pulse width is $2^3/fc$ [s] (400 ns at fc = 20 MHz) at both H levels and L levels. #### 3.8 CAPTURE CIRCUIT The capture circuit latches the time data of the time base counter (TBC) and the captures input status (Trigger input signal). The data of TBC can be latched by the trigger input signal and the interrupt request is generated to CPU. By using the capture circuit, the time can be measured in high resolution for servo control. The capture circuit consists of the capture 0 (CAP0) with eight (8) level of 24-bit FIFO (first-in first-out) as buffer, the capture 1 (CAP1) and the capture 2 (CAP2) with single level of 17-bit FIFO as buffers. ## 3.8.1 Capture Input Control Circuit (CAPIN) Capture input control circuit (CAPIN) controls the trigger input signals of the three channels of capture circuits (CAP0, CAP1 and CAP2), and comprises the capture 0 input control circuit, capture 1 input control circuit and capture 2 input control circuit. (a) Capture 0 (CAP0) input control circuit Figure 3.8.1 Capture input control circuit #### (1) Capture 0 (CAP0) Input Control ## ① Remote control signal rising edge (RMTU) This is the rising edge signal of the remote control signal detected by the remote control signal input circuit (RMTIN). Enabling this trigger input to capture 0 (CAP0) is controlled by Capture input control register 0 CAPINCR0<CAP00E>. ## ② Remote control signal falling edge (RMTD) This is the falling edge signal of the remote control signal detected by the remote control signal input circuit (RMTIN). Enabling this trigger input to capture 0 (CAP0) is controlled by Capture input control register 0 CAPINCR0<CAP01E>. ## ③ Sync. separation input (VSYNC) This is the vertical Synchronizing signal (VSYNC) separated from Composite Sync signal by Sync signal sparator (CSYNC). Enabling this trigger input to capture 0 (CAP0) controlled by CAPINCR0 <CAP02E>. ## Control signal input (CTLIN) This is the input pin for the control pulse signal (CTL) which formed into a square wave with the external CTL amplifier circuit. The polarity of the external input (CTLIN) can be selected by the capture input control register 3 (CAPINCR3) <CTLPO>. The capturing timing can be selected from either rising edge of control signal or both rising and falling edges by the capture input control register 3 (CAPINCR3) <CTLEG>. The detected edge signal can be divided by a 6-bit programmable frequency divider. The frequency division ratio can be set by the capture input control register 1 (CAPINCR1) <PCPR5-0>. The frequency division ratios can be set from <PCPR5-0> = 00H (1/1 frequency division) to <PCPR5-0> = 3FH (1/64 frequency division). Selection of whether edge signal is divided or bypassed is carried out by the VISS/VASS control register 2 (VIVACR2) <MSK1>. Enabling the trigger input to capture 0 (CAP0) is controlled by CAPINCR0 <CAP03E>. ## ⑤ EXT Input (EXT) This is the input pin for the rising edge signal from EXT terminal. Enabling the trigger input to capture 0 (CAP0) is controlled by CAPINCR0 <CAP04E>. ## ® Drum PG input (DPGIN) The external Drum PG signal is inputted to this pin. Detection of the rising edge or falling edge of the Drum PG signal is carried out by CAPINCR3 < DPGEG>. Enabling the trigger input to capture 0 (CAP0) is controlled by CAPINCR0 <CAP05E>. #### (2) Capture 1 (CAP 1) Input Control The trigger of capture 1 (CAP1) is the external Drum FG signal (DFGIN). Detection of the rising edge or falling edge of the DFG signal from terminal P81 (DFGIN) is carried out by CAPINCR3 <DFGEG>. The detected edge signal can be divided by a 3-bit programmable frequency divider. The frequency division ratio can be set by <DPCP2-0> of capture input control register 2 (CAPINCR2). The frequency division ratios can be set from <DPCP2-0> = 0H (1/1 frequency division) to <DPCP2-0> = 7H (1/8 frequency division). Enabling the trigger input to capture 1 (CAP1) is controlled by <CAP1E> of capture input control register 0 (CAPINCR0). TOSHIBA #### (3) Capture 2 (CAP2) Input Control The trigger of capture 2 (CAP2) is the external capstan FG signal (CFGIN). The polarity of the external input (CFGIN) can be selected by CAPINCR3 < CFGPO>. The input signal can be divided 1/1 or 1/2 by using < CFGWPR> of capture input control register 3 (CAPINCR3). Either the rising edge or both the rising and falling edges of the CFGIN signal can be selected by CAPINCR3</br> CFGEG>. The detected signal can be divided by a 6-bit programmable frequency divider. The frequency division ratio can be set by <PCPR5-0> of CAPINCR1 in common with the capturing for CTL. The divided CFGIN signal can be masked during an interval of TBC4 (2<sup>10</sup>/fc) x 8 [s] by a 4-bit mask counter. CFGIN signal during the mask interval are not inputted to CAP2, but CFG flag (CAPINCR2 < CFGMCP>) is set to 1. The CFG flag can be reset to "0" by <CFGCL> of capture control register (CAPCR). The selection between subjecting the CFGIN signal to mask processing or by passing it can be selected by <MSK0> of VISS/VASS control register 2 (VIVACR2). Enabling the trigger input to capture 2 (CAP2) is controlled by <CAP2E> of capture input control register 0 (CAPINCR0). The CFGTM signal is the pulse signal which output at the rising edge and falling edge of the CAPIN signal. The CFGTM is counted up by the 16-bit timer counter 4 (TC4). Figure 3.5.2 shows the timing chart for capture 2 input control. Figure 3.8.2 Capture 2 Input Control Timing Chart (VIVACR2<MSK0> = 0) # (4) Capture Input Control Register Capture Input Control Register 0 CAPINCR0 (0046H) | Ы | | 7 | 6 | ; 5 | <u>.</u> 4 | 3 | 2 | <u> </u> | ; 0 | | | |---|-------------|-------|----------------------------------------------------|---------|------------|--------|--------|----------|--------|--|--| | ı | bit Symbol | CAP2E | CAP1E | CAP05E | CAP04E | CAP03E | CAP02E | CAP01E | CAP00E | | | | ı | · | (CFG) | (DFG) | L (DPG) | (EXT) | (CTL) | ¦ (VS) | (RMTD) | (RMTU) | | | | | Read/Write | | R/W | | | | | | | | | | I | After reset | 0 | 0 | i 0 | 0 | 0 | 0 | i 0 | 0 | | | | I | Function | | Capture 0, 1/2 input source enable/disable control | | | | | | | | | | ١ | | | 0: Disable 1: Enable | | | | | | | | | Capture Input Control Register 1 CAPINCR1 (0047H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------|------------|------------|------------|-------|-------| | 1 [ | bit Symbol | PCTLCK1 | PCTLCK0 | PCPR5 | PCPR4 | PCPR3 | PCPR2 | PCPR1 | PCPR0 | | | Read/Write | | i | R/W | | | | | | | | After reset | 0 i 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | Function | CTL duty meas | 6-bit programmable divider control | | | | | | | | | | (VIVACR2 <pc< td=""><td>Dividing ra<br/>(from P85</td><td></td><td>on for CTL</td><td>IN (from P</td><td>80) and Cl</td><td>FGIN</td></pc<> | Dividing ra<br>(from P85 | | on for CTL | IN (from P | 80) and Cl | FGIN | | | | | | = | 000000: 1<br>000001: 1 | | 11:1/64 | | | | Capture Input Control Register 2 CAPINCR2 (0048H) | | Sapture input control register 2 | | | | | | | | | | |-----|----------------------------------|---|--------------------------|-------------|--------------------|-------------|-------------------|---------------|---------|--| | ا 2 | | 7 | 6 | ¦ 5 | ¦ 4 | 3 | 2 | 1 | 0 | | | ٦ | bit Symbol | | RMTST | RMTP0 | RMTBP | CFGMCP | DPCP2 | DPCP1 | DPCP0 | | | | Read/Write | | ! R/W | ! R/W | ! R/W | ! R | ! | R/W | | | | | After reset | | 0 | 0 | i 0 | . 0 | i 0 | i 0 | 0 | | | | Function | | RMTIN | RMTIN | Noise | CFG | 3-bit progr | ammable d | livider | | | | | | start/stop | input | canceller/ | status flag | ag icontrol | | | | | | | | control | polarity | correction | !<br>! | Dividing ra | ite selectioi | n for | | | | | | l<br>I | selection | circuit | !<br>! | DEGIN | | | | | | | | 1<br>! | I<br>I | control | !<br>! | (from P81) | ) | | | | - | | | 0: Stop & | 0: Positive | ; | !<br>! | ! | | | | | - | | | counter (+) 0: Active 0: | | 0: Normal | 1000: 1/1 | | | | | | | clear | | clear | 1: Negative | 1: Bypass 1: Error | | 001: 1/2 111: 1/8 | | | | | - | | | 1: Start | ¦ (-) | : | <br> | !<br>! | | | | Capture Input Control Register 3 CAPINCR3 (0049H) | | Capture input Control Register 5 | | | | | | | | | | |-------------|----------------------------------|-------------|-------------|------------|------------|-----------|----------------|----------------|--|--| | | 7 | 6 | 5 | i 4 | i 3 | i 2 | i 1 | 0 | | | | bit Symbol | | CTLPO | CFGPO | DPGEG | DFGEG | CFGWPR | CFGEG | CTLEG | | | | Read/Write | | R/W | l R/W | ¦ R/W | ¦ R/W | ¦ R/W | R/W | ¦ R/W | | | | After reset | | . 0 | . 0 | . 0 | . 0 | . 0 | . 0 | ! 0 | | | | Function | | CTL input | CFG input | Edge | Edge | Dividing | Edge | Edge | | | | | | polarity | polarity | selection | selection | rate | selection | selection | | | | | | selection | selection | for DPG | for DFG | selection | for CFG | for CTLIN | | | | | | i<br>i | i<br>i | input | input | for CFG | input | input | | | | | | 0: Positive | 0: Positive | | į | input | į | | | | | | | (+) | (+) | | į | i | 0: Both rising | 0: Rising | | | | | | 1: Negative | 1: Negative | 0: Rising | 0: Rising | 0: 1/1 | and falling | 1: Both rising | | | | | | (-) | (-) | 1: Falling | 1: Falling | 1: 1/2 | 1: Rising | and falling | | | VISS/VASS Control Register 2 VIVACR2 (0055H) | | | VISS/VAS | S Control | Register. | <u>Z</u> | |-------------|----------------------|----------------------------|-------------|-------------|---------------------------------------| | | 7 | ; 6 | 5 | i 4 | 3 2 1 1 0 | | bit Symbol | PCTLPO | PCTLCKS | MSK1 | ¦ MSK0 | VISS3 VISS2 VISS1 VISS0 | | Read/Write | R/W | ¦ R/W | R/W | ¦ R/W | R/W | | After reset | 0 | . 0 | . 0 | . 0 | . 0 . 0 . 0 . 0 | | Function | CTL signal | CTL duty | Dividing | masking | VISS compare data | | | polarity | measuring clock | control for | control for | I<br>I | | | selection | selection | CTLIN | CFG input | These 4-bit data are compared with | | | | ! | input | 0: Mask | higher 4 bit of the 6-bit CTL counter | | | 0: Positive | 0: Selected | į | 1: Bypass | I<br>I | | | (+)(when duty | by CAPINCR1 | 0: Divide | | ! | | | is less than | <pctlck1, 2=""></pctlck1,> | 1: Bypass | į | I | | | 50%, | <u>.</u> | | į | I | | | VIVACR1 | 1: Automatic | i | į | I | | | <ctldty> is</ctldty> | selection | į | į | 1<br>1 | | | set to 1) | <u>.</u> | i | į | I | | | | <u>:</u> | į | | | | | 1: Negative | : | | | | | | (-)(when duty | | !<br>! | ! | | | | is less than | !<br>! | !<br>! | 1 | !<br>! | | | 50%, | !<br>! | !<br>! | 1 | !<br>! | | | VIVACR1 | !<br>! | 1 | !<br>! | 1<br>1 | | | <ctldty> is</ctldty> | !<br>! | !<br>! | !<br>! | I<br>I | | | set to 0) | !<br>! | 1<br>1 | 1 | !<br>! | | | <b>'</b> | 1<br>1 | 1 | 1 | I<br>I | CAPCR (0052H) | | | | Ca | pture Contro | ol Register | | | | | | | |-------------|------------|-------------|--------------|---------------------------|-------------|------------|------------|-----------|--|--|--| | | 7 | 6 | i 5 | i 4 | ; 3 | 2 | 1 | 0 | | | | | bit Symbol | CAP2T | CAP1T | CAPCL | VISFRS | VASFRS | TPRS0 | CFGCL | CAFRS | | | | | | (CFG) | (DFG) | 1 | 1 | ! | ! | | | | | | | Read/Write | R | i R | i | R/W (Always 0 at reading) | | | | | | | | | After reset | 0 | ¦ 0 | ¦ o | ¦ 0 | ¦ 0 | 0 | ¦ o | ¦ 0 | | | | | Function | CAP2 | CAP1 | ¦CAP1/ | VISS detect | VASS detect | TPG0 FIFO | CFG flag | Capture0 | | | | | | trigger | trigger | CAP2 | flag clear | flag clear | counter | clear | ¦FIFO | | | | | | input | input | status clear | 1 | 1 | clear & | ]<br>] | counter/ | | | | | | status | status | 1<br>1 | 1 | 1 | INTTPG0 | ]<br> | status | | | | | | | !<br>! | ¦0: — | ¦0: — | ¦0: — | disable | ¦0: — | clear | | | | | | 0: | ¦0: | ¦1: Clear | 1: Clear | 1: Clear | ¦0: — | 1: Clear | ! | | | | | | No | ¦ No | (One-shot) | (One-shot) | (One-shot) | 1: Clear & | (One-shot) | ¦0: — | | | | | | trigger | trigger | l<br>I | 1 | 1 | Inhibit | !<br>! | ¦1: Clear | | | | | | input | input | !<br>! | 1 | 1 | (One-shot) | 1<br>1 | ¦(One- | | | | | | 1: Trigger | ¦1: Trigger | l<br>I | 1 | | <br> | <br> | ¦shot) | | | | | | input | input | l<br>I | 1 | 1 | <br> | l<br>1 | <br> | | | | Figure 3.8.3 Registers for CAPIN #### 3.8.2 Capture 0 (CAP0) Figure 3.8.4 Structure of Capture 0 # (1) Description of Operation # ① Capture The trigger signals for capture 0 are the six signals that are outputted from the capture 0 input control circuit: RMTU, RMTD, VS, CTL, EXT and DPG signals. The CAP0 latches 18 bits of timing data (Output from Time Base Counter: TBC3 to TBC20) and 6 bits of trigger data in 3 bytes of Capture Data Register (Memory address 004BH to 004DH). It latches a total of 24 bits data. The 24 bits of latched data can be obtained by reading the data from memory addresses 004BH, 004CH and 004DH in this order. Note1: By reading data from memory address 004DH, the address of the FIFO buffer is shifted, so please ensure that this data is read last. Note2: CAPOM and CAPOH need to read in the continuous read cycle. Therefore, CAPOM and CAPOH need to be read by word operation, or CAPFST, CAPOL, CAPOM and CAPOH need to be read by long-word operation. ex1) LDB reg. (CAP0L) LDW reg. (CAP0M); CAP0M/CAP0H word read operation ex2) LDL reg. (CAPFST); CAPFST/CAP0L/CAP0M/CAP0H long-word read operation # 2 FIFO Status Register The 24-bit 8-stage buffer features a FIFO (First In First Out) function, allowing the data latched first to be read first. The FIFO status register (CAPFST) indicates the shift status of FIFO, and the status bits that correspond to the stage being latched are set to 1. When the 8-stage FIFO buffer become full, capture operations are disabled and the FIFO status register shows FFH. When the FIFO status register shows 00H, in other words the 8-stage FIFO buffer is empty, the reading data of the capture data register is FFH. The capture data can be read out when INTCAP0 interruption has been generated after data has been latched by a trigger signal, or when the FIFO status register is not 00H. ### 3 Capture Reset In addition to a system reset function (initialization by resetting), capture 0 also has a software reset function. Software reset is performed by writing 1 at <CAFRS> of the capture control register (CAPCR). In performing a software reset, the following circuits are initialized. - a. The FIFO address counter is addressed to the first stage of the 8-stage FIFO buffer. - b. The FIFO status register (CAPFST) is initialized to 00H. # **4 INTCAP0 Interruption** When latch operations are carried out by a trigger input signal, an INTCAP0 interruption request is generated. The INTCAP0 interruption request signal is maintained in an active state until the FIFO status register reaches 00H (empty). Once INTCAP0 interruption is received, capture data in CAP0L, CAP0M and CAP0H <CAP0D16 to 17> and trigger input data in CAP0H<CAP0T0 to 5> can be read-out and verified the time data and interrupt sources. INTCAP0 interruption requests are canceled by reading out the FIFO buffer until the content of the FIFO status register reaches 00H or writing 1 to <CAFRS> of CAPCR. # S Data Processing The upper 6 bits of the 24 bits of data latched by the FIFO buffer are the status data for the trigger signal. The data of the bit that corresponds to the trigger input signal is set to 1, so by reading out this data the input signal can be identified. Store the latched data in RAM, and by subtracting the data previously stored in the RAM from the data latched by the next trigger signal, highly precise time measurement can be carried out. Detection precision is 400ns when operating at 20 MHz, and quantum error is extremely small. # (2) Control Register Capture 0 FIFO Status Register CAPFST (004AH) | | 7 | 6 | 5 | i 4 | 3 | 2 | i 1 | i 0 | | | |-------------|---------|-------------------------------------------------------|---------|---------|---------|---------|---------|---------|--|--| | bit Symbol | CAPF7 | CAPF6 | CAPF5 | CAPF4 | CAPF3 | CAPF2 | CAPF1 | CAPF0 | | | | | (FIFO8) | (FIFO7) | (FIFO6) | (FIFO5) | (FIFO4) | (FIFO3) | (FIFO2) | (FIFO1) | | | | Read/Write | | | | Read | l-only | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Function | | Capture0 FIFO status 0: Empty, 1: Capture data stored | | | | | | | | | Capture 0 data register-low order CAP0L (004BH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---------|--------|--------|--------|--------|--------|--------|--------| | bit Symbol | CAP0D7 | CAPOD6 | CAP0D5 | CAP0D4 | CAP0D3 | CAP0D2 | CAP0D1 | CAP0D0 | | | (TBC10) | (TBC9) | (TBC8) | (TBC7) | (TBC6) | (TBC5) | (TBC4) | (TBC3) | | Read/Write | | | | Read | l-only | | | | | After reset | * | * | * | * | * | * | * | * | \* : unknown after reset Capture 0 data register-middle order CAP0M (004CH) | | 7 | 6 | 5 | 4 | ¦ 3 | 2 | 1 | 0 | |-------------|---------|---------|---------|---------|-----------|-----------|---------|---------| | bit Symbol | CAP0D15 | CAP0D14 | CAP0D13 | CAPOD12 | CAP0D11 | CAPOD10 | CAP0D9 | CAP0D8 | | | (TBC18) | (TBC17) | (TBC16) | (TBC15) | i (TBC14) | i (TBC13) | (TBC12) | (TBC11) | | Read/Write | | | | Read | d-only | | | | | After reset | * | * | * | * | * | * | * | * | \*: unknown after reset Capture 0 data register-high order CAP0H (004DH) | | 7 | i 6 | i 5 | i 4 | i 3 | i 2 | i 1 | 0 | |-------------|--------------------------------------|---------|------------|--------|--------|--------|-----------|---------| | bit Symbol | CAP0T5 | CAP0T4 | CAP0T3 | CAP0T2 | CAP0T1 | CAPOTO | CAP0D17 | CAP0D16 | | | (DPG) | · (EXT) | (CTL) | i (VS) | RMTD) | RMTU) | i (TBC20) | (TBC19) | | Read/Write | | | Read-only | | | | | | | After reset | * | * | | | | | | : | | Function | | | Capture0 I | higher | | | | | | | 0: No trigger input 1: Trigger input | | | | | | | | <sup>\*:</sup> unknown after reset Capture Control Register CAPCR (0052H) | | | | | piaro contr | <del></del> | | | | |-------------|----------------|----------------|--------------|-------------|-------------|---------------|------------|------------| | | 7 | i 6 | ; 5 | i 4 | ; 3 | 2 | i 1 | 0 | | bit Symbol | CAP2T<br>(CFG) | CAP1T<br>(DFG) | CAPCL | VISFRS | VASFRS | TPRS0 | CFGCL | CAFRS | | Read/Write | R | R | i | | R/W (Always | 0 at reading) | | | | After reset | 0 | 0 | 0 | 0 | . 0 | 0 | , 0 | , 0 | | Function | CAP2 | CAP1 | CAP1/ | VISS detect | VASS detect | TPG0 FIFO | CFG flag | ¦Capture0 | | | trigger | trigger | CAP2 | flag clear | flag clear | counter | clear | ¦FIFO | | | input | input | status clear | 1<br>1 | 1 | clear & | ]<br> | counter/ | | | status | status | 1<br>1 | 1<br>1 | ¦0: — | INTTPG0 | 1<br>1 | status | | | | !<br>! | ¦0: — | ¦0: — | 1: Clear | disable | ¦0: — | clear | | | 0: No | ¦0: No | 1: Clear | 1: Clear | (One-shot) | ¦0: — | ¦1: Clear | !<br>! | | | trigger | trigger | (One-shot) | (One-shot) | 1 | 1:Clear & | (One-shot) | ¦0: — | | | input | ¦ input | <br> | <br> | 1 | Inhibit | I<br>I | ¦1: Clear | | | 1: Trigger | ¦1: Trigger | 1<br>1 | 1<br>1 | 1 | (One-shot) | 1<br>1 | (One-shot) | | | input | input | !<br>! | l<br>I | 1 | 1<br>1 | !<br>! | !<br>! | Figure 3.8.5 Registers for Capture 0 #### 3.8.3 Capture 1/Capture 2 (CAP1/CAP2) Figure 3.8.6 Structure of Capture 1/Capture 2 #### (1) Operation ### ① Capture The trigger input signals are DFG and CFG signals for capture 1 and capture 2 respectively. The output values of time base counters (TBC1-TBC16) are latched onto the 2 bytes of capture data register (capture 1 has memory addresses 004EH and 004FH, while capture 2 has memory addresses 0050H and 0051H) using the edge of the trigger input signal. The trigger input signal is latched onto <CAP1T> and <CAP2T> of the capture control register (CAPCR). When the CAPCR<CAP1T> is 1, the Capture 1 data can be obtained by reading out the data from the low order of the capture 1 data register (CAP1L) and from the high order capture 1 data register (CAP1H) in this order. By reading out CAP1H, the trigger input status <CAP1T> is cleared. When <CAP1T> is 0 the read-out of CAP1L and CAP1H is FFH. When the CAPCR<CAP2T> is 1, the Capture 2 data can be obtained by reading out the data from the low order of the capture 2 data register (CAP2L) and from the high order capture 2 data register (CAP2H) in this order. By reading out CAP2H, the trigger input status <CAP2T> is cleared. When <CAP2T> is 0 the read-out of CAP2L and CAP2H is FFH. # 2 Capture Reset In capture 1 and 2, trigger input signal <CAP1T> and <CAP2T> can be cleared by writing 1 to <CAPCL> of CAPCR. # **③ INTCAP1 Interruption** When latch operations are carried out by the edge of a DFG signal or CFG signal, an INTCAP1 interruption request is generated. INTCAP1 interruption is common to both capture 1 and capture 2, so please read out <CAP1T> and <CAP2T>, and discriminate between them before carrying out processing. INTCAP1 interruption requests are released by reading out either CAP1H or CAP2H and clearing <CAP1T> <CAP2T> to 0, or by writing <CAPCL> of CAPCR to 1. # (2) Control Register Capture 1 data register-low order CAP1L (004EH) | | 7 | . 6 | 5 | ı 4 | ١ 3 | . 2 | · 1 | ٠ 0 | |-------------|--------|--------|--------|----------|----------|----------|----------|----------| | bit Symbol | CAP1D7 | CAP1D6 | CAP1D5 | CAP1D4 | CAP1D3 | CAP1D2 | CAP1D1 | CAP1D0 | | | (TBC8) | (TBC7) | (TBC6) | ! (TBC5) | ! (TBC4) | ! (TBC3) | ! (TBC2) | ! (TBC1) | | Read/Write | | | | Read | d-only | | | | | After reset | * | * | * | * | * | * | * | * | \*: unknown after reset Capture 1 data register-high order CAP1H (004FH) | | 7 | 6 | 5 | 4 | 3 | 2 | ¦ 1 | 0 | |-------------|---------|---------|---------|---------|---------|---------|---------|--------| | bit Symbol | CAP1D15 | CAP1D14 | CAP1D13 | CAP1D12 | CAP1D11 | CAP1D10 | CAP1D9 | CAP1D8 | | , | (TBC16) | (TBC15) | (TBC14) | (TBC13) | (TBC12) | (TBC11) | (TBC10) | (TBC9) | | Read/Write | | | | Read | l-only | | | | | After reset | * | * | * | * | * | * | * | * | \*: unknown after reset Capture Control Register CAPCR (0052H) | | | | | 0 0011111011 | | | | | |-------------|---------------|---------------|---------------|--------------|-------------|---------------|------------|---------------| | | 7 | 6 | i 5 | 4 | ; 3 | 2 | 1 | . 0 | | bit Symbol | CAP2T | CAP1T | CAPCL | VISFRS | VASFRS | TPRS0 | CFGCL | CAFRS | | | (CFG) | (DFG) | ! | | ! | <u>!</u> | ! | ! | | Read/Write | R | R | i | | R/W (Always | 0 at reading) | | | | After reset | 0 | 0 | ¦ 0 | 0 | 0 | 0 | 0 | . 0 | | Function | CAP2 | CAP1 | CAP1/CAP2 | VISS detect | VASS detect | TPG0 FIFO | CFG flag | Capture0 | | | trigger input | trigger input | ¦status clear | ¦flag clear | flag clear | counter | clear | ¦FIFO | | | status | status | 1<br>1 | !<br>! | 1 | clear & | (<br>( | counter/ | | | | <br> | ¦0: — | : | ¦0: — | INTTPG0 | (<br> | status | | | 0: No | ¦0: No | ¦1: Clear | ¦0: — | ¦1: Clear | disable | ¦0: — | clear | | | trigger | trigger | (One-shot) | 1: Clear | (One-shot) | ¦0: — | 1: Clear | 1 | | | input | input | !<br>! | (One-shot) | 1 | 1: Clear & | (One-shot) | <b>'</b> 0: — | | | 1: Trigger | 1: Trigger | 1<br>1 | !<br>! | 1 | Inhibit | 1 | 1: Clear | | | input | input | !<br>! | !<br>! | I<br>I | (One-shot) | 1<br>1 | (One-shot) | Figure 3.8.7 Registers for Capture 1 | | | | | Capture 2 | data regist | er-low order | | | | |------------------|-------------|---------------|--------------|--------------|-----------------|------------------------------------------------|-----------------|------------------------------------------------|------------------------------------------------| | CAP2L | | 7 i | 6 i | 5 i 4 | i 3 | i 2 i | 1 i ( | ) | | | (0050H) | bit Symbol | | | | | 3 CAP2D2 C | | | | | (000011) | | (TBC8) ! | (TBC7) ! ( | TBC6) ! (TB( | C5) ! (TBC4) | · ! (TBC3) ! ( | TBC2) ! (TB | C1) | | | | Read/Write | | | | Read-only | | | | | | | After reset | * | * | * * | * | * ; | * * | <b>*</b> | | | | *: unknov | vn after res | set | | | | | | | | | | | | Capture 2 | data registe | er-high order | • | | | | 0.4.001.1 | | 7 ! | 6 ! | 5 ! 4 | ; 3 | ! 2 ! | 1 ! ( | | | | CAP2H<br>(0051H) | bit Symbol | | | | | 1iCAP2D10i C | | | | | (00510) | | (TBC16) ¦ | (TBC15) ¦ (T | BC14) ¦ (TBC | :13) ¦ (TBC12 | ) | ГВС10)¦ (ТВ | C9) | | | | Read/Write | | | | Read-only | | | | | | | After reset | * i | * i | * i * | i * | i * i | * i * | k | | | | *: unknov | vn after res | set | | | | | | | | | | | | Captu | re Control F | Register | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | , 0 | | CAPCR | bit Symbol | CAP2T | CAP1T | CAPCL | VISFRS | VASFRS | PRS0 | CFGCL | : CAFRS | | (0052H) | | (CFG) | (DFG) | | | <u>i </u> | <u>i</u> | <u>i </u> | <u>i </u> | | , | Read/Write | R | ¦ R | <u> </u> | | | 0 at reading) | | | | | After reset | 0 | : 0 | ; 0 | 0 | 0 | 0 | 1 0 | . 0 | | | Function | CAP2 | CAP1 | CAP1/CAP2 | VISS detect | VASS detect | TPG0 FIFO | CFG flag | Capture0 | | | | trigger input | trigger inpu | status clear | flag clear | flag clear | counter | clear | FIFO | | | | status | status | | į | į | clear & | į | counter/ | | | | | !<br>! | 0:— | : | 0: — | INTTPG0 | 1 | status | | | | 0: No | 0: No | 1: Clear | 0: — | 1: Clear | disable | 0:— | clear | | | | trigger | trigger | '(One-shot) | י<br>י1: Clear | (One-shot) | 0: — | 1: Clear | | | | | input | input | 1' ' | ı<br>(One-shot) | 1. , | י<br>1: Clear & | '(One-shot) | 0:— | | | | | 1: Trigger | 1 | 1` ' | 1 | ı<br>Inhibit | 1. | ו<br>יו: Clear | | | | input | input | 1 | : | I<br>I | '(One-shot) | 1 | '(One-shot) | Figure 3.8.8 Registers for Capture 2 ### 3.9 Remote control signal input circuit (RMTIN) The remote control signal input circuit (RMTIN) is a circuit which detects the rising and falling edge of the remote control signal element by removing the noise element which the received remote control signal includes. The detected rising signal (RMTU) and falling signal (RMTD) are input to the capture 0(CAP0) through the capture input circuit (CAPIN). The information on the remote control signal can be obtained by measuring those pulse widths with capture 0. ### (1) Block diagram The remote control signal input circuit consists of the H level noise canceller and the L level noise canceller, and each noise canceller is composed by 4-bit up-counter, the comparison/the match detection circuits. Figure 3.9.1 Composition of the remote control signal input circuit (RMTIN) #### (2) Control register Remote Control Signal Input Control Register RMTCR (0053H) | | 7 | i 6 | 5 | i 4 | i 3 i | 2 | i 1 | i o | |------------|------------|--------------|--------------|-------------|----------------------------------------------|-------|-------|---------| | bit Symbol | RMTD7 | RMTD6 | RMTD5 | RMTD4 | RMTD3 | RMTD2 | RMTD1 | ¦ RMTD0 | | Read/Write | | | R/W | | 1 | F | R/W | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | i 0 | | | H level no | ise cancelle | r width (TBC | 8: 25.6 µs) | L level noise canceller width(TBC8: 25.6 µs) | | | | | | Setting of | comparative | value of 4-b | it counter | Setting of comparative value of 4-bit counte | | | | Capture Input Control Register 2 | CAPINCR2<br>(0048H) | ŀ | |---------------------|---| | (0048H) | ŀ | | _[ | | 7 | 6 | i 5 | i 4 | 3 | 2 | 1 | 0 | |----|-------------|---|----------------|-------------|------------|-------------|------------|-------------|---------| | 2[ | bit Symbol | | RMTST | RMTP0 | RMTBP | CFGMCP | DPCP2 | DPCP1 | DPCP0 | | | Read/Write | | . R/W | ¦ R/W | ! R/W | . R | ! | R/W | | | [ | After reset | | 0 | i 0 | 0 | 0 | 0 | i | | | | Function | | RMTIN | RMTIN | Noise | CFG | 3-bit prog | rammable | divider | | ١ | | | start/stop | input | canceller/ | status flag | control | | | | ١ | | | control | polarity | correction | ! | Dividing r | ate selecti | on for | | - | | | !<br>! | selection | circuit | ! | DFGIN | | | | - | | | l<br>I | I<br>I | control | i | from P81 | ) | | | ١ | | | 0: Stop & | 0: Positive | !<br>! | ! | 1<br>! | | | | - | | | counter | (+) | 0: Active | 0: Normal | 000: 1/1 | | | | ١ | | | clear | 1: Negative | 1: Bypass | 1: Error | 001: 1/2 - | - 111: 1/8 | | | - | | | ı<br>ı1: Start | (-) | 1 | 1 | !<br>! | | | Figure 3.9.2 Register for RMTIN #### (3) Operation of the remote control signal input circuit The remote control signal input circuit begins operating by setting < RMTST > of the capture input control register 2 (CAPINCR2) to 1. Setting the noise removal width (RMTCR<RMTD7-RMTD0>) and the input polarity (CAPINCR2<RMTPO>) before beginning of the operation is necessary. #### ① Control of remote control signal input The polarity of the remote control signal input from the RMTIN (P82) pin can be switched by < RMTPO > of the capture input control register 2 (CAPINCR2). The remote control signal is input to the noise canceller circuit after being sampled by the falling edge of TBC4 of the time base counter (TBC) output (1.6 us at fc = 20 MHz). The operation when assuming <RMTPO>= 0 (positive polarity) is explained at the following. #### ② Operation of the noise canceller The noise canceller removes the pulse of less than width set with RMTCR<RMTD7-RMTD4> and <RMTD3-RMTD0> as the noise. As for the L level noise canceller, the 4-bit counter is counted up by TBC8 of the TBC output (It is 25.6 us at 20 MHz) while the remote control signal is on the L level. Moreover, the 4-bit counter is cleared for the period at the H level. When the count value matches to the value of RMTCR<RMTD0>, the L level noise canceller regards this state as the falling edge of the remote control signal and resets the flip-flop. As for the H level noise canceller, the 4-bit counter is counted up by TBC8 of the TBC output (It is 25.6 us at 20 MHz) while the remote control signal is on the H level. Moreover, the 4-bit counter is cleared for the period at the L level. When the count value matches to the value of RMTCR<RMTD7-RMTD4>, the H level noise canceller regards this state as the rising edge of the remote control signal and sets the flip-flop. # Measurement of the pulse width for the remote control signal The flip-flop output obtained from the L level noise canceller and the H level noise canceller is a signal which the noise is removed from the input remote control signal. As for this flip-flop output, the rising edge is assumed to be RMTU signal, the falling edge is assumed to be RMTD signal, and the RMTU and RMTD signals are input to the capture 0 (CAP0) through the capture input control circuit (CAPIN). The pulse width of the remote control signal can be calculated by the operation of the RMTU time data and the RMTD time data. When the RMTCR<RMTD7-RMTD4> or <RMTD3-RMTD0> is set to 0H, the noise removal operation is not done. Moreover, the noise canceller can be bypassed by setting CAPINCR2<RMTBP > to 1. Figure 3.9.3 Timing chart of the remote control signal input circuit #### 3.10 TIMING PULSE GENERATOR (TPG) In order to generate the various timing pulses necessary for VTR system control, the TMP93C071 has a timing pulse generator (TPG0) with 22-bit 8-stage FIFO buffer and a 20-bit timing pulse generator (TPG1). The TPG0 and TPG1 can output the timing pulse synchronized with the time base counter (TBC). Their resolution for both TPG0 and TPG1 is 400 ns (when operating at 20 MHz). # 3.10.1 Timing Pulse Generator 0 (TPG0) #### (1) Configuration The TPG0, as shown in Figure 3.10.1, is composed of 22-bit 8-stage FIFO data register (16-bit timing data + 6-bit output data), 16-bit comparator, 6-bit output data buffer and FIFO control circuit. #### (2) Operation #### ① 22-bit 8-stage FIFO buffer This is a 22-bit data register which is composed of 16-bit timing data and 6-bit output data. As this register has a 8-stage FIFO structure, the first written timing data and output data are transferred first to the comparator and output data register. Set to the lower timing data register (TPG0L), the higher timing data register (TPG0H) and the output data register (TPG0DR) in this order. The FIFO address is incremented by writing of TPG0DR. 6-bit output data is transferred to the output data buffer when 16-bit timing data matches the value of TBC3 to TBC18. And they become the TPG00 to TPG05. #### ② 16-bit comparator When the set data of the TPG0L and TPG0H matches the value of TBC3 to TBC18, the comparator outputs the match signal. The value of TPG0DR is transferred to output data buffer and the FIFO address is incremented by the match signal. ### 3 Output data buffer The data set in the output data register (TPG0DR) is latched by the match signal from the 16-bit comparator, and TPG00 to TPG05 outputs are changed. When resetting, this buffer is cleared to 0 and TPG00 to TPG05 outputs become 0. #### 4 FIFO control circuit The FIFO control circuit controls the 22-bit 4-stage FIFO buffer and has a status flag to monitor the FIFO address. The current number of retained data can be verified by reading out the FIFO status flags <TPF02, TPF01, TPF00> of the TPG0 control register (TPG0CR). In case that the value of the FIFO status flag is 000, the FIFO empty flag <TPEMP0> is set to 1 when retained data is nothing and the FIFO full flag <TPFUL0> is set to 1 when retained data are 8 words. And, writing data to the FIFO buffer is disabled while the <TPFUL0> is set to 1. The contents of the FIFO status flags is varied each time the match signal is outputted from the comparator. The contents of the FIFO status flags is cleared to 000 by resetting. In addition, the FIFO address can be cleared by writing 1 to <TPRS0> of the capture control register (CAPCR). #### S Timing pulse generator 0 interrupt (INTTPG0) When the contents of the FIFO buffer becomes empty, an INTTPG0 (empty) interrupt to request the writing of the next data is generated. The INTTPG0 (empty) interrupt request can be controlled by TPG0CR <FEMPIE> and CAPCR <TPRS0>. By setting <FEMPIE> to "1", INTTPG0 (empty) interrupt request is enabled by writing of TPG0 output data register (TPG0DR). And by writing "1" to CAPCR <TPRS0>, it can be disabled (in this case FIFO address will also be cleared). In addition, INTTPG0 (TPG03) interrupt request can be generated synchronized with the rising edge or falling edge of TPG03. Either rising or falling edge of TPG03 can be selected by <INTTPG0E> of interrupt input mode control register (IIMC1). To enable or disable INTTPG0 (TPG03) interrupt request can be selected using IIMC1 <INTTPG0S>. INTTPG0 interrupt request is generated as logical-OR with INTTPG0 (empty) interrupt request and INTTPG0 (TPG03) interrupt request. # (3) Control Register **TPG0 Control Register** | TΡ | G00 | CR | |-----|-----|----| | (00 | 36I | H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|----------|--------|-----------|-----------|---------|-------------|--------------|---------|--|--|--| | bit symbol | | | FEMPIE | TPFUL0 | ¦TPEMP0 | TPF02 | TPF01 | ¦ TPF00 | | | | | Read/Write | | | . W | ! R | ! R | ! | R | | | | | | After reset | 0 | | i 0 | 0 | i 1 | i 0 | 0 | i o | | | | | Function | Always | | INTTPG0 | TPG0 | TPG0 | TPG0 FIF | O status fla | ag | | | | | | set to 0 | l | FIFO | FIFO full | FIFO | (Stored | data) | | | | | | | | l<br>I | empty | flag | empty | 000:Empty | or Full | | | | | | | | l<br>I | interrupt | !<br>! | 1<br>1 | 1001: 1 wor | ď | | | | | | | | | enable | 0: — | 0: — | 010: 2 wor | ď | | | | | | | | İ | ! | 1:FIFO | 1: FIFO | 1011: 3 wor | ·d | | | | | | | | l<br>I | ¦0: — | full | empty | 100: 4 wor | ď | | | | | | | | l<br>I | 1: Enable | l<br>1 | )<br> | 101: 5 wor | ď | | | | | | | | | 1<br>1 | 1<br>1 | 1<br>1 | ¦110: 6 wor | ď | | | | | | | | 1 | !<br>! | l<br>I | ]<br> | 1111: 7 wor | rd | | | | | TPG0 lower timing data register TPG0L (0037H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------------|---------|------------|--------|--------|--------|--------|--------|--------|--|--| | bit Symbol | TPG0D7 | TPG0D6 | TPG0D5 | TPG0D4 | TPG0D3 | TPG0D2 | TPG0D1 | TPG0D0 | | | | | (TBC10) | (TBC9) | (TBC8) | (TBC7) | (TBC6) | (TBC5) | (TBC4) | (TBC3) | | | | Read/Write | | Write-only | | | | | | | | | | After reset | * | * | * | * | * | * | * | * | | | | $\overline{}$ | | | | | | | | | | | <sup>\*:</sup> unknown after reset TPG0 higher timing data register TPG0H (0038H) | | 7 | 6 | 5 | 4 | i 3 | i 2 | i 1 | 0 | |-------------|---------|---------|---------|---------|---------|---------|---------|---------| | bit Symbol | TPG0DF | TPG0DE | TPG0DD | TPG0DC | TPG0DB | TPG0DA | TPG0D9 | TPG0D8 | | · | (TBC18) | (TBC17) | (TBC16) | (TBC15) | (TBC14) | (TBC13) | (TBC12) | (TBC11) | | Read/Write | | | | Write | -only | | | | | After reset | * | * | * | * | * | * | * | * | <sup>\*:</sup> unknown after reset TPG0 output data register TPG0DR (0039H) | , | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---|-------------|---|------------|---------|---------|-----------|---------|---------|---------|--|--| | ` | bit Symbol | | 1 | TPGD05 | TPGD04 | TPGD03 | TPGD02 | TPGD01 | TPGD00 | | | | | | | 1 | (TPG05) | (TPG04) | ! (TPG03) | (TPG02) | (TPG01) | (TPG00) | | | | | Read/Write | | Write-only | | | | | | | | | | | After reset | | 1 | * | * | * | * | * | * | | | \*: unknown after reset CAPCR (0052H) | ·. umanor | Capture control register | | | | | | | | | | | |-------------|--------------------------|----------------|--------------|-----------------------------|-------------|------------|------------|------------|--|--|--| | | 7 | ! 6 | <u> </u> | ! 4 | ! 3 | 2 | 1 | ! 0 | | | | | bit Symbol | CAP2T<br>(CFG) | CAP1T<br>(DFG) | CAPCL | VISFRS | VASFRS | TPRS0 | CFGCL | CAFRS | | | | | Read/Write | R | ! R | ! | R/W (Always "0" at reading) | | | | | | | | | After reset | 0 | i 0 | i 0 | i 0 | 0 | 0 | i 0 | i 0 | | | | | Function | CAP2 | CAP1 | CAP1/ | VISS detect | VASS detect | TPG0 FIFO | CFG flag | Capture0 | | | | | | trigger input | trigger input | CAP2 | flag clear | flag clear | counter | clear | FIFO | | | | | | status | status | status clear | i | ; | clear & | 1 | counter/ | | | | | | | ! | !<br>! | 1 | lo: — | INTTPG0 | 1 | istatus | | | | | | 0: No | 0: No | lo: — | lo: — | 1:Clear | disable | 0: — | iclear | | | | | | trigger | trigger | 1: Clear | 1: Clear | (One-shot) | 10:— | 1: Clear | 1 | | | | | | input | input | (One-shot) | (One-shot) | !<br>! | 1: Clear & | (One-shot) | lo: — | | | | | | 1: Trigger | 1: Trigger | ! | 1 | 1 | Inhibit | 1 | 1: Clear | | | | | | input | input | 1<br>1 | 1 | 1 | (One-shot) | 1 | (One-shot) | | | | Interrupt input mode control register 1 IIMC1 (005FH) | | 7 | ¦ 6 | ¦ 5 | 4 | ; 3 | 2 | 1 | , 0 | |-------------|------------|-------------|------------|-------------|--------------|--------|-------------|-------------| | bit Symbol | I4EG | ¦ I3EG | ¦ I2EG | ¦ I1EG | l IOEG | | INTTPG0 | INTTPG0S | | | | i | i | i | i i | | E | i | | Read/Write | | | W | | | | R/W | , R/W | | After reset | 0 | <u> </u> | ¦ 0 | <u> </u> | 0 | | ¦ 0 | 0 | | Function | INT4 | ¦INT3 | ¦INT2 | ¦INT1 | ¦INT0 | l<br>I | INTTPG0 | ¦INTTPG0 | | | edge | ¦edge | edge | ¦edge/leve | edge/leve | <br> | interrupt | interrupt | | | selection | selection | selection | I selection | I selection | !<br>! | TPG03 | selection | | | | 1<br>1 | 1 | 1<br>1 | i ! | )<br> | ¦edge | l<br>J | | | 0: Rising | ¦0: Rising | ¦0: Rising | ¦0: Rising | ¦0: Rising ¦ | !<br>! | selection | ¦0: FIFO | | | 1: Falling | ¦1: Falling | 1: Falling | edge | edge | l<br>I | l<br>I | empty | | | | 1 | 1 | 1: Level | 1: Level | )<br> | ¦0: Rising | ¦ interrupt | | | | 1<br>1 | 1 | 1<br>1 | ! !<br>! ! | ]<br> | ¦1: Falling | ¦1: FIFO | | | | 1<br>1 | 1 | 1<br>1 | ! !<br>! ! | l<br>I | !<br>! | empty/ | | | | !<br>! | I<br>I | !<br>! | ! !<br>! ! | <br> | <br> | ¦ TPG03 | | | | I<br>L | I<br>L | I<br>L | l<br>1 | | I<br>1 | interrupt | Prohibit read-modify-write Figure 3.10.2 Registers for TPG0 # (4) Output of timing pulse generator 0 ① TPG00 TPG00 controls the color rotary output (CR). (Refer to 3.13 Head Amplifier (HA) /Color Rotary (CR) Control Circuit.) ② TPG01 TPG01 can be used as AFF (audio head switching) signal. **3 TPG02** TPG02 controls the pseudo synchronizing signal output (PV). (Refer to 3.15 Pseudo Synchronizing Signal Output Circuit.) **4** TPG03 TPG03 can be used as DFF (cylinder head switching) signal. ⑤ TPG04 TPG04 controls the pseudo synchronizing signal output (PV). (Refer to 3.15 Pseudo Synchronizing Signal Output Circuit. **© TPG05** TPG05 controls the head amp (HA) output. (Refer to 3.13 Head Amplifier (HA) /Color Rotary (CR) Control Circuit.) #### 3.10.2 Timing Pulse Generator (TPG1) #### (1) Configuration TPG1 consist of a 20-bit data register (16-bit timing data + 4-bit output data), 16-bit comparator and 4-bit output data buffer. # (2) Operation #### ① 20-bit data register This is a 20-bit data register which is composed of 16-bit timing data and 4-bit output data. Set to the lower timing data register (TPG1L), higher timing data register (TPG1H), and the output data register (TPG0DR). 4-bit output data is transferred to the output data buffer when 16-bit timing data matches the value of TBC3 to TBC18. And they become the TPG10 to TPG13. # ② 16-bit comparator When the set data of the TPG1L and TPG1H matches the value of TBC3 to TBC18, the comparator outputs the match signal. The value of the TPG1DR is transferred to output data buffer and INTTPG1 interrupt request is generated by the match signal. #### 3 Output data buffer The data set in the output data register (TPG1DR) is latched by the match signal from the 16-bit comparator, and TPG00 to TPG05 are outputted. When resetting, this buffer is cleared to 0 and TPG10 to TPG13 output become 0. # (3) Control register TPG1 lower timing data register TPG1L (003AH) | - 1 | | 7 | 6 | 5 | 4 | i 3 | i 2 | 1 | i 0 | | |-----|-------------|------------|--------|--------|--------|--------|--------|--------|--------|--| | - [ | bit Symbol | TPG1D7 | TPG1D6 | TPG1D5 | TPG1D4 | TPG1D3 | TPG1D2 | TPG1D1 | TPG1D0 | | | - | • | (TBC10) | (TBC9) | (TBC8) | (TBC7) | (TBC6) | (TBC5) | (TBC4) | (TBC3) | | | | Read/Write | Write-only | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TPG1 higher timing data register TPG1H (003BH) | | 7 | <u> 6</u> | <u> 5</u> | <u> </u> | <u> 3</u> | . 2 | <u> </u> | 0 | |-------------|---------|-----------|-----------|----------|-----------|---------|----------|---------| | bit Symbol | TPG1DF | TPG1DE | TPG1DD | TPG1DC | TPG1DB | TPG1DA | TPG1D9 | TPG1D8 | | - | (TBC18) | (TBC17) | (TBC16) | (TBC15) | (TBC14) | (TBC13) | (TBC12) | (TBC11) | | Read/Write | | | | Write | -only | | | | | After reset | 0 | 0 | . 0 | ; O | 0 | 0 | 0 | 0 | TPG1 output data register TPG1DR (003CH) | | | | *** *** ****************************** | | | | | | | | | |---|-------------|---|----------------------------------------|----------|---|---|------------|---------|---------|---------|--| | , | | 7 | 6 | 5 | 1 | 4 | 3 | 2 | 1 | 0 | | | ٠ | bit Symbol | | I<br>1 | I<br>1 | 1 | | | | | TPGD10 | | | | | | I | <u>i</u> | i | | (TPG13) | (TPG12) | (TPG11) | (TPG10) | | | | Read/Write | | l<br>I | 1<br>1 | 1 | | ı | Write | -only | | | | | After reset | | ! | | 1 | | <u>'</u> 0 | . 0 | 0 | . 0 | | Figure 3.10.3 Registers for TPG1 # (4) Output of timing pulse generator 1 ① TPG10 TPG10 controls the recording amplifier (external IC) for CTL signal. ② TPG11 TPG11 controls the recording amplifier (external IC) for CTL signal. **③ TPG12** TPG12 can be output from TPG12 (P90) pin. **4** TPG13 TPG13 can be output from TPG13 (P95) pin. #### 3.11 Pulse Width Modulation output(PWM) TMP93C071F has the pulse width modulation output with 14-bit resolution of 3 channels (PWM0, PWM1, PWM2) and with 8-bit resolution of 9 channels (PWM3-PWM11). It is possible to use it to apply the DC motor control for the drum and capstan, the tuner control (voltage synthesize method), and the volume control, etc. by turning on the low-pass filter outside. ### 3.11.1 8-bit PWM (PWM3-PWM11) PWM3 to PWM11 are the 8-bit PWM output of 9 channels. These are controlled by the PWM control register (PWMCR) and the PWM data buffer register (PWMDBR). #### (1) Block diagram Figure 3.11.1 8-bit PWM output (PWM3 to PWM11) #### (2) Control of PWM output PWM3 to PWM11 are the pulse output with 8-bit resolution and the one cycle time is $T_M = 2^8/(fc/2)$ s (25.6 us/39.06 kHz at 20 MHz operation). When the value of the 8-bit PWM data latch is n, the H level pulse width becomes n × t0 (t0 = 1/(fc/2)) [s]. The PWM control register (PWMCR) and the PWM data buffer register (PWMDBR) are shared with all channels. The data set in PWMDBR is transferred to the data latch of the channel selected by PWMCR. Moreover, It can be known the state of the PWM data transfer from the data buffer register to the data latch by reading PWMCR<PWMEOT >. Figure 3.11.2 Wave form of the 8-bit PWM output | PWM data | huffer | register | |----------------|--------|----------| | r v v ivi uala | Dullel | redister | | PWMDBR | | |---------|--| | (0044H) | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------------|---------|------------|---------|---------|---------|---------|---------|---------|--|--|--|--| | bit Symbol | PWMDBR7 | PWMDBR6 | PWMDBR5 | PWMDBR4 | PWMDBR3 | PWMDBR2 | PWMDBR1 | PWMDBR0 | | | | | | Read/Write | | Write-only | | | | | | | | | | | | After reset | * | <br> * | * | * | * | ı * | · * · | * | | | | | #### \*: unknown after reset PWM control register | <b>PWMCR</b> | |--------------| | (0045H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|-------------|--------|--------|--------|-------------------------------------------|-----------------|----------------------------------------------|---------|--|--| | bit Symbol | PWMEOT | | i | l<br>I | PWMDLS3 | PWMDLS2 | PWMDL\$1 | PWMDLS0 | | | | Read/Write | R | | | | T<br>I | Write- | only | | | | | After reset | 0 | l<br>I | <br> | !<br>! | ¦ 0 | l<br>I | <br> | I<br>I | | | | Function | End flag of | | | | PWM channel select and data transfer | | | | | | | | PWM data | i i | | i<br>İ | The PWMDBR data is stored to the selected | | | | | | | | transfer | | | !<br>! | PWM channe | l after setting | this channel o | code. | | | | | | | | i | This code mu | st be set wh | en <pwmeo< td=""><td>T&gt; = 0</td></pwmeo<> | T> = 0 | | | | | 0: End of | | <br> | ]<br> | 1<br>1 | | | | | | | | transfer | | | | 0000: PWM3 | 0100: PWN | //7 1000: P | WM11 | | | | | 1: Under | | | <br> | 0001: PWM4 | 0101: PWN | /18 | | | | | | transfer | i<br>i | i<br>! | <br> | 0010: PWM5 | 0110: PWN | <b>/</b> 19 | | | | | | | | <br> | !<br>! | 10011: PWM6 | 0111: PWN | <b>/11</b> 0 | | | | Figure 3.11.3 Registers for the 8-bit PWM # (3) Writing of the PWM output data The PWM output is controlled by writing the output data in the data latch. The output data is written by using PWMCR<PWMDLS3-0>, <PWMEOT> and PWMDBR according to the following procedure. - 1. It is confirmed that it is PWMCR<PWMEOT> = 0. - 2. The output data is written in PWMDBR. - 3. By writing the channel code to PWMCR<PWMDLS3-0>, the data transfer demand is generated at the same time as selecting the channel, and PWMCR<PWMEOT> becomes 1. - 4. The output data is transferred to the selected channel according to the timing that (TBC8 to TBC0) of the time base counter (TBC) becomes FFH, and PWMCR<PWMEOT> is cleared to 0 at the same time. When PWMCR<PWMEOT > becomes 0, the next data can be written. Note: Please rewrite PWMDBR at PWMCR<PWMEOT> = 0. #### 3.11.2 14-bit PWM (PWM0 to PWM2) The 14-bit PWM are controlled by the data register (PWM0DRL/PWM0DRH, PWM1DRL/PWM1DRH, PWM2DRL/PWM2DRH) and the PWM start register (PWMRUN). #### (1)Block diagram Figure 3.11.4 14-bit PWM output (PWM0 to PWM2) #### (2) Control of PWM output The PWM0 to PWM2 output are the pulse output with 14-bit resolution and the one cycle time is $T_M = 2^{14}/(fc/2)$ s (1.638 ms at 20 MHz operation). The carrier frequency is $T_s = T_M/64$ [s] (25.6 us/39.06 kHz at 20 MHz operation). The data register to set the pulse width is composed of 14-bit (PWM0DRL/PWM0DRH (PWM0), PWM1DRL/PWM1DRH (PWM1), and PWM2DRL/PWM2DRH (PWM2)) respectively. It is necessary to write the data in the data register in order of the lower-data register (PWM0DRL, PWM1DRL, PWM2DRL) → the higher-data register (PWM0DRH, PWM1DRH, PWM2DRH). The data changes when the following T<sub>s</sub> cycle is begun after writing in the higher-data register. When the value of the upper data latch is "n" and the value of the lower-data latch is "m", the carrier pulse width is "n $\times$ t0 (t0=1/(fc/2))[s]", the additional pulse with "t0 (t0=1/(fc/2))[s]" is added at the "m" points of the carrier pulses which output for the one $T_M$ cycle. Therefore, the width of the carrier pulse with the additional pulse becomes "(n+1) $\times$ t0[s]". (When the value of 14-bit data register is increased by "k", the total pulse width is increased by "(k $\times$ t0)" for the one $T_M$ cycle.) The PWM0 to PWM2 begins outputting by setting PWMRUN<PWM0RUN, PWM1RUN, PWM2RUN > to 1. Figure 3.11.5 Wave form of the 14-bit PWM output | PW/M | start | register | |-----------|-------|----------| | L A A IAI | อเลเเ | redister | | <b>PWMRUN</b> | ١ | |---------------|---| | (003DH) | | | | 100 1 3 100 | | | | | | | | | | |-------------|-------------|--------|--------|--------|--------|---------|------------------|---------|--|--| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | bit Symbol | | 1<br>1 | <br> | <br> | <br> | PWM2RUN | PWM1RUN | PWM0RUN | | | | Read/Write | | ! | i<br>I | i<br>I | i<br>I | I<br>I | R/W | | | | | After reset | | 1<br>1 | <br> | <br> | <br> | 0 | 0 | 0 | | | | Function | | i<br>i | i<br>I | i<br>I | i<br>I | 0: S | 0: Stop 1: Start | | | | PWM0 lower data register PWM0DRL (003EH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|---------------|--------|--------|--------|--------|--------|--------|--------|--|--| | bit Symbol | PWM0D7 | PWM0D6 | PWM0D5 | PWM0D4 | PWM0D3 | PWM0D2 | PWM0D1 | PWM0D0 | | | | Read/Write | te Write-only | | | | | | | | | | | After reset | * | * | * | * | * | * | * | * | | | \*: unknown after reset PWM0DRH (003FH) | | | PWM0 higher data register | | | | | | | | | | | | |---|-------------|---------------------------|---|------------|--------|--------|--------|--------|--------|--|--|--|--| | 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | bit Symbol | | | PWM0DD | PWM0DC | PWM0DB | PWM0DA | PWM0D9 | PWM0D8 | | | | | | | Read/Write | | | Write-only | | | | | | | | | | | | After reset | | | * | * | * | * | * | * | | | | | \*: unknown after reset PWM1DRL (0040H) | | PWM1 lower data register | | | | | | | | | | | |----|--------------------------|------------|--------|--------|--------|--------|--------|--------|--------|--|--| | L. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | bit Symbol | PWM1D7 | PWM1D6 | PWM1D5 | PWM1D4 | PWM1D3 | PWM1D2 | PWM1D1 | PWM1D0 | | | | | Read/Write | Write-only | | | | | | | | | | | | After reset | * | * | * | * | !<br>! | * | * | * | | | \*: unknown after reset PWM1 higher data register PWM1DRH (0041H) | н[ | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----|-------------|---|-------------|------------|----------|--------|------------|--------|--------|--| | | bit Symbol | | 1<br>!<br>! | PWM1DD | PWM1DC | PWM1DB | PWM1DA | PWM1D9 | PWM1D8 | | | | Read/Write | | 1 | Write-only | | | | | | | | | After reset | | !<br>! | ' *<br>' * | *<br>! * | * | ' *<br>' * | * | * | | <sup>\*:</sup> unknown after reset | | | | | PWM2 I | ower data r | egister | | | | | | |-----------------------------|---------------------------------------------------|-------------|----------|-------------|---------------|-----------|------------------------|---------------|----------|--|--| | PWM2DRL | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | (00 <b>4</b> 2H) | bit Symbol | PWM2D7 | PWM2D6 | PWM2D5 | PWM2D4 | PWM2D3 | PWM2D2 | PWM2D1 | PWM2D0 | | | | | Read/Write | | | | Write | -only | | | | | | | | After reset | * | * | !<br>! * | * | * | 1<br>1 * | * | * | | | | | *: unknown after reset PWM2 higher data register | | | | | | | | | | | | PWM2DRH<br>(00 <b>4</b> 3H) | | 7 | 6 | 5 | . 4 | 3 | . 2 | 1 | 0 | | | | (004011) | bit Symbol | | l<br>1 | PWM2DD | PWM2DC | PWM2DB | PWM2DA | PWM2D9 | PWM2D8 | | | | | Read/Write | | | <br> | | Write | e-only | | | | | | | After reset | İ | l<br>I | * | * | * | * | * | * | | | | | *: unknow | n after res | et | Open dra | in control re | egister 3 | | | | | | | ODCR3 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | (0021H) | bit Symbol | | !<br>! | <br> | PWMOD1 | PWMOD0 | PODA5 | PODA4 | PODA3 | | | | | | | | l<br>I | (PWM1) | (PWM0) | (PortA5) | (PortA4) | (PortA3) | | | | | Read/Write | | | | Write | -only | !<br>!<br><del>!</del> | Write-only | | | | | | After reset | | <u> </u> | l<br>! | 0 | 0 | 0 | 0 | 0 | | | | | Function | 1 | <br> | !<br>!<br>! | PWM0, 1 Op | en drain | Port A Open | drain control | | | | | | | ! | | <br> | control | | 1<br>1 | | | | | | | | | | <br> | !<br>!<br>! | | l 0: Push- | pull 1: Op | en drain | | | | | | i<br>I | | l | 0: Push-pull | | <br> | | | | | | | | | | l<br>I | 1: Open drair | 1 | <br> | | | | | Figure 3.11.6 Registers for 14-bit PWM ### 3.12 VISS / VASS DETECTOR (VIVA) This circuit is to support the Video Index Search System (VISS) and Video Address Search System (VASS) for VHS VCR. By using this circuit, the duty of control signal (CTL) recorded on video tapes is can be measured and the VISS code can be detected. Further, the address code of VASS can be read out. #### 3.12.1 Configuration VISS / VASS detector consists of the CTL duty discrimination circuit, VISS detection circuit, VASS header detection circuit and 16-bit address code register. Figure 3.12.1 VISS/VASS detector # 3.12.2 Control Registers VIVACR1 (0054H) | | | 1 | VISS/VASS | control reg | ister 1 | | | | |-------------|---------------|---|-----------|-------------|---------|----------------|-------------|-------------| | | 7 | 6 | 5 | 4 | 3 | 2 | <u>.</u> 1 | . 0 | | bit Symbol | | | İ | i | | CTLDTY | VISSFL | VASSFL | | Read/Write | ! | | l<br>I | 1 | 1<br>1 | ¦ R | ¦ R | ¦ R | | After reset | I | | I<br>I | I<br>I | I<br>I | ¦ 0 | , 0 | ; 0 | | Function | Always set to | | l<br>I | 1 | i | CTL signal | ¦viss | lvass | | | 0 | | !<br>! | | !<br>! | duty detector | detect flag | detect flag | | | | | !<br>! | | : | monitor flag | ! | | | | ] | | !<br>! | | !<br>! | ! | 0:— | 0:— | | | | | !<br>! | | į | 0: CTL duty | 1: VISS | 1: VASS | | | 1 : | | !<br>! | | !<br>! | greater | detected | detected | | | | | !<br>! | | ! | than 50% | | - | | | ; | | !<br>! | 1 | ; | (VIVACR2 | 1 | 1 | | | | I | !<br>! | 1 | : | | 1 | 1 | | | | ! | !<br>! | 1 | : | ¦0) | 1 | 1 | | | | ! | !<br>! | 1 | : | 1 | 1 | 1 | | | | ! | 1<br>1 | 1 | ! | 1: CTL duty | 1 | 1 | | | | ! | !<br>! | 1 | 1<br>1 | less than | 1 | 1 | | | | | !<br>! | 1 | !<br>! | 50% | ! | 1 | | | | | I<br>I | : | ! | (VIVACR2 | I<br>I | 1 | | | ; | | I<br>I | 1 | !<br>! | -<br>PCTLPO> = | 1<br>1 | 1<br>1 | | | : | I | !<br>! | 1 | !<br>! | ¦0) | I<br>I | ]<br>] | VISS/VASS control register 2 VIVACR2 (0055H) | | | | | VIOO/VAGO | control regi | ISICI Z | | | | |---|-------------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------|---------|---------------|-------|-------| | : | | 7 | 6 | 5 | . 4 | 3 | 2 | 1 | 0 | | | bit Symbol | PCTLPO | PCTLCKS | MSK1 | MSK0 | VISS3 | VISS2 | VISS1 | VISS0 | | | Read/Write | R/W | l R/W | R/W | ¦ R/W | 1<br>1 | R/W | | | | | After reset | 0 | 0 | 0 | . 0 | 0 0 | | 0 | 0 | | | Function | CTL signal polarity selection 0: Positive (+) (when duty is less than 50%, VIVACR1 < CTLDTY> is set to 1) | CTL duty measuring clock selection 0: Selected by CAPINCR1 <pctlck 1,="" 2=""> 1: Automatic selection</pctlck> | Dividing control for CTLIN input 0: Divide 1: Bypass | masking<br>control for<br>CFG input<br>0: Mask<br>1: Bypass | The | with<br>Inter | | | | | | is set to 0) | l | l | !<br>! | l<br>! | | | | Capture input control register 1 CAPINCR1 7 6 5 3 2 1 0 PCTLCK1 | PCTLCK0 PCPR4 PCPR1 bit symbol PCPR5 PCPR3 PCPR2 PCPR0 Read/Write R/W R/W 0 0 0 0 0 0 After reset 0 0 CTL duty measure clock 6-bit programmable divider control Function Dividing rate selection for (VIVACR2<PCTLCKS> CTLIN (from P80) and CFGIN (from P85). = 0) 1000000: 1/1 00: TBC3 01: TBC5 1000001: 1/2 --- 111111: 1/64 10: TBC7 11: TBC10 Capture control register CAPCR (0052H) (0047H) | | 7 | <del> </del> 6 | 5 | 4 | 3 | 2 | 1 | i o | |-------------|---------------|----------------|--------------|-------------|-------------|----------------|------------|------------| | bit Symbol | CAP2T | CAP1T | CAPCL | VISFRS | VASFRS | TPRS0 | CFGCL | CAFRS | | | (CFG) | (DFG) | <br> | | <br> | | l<br>I | l<br>I | | Read/Write | R | R | <br> | · | R/W (Alway | s 0 at reading | <b>j</b> ) | | | After reset | 0 | ¦ 0 | ¦ 0 | ¦ 0 | ¦ 0 | ¦ o | ¦ 0 | ¦ 0 | | Function | CAP2 | CAP1 | CAP1/ | VISS detect | VASS detect | TPG0 FIFO | CFG flag | Capture0 | | | trigger input | trigger input | CAP2 | lflag clear | flag clear | counter | clear | FIFO | | | status | status | status clear | ! | ! | clear & | !<br>! | counter/ | | | | :<br>! | '<br>!<br>! | ! | 0: — | INTTPG0 | !<br>! | status | | | 0: No trigger | 0: No trigger | ¦0: — | ¦0: — | ¦1: Clear | disable | ¦0: — | clear | | | input | input | 1: Clear | 1: Clear | (One-shot) | 0: — | 1: Clear | 1 | | | 1: Trigger | 1:Trigger | (One-shot) | (One-shot) | !<br>! | 1:Clear & | (One-shot) | 0: — | | | input | input | !<br>! | 1<br>1 | I<br>I | Inhibit | 1<br>1 | 1: Clear | | | | 1<br>1 | I<br>I | I<br>I | <br> | (One-shot) | 1<br>1 | (One-shot) | VASS data register VASSDR (0056H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|---------------------------|--------|--------------|------------------|----------------|--------------|-------|-------|--|--| | bit Symbol | VASS7 | VASS6 | VASS5 | VASS4 | VASS3 | VASS2 | VASS1 | VASS0 | | | | | VASS15 | VASS14 | VASS13 | VASS12 | VASS11 | VASS10 | VASS9 | VASS8 | | | | Read/Write | | | | Read | -only | | | | | | | After reset | * | * | | | | | | | | | | Function | Twice reading from VASSDR | | | | | | | | | | | | | | The First is | s lower 8-bit, t | he second is l | nigher 8-bit | | | | | <sup>\*:</sup> unknown after reset Figure 3.12.2 Registers for VISS/VASS #### 3.12.3 Control of the CTL duty discrimination circuit #### (1) Control of CTL duty discrimination The CTL signal which is inputted from CTLIN pin is inputted, as a PCTLA signal, to VISS/VASS detector (VIVA) via the Capture input control circuit (CAPIN). The CTL duty discrimination circuit judges by threshold; the threshold has half the time of PCTLA signal term. If duty of the PCTLA signal $\geq$ 50%, the CTL duty discrimination circuit outputs 0. And if its duty $\leq$ 50%, it outputs 1. This output can be read as <CTLDTY> of the VISS/VASS control register 1 (VIVACR1). And, the polarity of output can be inverted by using <PCTLPO> of the VISS/VASS control register 2 (VIVACR2). #### (2) Control of Clock switching The Clock source, which is to measure CTL signal term, is selected by software or by hardware. If its clock source is selected by software, it is required to set <PCTLCK0> and <PCTLCK1> in Capture Input Control Register 1 (CAPINCR1) to connect adequate TBC while <PCTLCKS> in VIVACR2 is 0. On the other hand, TBC is selected automatically while <PCTLCKS> is 1. The following table indicates the relation between the term of CTL and its clock source. Table 3.12.1 Relation between the CTL signal term and its measuring clock source | <pctck1></pctck1> | Clock source for CTL duty discrimination (at | Term of CTL signal | | | | |---------------------|----------------------------------------------|--------------------|--|--|--| | <pctlck0></pctlck0> | fc = 20 MHz) | | | | | | 00 | TBC3 ( 0.8 µs) | 1221 to 25000 Hz | | | | | 01 | TBC5 ( 3.2 μs) | 305 to 6250 Hz | | | | | 10 | TBC7 ( 12.8 μs) | 76 to 1562 Hz | | | | | 11 | TBC10 (102.4 μs) | 9 to 195 Hz | | | | #### 3.12.4 Control of VISS detection VISS detection circuit consists of 6-bit up counter counts PCTLA signal, comparator for detecting VISS index code, and R/S flip-flop (VISS flag). Since CTL duty discriminating output is "L" active reset input for 6-bit counter, 6-bit counter is held on count operation while CTL duty discriminating output is "H" (in case that <PCTLPO> = 0). The upper 4bits in 6-bit counter are compared with value of VISS detection circuit which is a 4-bit comparator. The data on the comparator is set by <VISS3> to <VISS0> of VISS/VASS Control Register 2 (VIVACR2). VISS signal is outputted when the upper 4bits in 6-bit counter and the data on <VISS3> to <VISS0> are matched; the matching sets the VISS flag and requests INTVA interrupt. The state of VISS flag can be read out by <VISSFL> of VISS/VASS Control Register 1 (VIVACR1), and the VISS flag can be cleared by using <VISFRS> of the Capture control register (CAPCR). Table 3.7 2 shows relation between the value of <VISS3> to <VISS0> and count value of the PCTLA signal. In order to detect VISS, set VIVACR2 <PCTLPO> to 0 when tape operates forward and set VIVACR2 <PCTLPO> to 1 when it operates reversely. Table 3.12.2 Relation between the value of <VISS3> to <VISS0> and count value of the PCTLA signal | <viss< th=""><th>33&gt;tc</th><th><vi:< th=""><th>SS0&gt;</th><th>The count value for detecting VISS index code</th></vi:<></th></viss<> | 33>tc | <vi:< th=""><th>SS0&gt;</th><th>The count value for detecting VISS index code</th></vi:<> | SS0> | The count value for detecting VISS index code | |------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------------------------------------------------------|------|-----------------------------------------------| | 3 | 2 | 1 | 0 | Ţ | | 0 | 0 | 0 | 0 | don't use | | 0 | 0 | 0 | 1 | 4 | | 0 | 0 | 1 | 0 | 8 | | 0 | 0 | 1 | 1 | 12 | | 0 | 1 | 0 | 0 | 16 | | 0 | 1 | 0 | 1 | 20 | | 0 | 1 | 1 | 0 | 24 | | 0 | 1 | 1 | 1 | 28 | | 1 | 0 | 0 | 0 | 32 | | 1 | 0 | 0 | 1 | 36 | | 1 | 0 | 1 | 0 | 40 | | 1 | 0 | 1 | 1 | 44 | | 1 | 1 | 0 | 0 | 48 | | 1 | 1 | 0 | 1 | 52 | | 1 | 1 | 1 | 0 | 56 | | 1 | 1 | 1 | 1 | 60 | #### 3.12.5 Control of VASS detection circuit VASS detector consists of the header detection circuit and address code register (16-bit shift register). The header detection circuit detects the CTL duty discriminating output status that begins with "0" (6-bit counter is reset) before 9-bits of continuous 1 (the PCTLA signal is counted by 6-bit counter). 16-bit shift register latches 16 bits of CTL duty discriminating output as the address code, which follows 0 after 9-bits of 1 in header. When the register finishes latching whole data of 16 bits, R/S flip-flop (VASS flag) is set and INTVA interrupt is requested. Which interrupt request is generated; it can be checked by reading <VISSFL> and <VASSFL> of the VISS/VASS control register 1 (VIVACR1) in INTVA interrupt processing routine. VASS flag can be reset to 0 by using <VASFRS> of the Capture control register (CAPCR). VASS address code generates INTVA interrupt 4 times by one set because address code has 4 headers. But the 4th code data becomes dummy. And, when the INTVA interrupt is generated, it is required to read address code before the next address code is started to latch. The 16-bit address code can be got by reading VASS data register (VASSDR) twice; the first read data is lower 8-bit (<VASS7> to <VASS0>) of the address code and the second read data is higher 8-bit (<VASS15> to <VASS8>). In addition, if data is written to VASSDR (dummy write), the VASSDR gets ready for reading lower 8-bit. In order to detect VASS, set VIVACR2 <PCTLPO> to 0 when the tape operates forward and set VIVACR2<PCTLPO> to 1 when the tape operates reversely. Notice that the LSB and MSB of address code are reversed each other in case the tape operates reversely. **TOSHIBA** # 3.13 Head Amp Switch/Color Rotary control circuit (HA/CR) TMP93C071 has the head amp switch (HA)/color rotary (CR) control output circuit. The HA output/the CR output are controlled by TPG00 and TPG05 of the timing pulse generator 0 (TPG0), and the COMPIN (P87) pin input value. The input enable and disable of the COMPIN can be controlled by CSYNCR<COMPS >. Figure 3.13.1 HA/CR control circuit # CSYNC control register CSYNCR (0057H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---------------|------|--------|-----------------|------------------|-----------|----------------|------------| | bit Symbol | COMPS | | | CSYNCPO | SEPMOD | CSYNBP | HSEN | MASK | | Read/Write | R/W | | | R/W | R/W | R/W | R/W | R/W | | After reset | 0 | | | <u>.</u> 0 | 0 | . 0 | 0 | 0 | | Function | COMPIN | | <br> | CSYNC input | 7-bit counter | CSYNC | Pseudo-Hsync | Vsync mask | | | input control | | | signal polarity | up/down | bypass | generation to | control | | | | | | selection | count selection | control | PV/PH | 0: | | | 0: Disable | | | <br> | (duty) | | !<br>! | 1: Release | | | (TPG00/ | | | 0: Positive | 0: up/down = 1/1 | 0: V-sep. | 0: Non- | masking | | | TPG05 | | | 1: Negative | 1: up/down = 1/2 | 1: Bypass | synchronized | (One-shot) | | | Output) | ; | | I<br>I | 1<br>1 | !<br>! | with Csync | 1 | | | | | | !<br>! | 1<br>! | !<br>! | input | : | | | 1: Enable | | | !<br>! | !<br>! | !<br>! | 1: synchronize | i | | | ; | | | I<br>I | 1<br>1 | 1<br>1 | with Csync | ; | | | | <br> | l<br>I | I<br>I | !<br>! | !<br>! | input | 1<br>1 | Figure 3.13.2 Registers for HA/CR #### 3.14 SYNC SIGNAL SEPARATOR (CSYNC) The Sync Signal Separator separates the Vertical Synchronizing Signal (V.SYNC) and Horizontal Synchronizing Signal (H.SYNC) from composite synchronizing signal (C.SYNC signal). # 3.14.1 Configuration The Sync Signal Separator consists of H/V Separator and H.Pulse Generator. A configuration of the Sync Signal Separator is shown in Figure 3.14.1. Figure 3. 14.1 Configuration of Sync Signal Separator ### (1) H/V Separator The H/V separator separates H.SYNC and V.SYNC signals from the C.SYNC inputted from CSYNCIN pin. A separated V.SYNC signal is transferred to Capture 0 (CAP0: VS) via the Capture input control circuit (CAPIN). And it is used for reference signal in the servo processing routine. A separated H.SYNC signal is inputted to the H.Pulse generator. #### (2) H.Pulse Generator The H.Pulse generator generates serrated-pulse (HP signal), synchronizing with H.SYNC signal from C.SYNC, in pseudo-V.SYNC signal. The HP signal is transferred to the Pseudo-sync signal output circuit (PV/PH), and it is superimposed to the pseudo-V.SYNC signal as serrated-pulse. (Refer to 3.15 Pseudo-sync signal output circuit.) # 3.14.2 Control Registers CSYNCR (0057H) | | CSYNC control register | | | | | | | | | | | |-------------|------------------------|---|-------------|-------------|------------------|-----------|----------------|--------------|--|--|--| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | . 0 | | | | | bit Symbol | COMPS | | <br> | CSYNCPO | SEPMOD | CSYNBP | HSEN | MASK | | | | | Read/Write | R/W | | i<br>I | R/W | R/W | R/W | R/W | R/W | | | | | After reset | 0 | | I<br>I | . 0 | . 0 | 0 | . 0 | . 0 | | | | | Function | COMPIN | | i<br>I | CSYNC input | 7-bit counter | CSYNC | Pseudo-Hsync | Vsync mask | | | | | | input control | | <br> | signal | up/down | bypass | generation | control | | | | | | | | !<br>!<br>! | polarity | count selection | control | to PV/PH | 0: – | | | | | | 0: Disable | | <br> | selection | ¦(duty) | l<br>I | í<br>1 | 1: Release | | | | | | (TPG00/ | | <br> | ! | 0: up/down = 1/1 | 0: V-sep. | 0: Non- | masking | | | | | | TPG05 | | !<br> <br> | 0: Positive | 1: up/down = 1/2 | 1: Bypass | synchronized | (One-shot) | | | | | | Output) | | <br> | 1: Negative | 1<br>1 | <br> | with Csync | i<br>i | | | | | | | | <br> | 1 | ! | !<br>! | input | ! | | | | | | 1: Enable | | !<br>!<br>! | <br> | !<br>! | | 1: Synchronize | <u> </u><br> | | | | | | | | !<br>! | !<br>! | 1<br>1 | ! | with Csync | I<br>I | | | | | | | | <br> | 1 | <br> | l<br>I | input | 1 | | | | Figure 3.14.2 Registers for CSYNC #### 3.14.3 H/V Separator The H/V Separator Separates the Vertical Synchronizing Signal (V.SYNC) and Horizontal Synchronizing Signal (H.SYNC) from Composite Synchronizing Signal inputted from CSYNC pin. The H/V Separator consists of 7-bit up/down counter and pattern detector (compare / match circuit). 7-bit up/down counter counts TBC1 ( $2^2$ /fc) or TBC2 ( $2^3$ /fc) output from the Time Base Counter. And its direction for counting is controlled by input polarity of CSYNCIN pin; CSYNCA = 1 is for up count and CSYNCA = 0 is for down count. The source clock for up count is only TBC1 ( $0.2 \, \mu s$ : fc = 20 MHz). The source clock for down count is selected either TB1 or TBC2 ( $0.4 \, \mu s$ : fc = 20 MHz) by CSYNCR <SEPMOD>. The input polarity of CSYNCIN pin (CSYNCA signal) is selected by setting <SYNCPO> in CSYNCR and it controls the direction for counting 7-bit counter. In case that CSYNCA is 1, counter stops when counter output becomes all 1. And in case that CSYNCA is 0, counter stops when counter output becomes all 0. CSYNCA is counted up by the 16-bit timer counter 5 (TC5). When CSYNCR <CSYNBP> is set to 1, CSYNCA instead of V-SYNC is inputted to capture 0 (CAP0). # (1) V.SYNC separation If pattern detector (compare/match circuit) detects "114 (72H)" (TBC1 term: 200 [ns] at fc = 20 [MHz]. Therefore, threshold rate is 200 [ns] $\times$ 114 = 22.8 [ $\mu$ s]), it outputs the V.SYNC signal. VS signal is inputted to capture 0 (CAP0) at the same time. V.SYNC resets flip-flop for masking. Flip-flop for masking are reset once, the following V.SYNC signals are not accepted until masking is released. Setting flip-flop (to release masking) is executed on <MASK> of CSYNC control register (CSYNCR). Timing chart of V.SYNC separation is show in Figure 3.14.3. Figure 3.14.3 Timing Chart for V.SYNC separation #### (2) H.SYNC separation If pattern detector detects "15 (FH)" (TBC1 term: 200 [ns] at fc = 20 [MHz]. Therefore, threshold rate is 200 [ns] $\times$ 15 = 3.0 [µs]), it outputs the H.SYNC signal. In case that CSYNCA signal is 0, H.SYNC signal is reset when 7-bit counter becomes all 0. H.SYNC (3.0 µs) signal, which are separated by H/V Separator, is transferred to H.Pulse generator. #### 3.14.4 H.PULSE Generator H.SYNC Generator generates serrated pulse in V.SYNC signal. This generated pulse (HP signal) is transferred to Pseudo-sync signal output circuit (PV/PH), and it can be mixed to pseudo-V.SYNC signal. Configuration of the H.Pulse generator is shown in Figure 3.14.(4). Figure 3.14.4 H.Pulse Generator H.Pulse Generator generates serrated pulse (HP signal) to mix with pseudo-V.SYNC. The timing to mix pseudo-V.SYNC with HP signal is controlled by TPG02 from the Timing pulse generator 0 (TPG0) (Refer to section 3.15 Pseudo-sync signal output circuit). By setting <HSEN> in CSYNC control register (CSYNCR) to 1, HP signal can be synchronized with the H.SYNC signal, outputted from H/V Separator, during TPG02 is "L". In case that <HSEN> is 0, HP signal is not synchronized with C.SYNC signal input. Wave form of the HP signal output is shown in Figure 3.14.5. Figure 3.14.5 Wave form of HP signal output # 3.15 Pseudo-sync Signal Output Circuit (PV/PH) The TMP93C071 has a function to output a pseudo-sync signal (PV) in place of the playback sync signal during special effect reproduction. The PV output is controlled by the timing pulse generator 0 (TPG0)'s TPG02 and TPG04 outputs and the PV control register (PVCR). #### 3.15.1 Circuit Configuration The pseudo-sync signal output circuit consists of a sync signal mixing circuit and a 3-level output circuit. The sync signal mixing circuit is used to superimpose the serrated pulse (HP) that is generated by the H pulse generator of the sync signal separation circuit (CSYNC) on a pseudo-V.SYNC signal. # 3.15.2 Control Register | | PV/PH control register | | | | | | | | | | | |---------|------------------------|---|-------------|---|--------|-----------|-----------------------------|--------|--------|--|--| | PVCR | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | (0058H) | bit Symbol | | l<br>! | | | PHMIX | PVSEL2 | PVSEL1 | PVSEL0 | | | | | Read/Write | | '<br>!<br>! | | | R/W | ,<br> <br> | R/W | | | | | | After reset | | l<br>! | | | . 0 | . 0 | 0 | 0 | | | | | Function | | ,<br>,<br>, | | i<br>I | PH mixing | PV/PH output format control | | ol | | | | | | | !<br>! | | !<br>! | !!! | !<br>! | | | | | | | | | ! ! | | | 0: OFF | !<br>! | | | | | | | | | l <br> | | l | 1: ON | )<br>1 | | | | | Figure 3.15.1 Registers for PV/PH ### 3.15.3 Control of Pseudo-sync Signal Output Output of the pseudo-sync signal (PV) is controlled by TPG02 and TPG04 outputs of the timing pulse generator 0 (TPG0) and the PV control register (PVCR). The vertical sync signal (V.SYNC) is patterned by the TPG0 which is output from TPG04. The TPG02 output is used to set a period at which time the serration (serrated pulse) of V.SYNC is inserted. The serration (HP signal) is generated by the H pulse generator of the sync signal separation circuit (CSYNC). The HP signal is inserted into V.SYNC by setting the PVCR register PHMIX bit to 1. The pseudo-sync signal has six output formats which can be selected by the PVCR register's PVSEL2-0 bits. Figure 3.15.2 shows the output formats of the pseudo-sync signal. Figure 3.15.2 Pseudo-Vsync output format # 3.16 Serial Channels (SIO0 / SIO1) The TMP93C071 has two built-in 8-bit synchronous serial channels. Serial channel 0 (SIO0) is connected to an external circuit via P77 (SCK0), P75 (SO0), P76 (SI0), and serial channel 1 (SIO1) is connected to an external circuit via PB3 (SCK1), PB2 (SO1/SI1). Serial channel 0 and 1 are identical circuits, configured independently. SIO1 is limited for some function, because both transmit data output (SO1) and receive data input (SI1) are shared with PB2 pin. # 3.16.1 Configuration (a) Configuration of Serial Channel 1 (SIO0) Figure 3.16.1 Configuration of Serial Channel 0 (SIO1) ## 3.16.2 Control Registers The serial channels are controlled by two (2) control registers SC0MOD, SC1MOD and two (2) buffer registers SC0BUF, SC1BUF. SIO0 control register **SCOMOD** 7 6 3 2 0 bit Symbol FF0SI S0RES S0MOD1 S0MOD0 SIFT0 CLK0SI SCK0S SIO0E R R/W R/W R/W R/W Read/Write R/W R/W 0 0 After reset 1 0 0 0 0 0 Shift edge Internal clock Serial clock Function Transfer Serial transferTransfer mode select Serial transfer monitor flag terminate select rate select source enable/ 00: Transmit mode select disable 0: Under 01: Receive mode 0: TBC3 10: ---0: Leading transferring 1: Terminate 10: — (Falling) 0: Internal 0: Disable $(0.8 \mu s)$ 1: Stop 11: Transmit/receive mode 1: Trailing 1: TBC7 clock 1: Enable (Rising) $(6.4 \mu s)$ 1: External clock SIO0 buffer register | SC0BUF | |----------| | (0061H) | | (000111) | (0060H) | F | | 7 | . 6 | 5 | 4 | 3 | . 2 | 1 | 0 | |-----|-------------|-------|-------|-------|-------|-------|-------|----------|-------| | ' [ | bit Symbol | TRB07 | TRB06 | TRB05 | TRB04 | TRB03 | TRB02 | TRB01 | TRB00 | | | Read/Write | | | | R/ | W | | | | | | After reset | * | * | * | * | * | * | *<br>! * | * | <sup>\*:</sup> unknown after reset SIO1 control register SIO1 | SC <sub>1</sub> | MOD | |-----------------|-----| | (006 | 2H) | | D | | 7 | . 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------------|--------------|-----------------------|---------------------------|--------|-------------|----------------|--------------|-----------------| | | bit Symbol | FF1SI | S1RES | S1MOD1 | S1MOD0 | SIFT1 | CLK1SI | SCK1S | SIO1E | | | Read/Write | R | R/W | R/ | W | . R/W | R/W | R/W | R/W | | | After reset | 1 | 0 | 0 | 0 | . 0 | . 0 | 0 | 0 | | | Function | Transfer | ।<br>।Serial transfer | ı<br>¹Transfer mode | select | Shift edge | Internal clock | Serial clock | Serial transfer | | | | monitor flag | terminate | <br> | | select | rate select | source | enable/ | | | | | <br> | 00: Transmit n | node | 1 | 1 | select | disable | | | | 0: Under | 0: — | 01: Receive m | ode | 0: Leading | 0: TBC3 | !<br>! | ;<br>; | | | | transferring | ¦1: Terminate | ¦10: — | | ¦ (Falling) | (0.8 µs) | 0: Internal | 0: Disable | | | | 1: Stop | !<br>! | 11: Transmit/receive mode | | 1: Trailing | 1: TBC7 | clock | 1: Enable | | | | | I<br>I | | | (Rising) | (6.4 µs) | 1: External | i<br>1 | | l | | | l<br>I | l<br>I | | I<br>I | l<br>I | clock | 1<br>1 | The SIO1 can not be used as the transmit/receive mode because the transmit line and receive line (Note): of the SIO1 are connected to the common pin (PB2). SIO1 buffer register SC1BUF (0063H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------|-------|-------|-------|-------|-------|-------|----------| | bit Symbol | TRB17 | TRB16 | TRB15 | TRB14 | TRB13 | TRB12 | TRB11 | TRB10 | | Read/Write | | | | R/ | w | | | | | After reset | * | * | * | * | * | * | * | '<br>' * | <sup>\*:</sup> unknown after reset Figure 3.16.2 Registers for SIO0/SIO1 ### 3.16.3 Operation ## (1) Serial Clock #### ① Clock Source Selection The clock of SIO can be selected from either external clock or internal clock by setting <SCK0S> bit in SC0MOD register (<SCK1S> bit in SC1MOD register for channel 1). ### a. Internal clock The clock rate can be selected from either TBC3 (24/fc) or TBC6 (27/fc) by setting SC0MOD <CLK0SI> (SC1MOD <CLK1SI> for channel 1). Table 3.16.1 shows the maximum transfer rate using the internal clock. The serial clock outputs from SCK0 (SCK1 for channel 1). The serial clock automatically stops after the end of one-frame serial operation, and waits for the next serial operation. The serial clock holds high-level are not transferred. | Table 3.16.1 The Maximum | Transfer Rate by Internal Clock | |---------------------------|---------------------------------| | Internal Clock | Maximum Transfer Rate | | | (at fc = 16 MHz) | | TBC3 (2 <sup>4</sup> /fc) | 1.25 <b>M</b> bps | | TBC6 (2 <sup>7</sup> /fc) | 156.25 kbps | #### b. External clock The clock input to the SCK0 (SCK1 for channel 1) pin is used as the serial clock. To make certain of the shift operation, set SC0MOD <CLK0SI> (SC1MOD <CLK1SI> for channel 1) to 0. Using certain shift operation, it is necessary to set more than 8/fc at both high-level and low-level of the serial clock width. When SC0MOD <SIO0E> (SC1MOD <SIO1E> for channel 1) are set to 0 under transferring and ending the transfer, it is necessary to set more than 16/fc at both high-level and low-level of the serial clock width. Figure 3.16.3 External Clock Input ### 2 Shift Edge Selection The leading or trailing edge shift can be selected by setting <SIFT0> bit in SC0MOD register (<SIFT1> bit in SC1MOD register for channel 1). ### a. Leading edge The serial data are shifted on the leading edge of the serial clock (falling edge of SCK0 or SCK1 pin input/output). ### b. Trailing edge The serial data are shifted on the trailing edge of the serial clock (rising edge of SCK0 or SCK1 pin input/output). (2) Serial Operation Three transfer mode such as transmit, receive and simultaneous transmit-receive modes for serial channel 0 and 1 are selected by SC0MOD <S0MOD1, 0> (SC1MOD <S1MOD1, 0 for channel 1). After reset, SC0MOD <S0MOD1, 0> and SC1MOD <S0MOD1, 0> are cleared to 0, and transmit mode is selected. SIO1 can not be used as simultaneous transmit-receive mode, because both transmit data output (SO1) and receive data input (SI1) are shared with PB2 pin. The following explains the operation in each transfer mode. ### ① Transmit mode After setting transmit mode to the control register, the first transmit data is written into buffer registers SC0BUF or SC1BUF (address 0061H or 0063H in memory). (When transmit mode is not set, transmit data can not be written into the buffer registers.) Setting SC0MOD<SIO0E> or SC1MOD<SIO1E> to 1 starts transmit operation. As the transmit starts, the transmit data area synchronized with the leading edge of the serial clock (falling edge shift), and sequentially output from the SO pin of the LSB side. At the same time, the transmit data area transferred from the buffer registers to the shift registers. Since the buffer registers are empty, the buffer empty interrupt (INTSIO0 or INTSIO1) is generated to request new data. When the next transmit data is written into the buffer register in the interrupt service program, the interrupt request signal is cleared. Note: After the serial transfer enable/disable register SC0CR<SC00E> or SC1CR<SIO1E> are set to 1, undefined data are output from SO pin till the first falling edge of the serial clock. ### (Internal clock mode) In the internal clock mode, When all data are transmitted and no subsequent data is set in the register, the serial clock output stops and a wait begins. Figure 3.16.5 (a) shows the timing chart of internal clock operation in transmit mode (with wait). ### (External clock mode) In the external clock mode, data must be set in the buffer registers before the next data shift operation begins. Therefore the transfer rate is determined by the maximum delay time from interrupt request generation to writing the transmit data into the buffer register in the interrupt service program. Figure 3.16.5 (b) shows the timing chart of external clock operation in transmit mode. To end the transmit operation, set SC0MOD <SIO0E> or SC1MOD <SIO1E> to 0 instead of writing the next transmit data into the buffer register in the interrupt service program. When <SIO0E> or <SIO1E> are cleared to 0, the transmit operation stops at the end of transmitting a data which is shifted out currently. The transmit operation also stops at once by setting SC0MOD <S0RES> or SC1MOD <S1RES> to 1, and <S0RES> or <S1RES> are automatically cleared to 0. The end of transmit operation can be confirmed by reading out the serial transfer monitor flag SC0MOD<FF0SI> or SC1MOD<FF1SI>. (When the transmit operation is finished, the serial transfer monitor flag is set to 1.) In the external clock mode, the serial transfer enable/disable register<SIO0E> or <SIO1E> must be cleared to 0 before starting the next transmit data shift operation. If <SIO0E> or <SIO1E> is not cleared to 0 before the shift operation begins, operations stop after transferring the next transmit data (dummy). Figure 3.16.5 Serial channel Timing Chart in Transmit mode ### 2 Receive Mode After setting the control register to receive mode, setting SC0MOD <SIO0E> or SC1MOD <SIO1E> to 1 makes receive possible. The shift data is synchronized with the serial clock and fetched from the SI pin. When 8-bit data is fetched, it is transferred from the shift register to the buffer register, and buffer-full interrupt INTSIO0 or INTSIO1 is generated to request a read of receive data. The receive data are read from the buffer register in the interrupt service program. The interrupt request signal is cleared when they are read. ### (Internal clock mode) In the internal clock mode, if the previous receive data has not been read from the buffer register after the next data is fetched, the serial clock stops and waits until the previous data is read. Figure 3.16.6 (a) shows the timing chart of internal clock operation in receive mode (leading edge shift with wait). Figure 3.16.7 (a) shows the timing chart of internal clock operation in receive mode (trailing edge shift with wait). ## (External clock mode) In the external clock mode, as the shift operation synchronizes with supplied external clock, it is necessary to read from the buffer register before transferring the next receive data. If the previous data has not read, the receive data will not be transferred to the buffer register, and subsequent receive data will be canceled. The maximum transfer rate of the external clock operation is determined by the maximum delay time from the generation of interrupt requests to receive data read. Figure 3.16.6 (b) shows the timing chart of external clock operation in receive mode (leading edge shift). Figure 3.16.7 (b) shows the timing chart of external clock operation in receive mode (trailing edge shift). In the receive mode, either leading edge shift or trailing edge shift can be selected. When the leading edge is used for shifting, because data is fetched at the leading edge of the serial clock, the first shift data must already be input to the SI pin when the initial serial clock pulses are applied at transfer start. To end the receive operation, set the serial transfer enable/disable register (SC0MOD) <SIO0E> or (SC1MOD) <SIO1E> to 0. When the serial transfer enable/disable register <SIO0E> or <SIO1E> are cleared to 0, the receive operation ends after 8 bits of receive data are fetched. Don't read the buffer register after clearing the serial transfer enable/disable register. Setting the serial transfer enable/disable register (SC0MOD) <S0RES> or (SC1MOD) <S1RES> are set to 1 stops the serial transfer at once and <SIO0E> or <SIO1E> are cleared to 0. Note: If the transfer mode is switched, the contents of the buffer registers can not be kept. If necessary to switch the transfer mode, the transfer mode should be switched after clearing the transfer enable/disable register <SIO0E> or <SIO1E> to 0 and reading out the last bit of the receive data. The end of receive can be confirmed by reading serial transfer monitor flags SC0MOD <FF0SI> or SC1MOD <FF1SI>. Figure 3.16.6 Serial channel Timing chart in Receive mode (Leading edge) Figure 3.16.7 Serial channel Timing chart in Receive mode (Trailing edge) ### 3 Simultaneous Transmit / Receive Mode The first transmit data are written into the buffer register SC0BUF (SC1BUF for channel 1) after the simultaneous transmit-receive mode is set to the control register. Then, setting the serial channel control register SC0MOD <SIO0E> or SC1MOD <SIO1E> to 1 enables transmitting or receiving data. The transmit data area output from the SO pin at the leading edge of the serial clock. The receive data area fetched from the SI pin at the trailing edge of the serial clock. When the 8-bit receive data are fetched, the data are transferred from the shift register to the buffer register, and the interrupt request (INTSIO0 or INTSIO1) is generated to request receive data read. In the interrupt service program, the received data are read out from the buffer register and the next transmit data are written into the buffer register. Note: After the serial transfer enable/disable register SC0MOD <SIO0E> or SC1MOD <SIO1E> is set to 1, undefined data are output from SO pin till the first falling edge of serial clock. SIO1 can not be used as simultaneous transmit / receive mode. ### (Internal clock mode) In the internal clock mode, a wait begins until the receive data are read and the next transmit data are written into the buffer register. Figure 3.16.8 (a) shows the timing chart of internal clock operation is simultaneous transmit / receive mode. ### (External clock mode) In the external clock mode, the receive data must be read and the next transmit data written before the next shift operation, because the shift operation is synchronized with external supplied clock pulses. The maximum transfer rate of the external clock operation is determined by the maximum delay time from interrupt request generation to receive data read and transmit data write. Figure 3.16.8 (b) shows the timing chart of external clock operation in simultaneous transmit/receive mode. Since the buffer registers are used for both transmit and receive data, always ensure that transmit data is written after 8 bits of receive data are read. To end the simultaneous transmit-receive operation, clear the serial transfer register<SIO0E> or <SIO1E> to 0 When the serial transfer enable/disable register<SIO0E> or <SIO1E> is cleared to 0, the simultaneous transmit-receive operation ends after the 8 bits of receive data are fetched. Don't read the buffer register after clearing the serial transfer enable/disable register. In the simultaneous transmit-receive mode, the serial transfer operation ends just after setting <S0RES> or <S1RES> to 1, and the serial transfer enable/disable register <SIO0E> or <SIO1E> is cleared to 0. The end of simultaneous transmit-receive can be confirmed by reading the serial transfer monitor flags<FF0SI> or <FF1SI> in program. (b) External clock operation in simultaneous transmit/receive mode Figure 3.16.8 Serial channel Timing chart in Simultaneous Transmit / Receive mode ## 3.17 Serial Channel (UART) TMP93C071 has an asynchronous serial I/F (UART). The UART has the following operation modes. In mode 1 and mode 2, a parity bit can be added. Mode 3 has wake-up function for making the master controller start slave controllers in serial link (multi-controller system). Figure 3.17.1 shows the data format (for one frame) in each mode. Mode 2 (8-bit UART mode) Mode 3 (9-bit UART mode) When bit 8 = 0, data is denoted. Figure 3.17.1 Data Formats The UART has a buffer register for transmitting and receiving operations, in order to temporarily store transmitted or received data, so that transmitting and receiving operations can be done independently (full duplex). The receiving data register is of a double buffer structure to prevent the occurrence of overrun error and provides one frame of margin before CPU reads the received data. The receiving data register stores the already received data while the buffer register receives the next frame data. By using $\overline{\text{CTS}}$ and $\overline{\text{RTS}}$ (there is no $\overline{\text{RTS}}$ pin, so any 1 port must be controlled by software), it is possible to halt data send until the CPU finishes reading receive data every time a frame is received. (Handshake function) A check function is added not to start the receiving operation by error start bits due to noise. The channel starts receiving data only when the start bit is detected to be normal at least twice in three samplings. When the transmission buffer becomes empty and requests the CPU to send the next transmission data, or when data is stored in the receiving data register and the CPU is requested to read the data, INTTX or INTRX interrupt occurs. Besides, if an overrun error, parity error, or framing error occurs during receiving operation, flag SC2CR <OERR, PERR, FERR> will be set. The UART includes a special baud rate generator, which can set any baud rate by dividing the frequency of 4 clocks (TBC1, TBC2, TBC3, and TBC4) from the time base counter (TBC). In addition, the UART can be operated by using the timeout output of the timer counter 0 (TC0). ## 3.17.1 Control Registers The UART is controlled by 3 control registers SC2CR, SC2MOD and BR2CR. Transmitted and received data are stored in register SC2BUF. Figure 3.17.2 Serial Mode Control Register (SC2MOD) Note1: As all error flags are cleared after reading, do not test only a single bit with a bit-testing instruction. Figure 3.17.3 Serial Control Register (SC2CR) Note: Bit 6 of BR2CR is read as 1. Figure 3.17.4 Serial Channel Control (BR2CR) | SC2BUF | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|-------------|-----|-----|-----|-----------------|----------------|-----|-------|-----| | (0067H) | bit Symbol | RB7 | RB6 | RB5 | RB4 | RB3 | RB2 | ¦ RB1 | RB0 | | ( | | TB7 | TB6 | TB5 | TB4 | TB3 | TB2 | i TB1 | TB0 | | Prohibit | Read/Write | | | R | (Receiving) / V | V(Transmission | n) | | | | read- | After reset | | | | Unde | fined | | | | | modify-<br>write | | | | | | | | | | Figure 3.17.5 Serial Transmission / Receiving Buffer Registers (SC2BUF) # 3.17.2 Configuration Figure 3.17 (6) shows the block diagram of the serial channel 0. Figure 3.17.6 Block Diagram of the UART ### ① Baud Rate Generator Baud rate generator comprises a circuit that generates transmission and receiving clocks to determine the transfer rate of the UART. The input clock to the baud rate generator, TBC1, TBC2, TBC3, or TBC4 is generated by the time base counter (TBC). One of these input clocks is selected by the baud rate generator control register BR2CR<BR0CK1, 0>. The baud rate generator includes a 4-bit frequency divider, which divides frequency by 1 to 16 values to determine the transfer rate. How to calculate a transfer rate when the baud rate generator is used is explained below. Accordingly, when source clock fc is 12.288 MHz, input clock is TBC3 (fc/16), and frequency divisor is 5, the transfer rate in UART becomes as follows: Baud rate = $$\frac{\text{fc/16}}{5} \div 16$$ =12.288×10<sup>6</sup>÷16÷5÷16=9600 (bps) The maximum baud rate of this baud rate generator is 312.5 kbps (fc = 20 MHz). 19.531 Table 3.17.1 shows an example of the transfer rate. 16 Also with 8-bit timer 0 (TC0), the UART can get a transfer rate. Table 3.17.1 Selection of UART Transfer Rate (1) (When Baud Rate Generator is used.) Unit (Kbps) fc[MHz] Input clock TBC1 TBC2 TBC3 TBC4 Divider (4/fc) (8/fc) (16/fc) (32/fc)12.288000 5 38.400 19.200 9.600 4.800 10 19.200 9.600 4.800 2.400 19.660800 2 153.600 76.800 38.400 19.200 19.200 4 76.800 38.400 9.600 8 38.400 19.200 9.600 4.800 16 19.200 9.600 4.800 2.400 20.000000 2 156.250 78.125 39.063 19.531 39.063 4 78.125 19.531 9.766 19.531 8 39.063 9.766 4.883 9.766 4.883 2.441 ### ② Serial Clock Generation Circuit This circuit generates the basic clock for transmitting and receiving data. According to the setting of SC2MOD <SC1, 0>, the above baud rate generator clock, internal clock fc/2 (max 625 kbps at fc = 20 MHz), or the match detect signal from timer 0, will be selected to generate the basic clock SIOCLK. ### ③ Receiving Counter The receiving counter is a 4-bit binary counter and counts up by SIOCLK clock. 16 pulses of SIOCLK are used for receiving 1 bit of data, and the data bit is sampled three times at 7th, 8th and 9th clock. With the three samples, the received data is evaluated by the rule of majority. For example, if the sampled data bit is 1, 0 and 1 at 7th, 8th and 9th clock respectively, the received data is evaluated as 1. The sampled data 0, 0 and 1 is evaluated that the received data is 0. ### Receiving Control The receiving control has a circuit for detecting the start bit by the rule of majority. When two or more "0" are detected during 3 samples, it is recognized as start bit and the receiving operation is started. Data being received are also evaluated by the rule of majority. ## S Receiving Buffer To prevent overrun error, the receiving buffer has a double buffer structure. Received data are stored one bit by one bit in the receiving buffer 1 (shift register type). When 7 bits or 8 bits of data is stored in the receiving buffer 1, the stored data are transferred to the receiving buffer 2 (SC2BUF), generating an interrupt INTRX. The CPU reads only receiving buffer 2 (SC2BUF). Even before the CPU reads the receiving buffer 2 (SC2BUF), the received data can be stored in the receiving buffer 1. However, unless the receiving buffer 2 (SC2BUF) is read before all bits of the next data are received by the receiving buffer 1, an overrun error occurs. If an overrun error occurs, the contents of the receiving buffer 1 will be lost, although the contents of the receiving buffer 2 and SC2CR<RB8> is still preserved. The parity bit added in 8-bit UART mode and the most significant bit (MSB) in 9-bit UART mode are stored in SC2CR<RB8>. When in 9-bit UART mode, the wake-up function of the slave controllers is enabled by setting SC2MOD<WU> to 1, and interrupt INTRX occurs only when SC2CR<RB8> is set to 1. ### **©** Transmission Counter Transmission counter is a 4-bit binary counter and counts by SIOCLK clock, generating TxDCLK every 16 clock pulses. Figure 3.17.7 Generation of transmission Clock ### **Transmission Controller** When transmission data are written in the transmission buffer sent from the CPU, transmission starts at the rising edge of the next TxDCLK, generating a transmission shift clock TxDSFT. ### **Handshake Function** The serial channels use the $\overline{\text{CTS}}$ pin to transmit data in units of frames, thus preventing an overrun error. Use SC2MOD<CTSE> to enable or disable the handshake function. When CTS goes high, data transmission is halted after the completion of the current transmission and is not restarted until CTS returns to low. An INTTX interrupt is generated to request the CPU for the next data to transmit. When the CPU write the data to the transmit buffer, processing enters standby mode. An RTS pin is not provided, but a handshake function can easily be configured if the receiver sets any port assigned to the RTS function to high (in the receive interrupt routine) after data receive, and requests the transmitter to temporarily halt transmission. Figure 3.17.8 Handshake Function Note1: If the CTS signal rises during transmission, the next data is not sent after the completion of the current transmission. Note2: Transmission starts at the first TxDCLK clock fall after the CTS signal falls. Figure 3.17.9 Timing of CTS (Clear to send) ### ® Transmission Buffer Transmission buffer (SC2BUF) shifts out and sends the transmission data written from the CPU. When all bits are shifted out, the transmission buffer becomes empty and generates INTTX interrupt. ### Parity Control Circuit When serial channel control register SC2CR<PE>is set to 1, it is possible to transmit and receive data with parity. However, parity can be added only in 7-bit UART or 8-bit UART mode. With SC2CR <EVEN> register, even (odd) parity can be selected. For transmission, parity is automatically generated according to the data written in the transmission buffer SC2BUF, and data are transmitted after being stored in SC2BUF<TB7> when in 7-bit UART mode, while in SC2MOD <TB8> when in 8-bit UART mode. <PE> and <EVEN> must be set before transmission data are written in the transmission buffer. For receiving, data are shifted in the receiving buffer 1, and parity is added after the data are transferred in the receiving buffer 2 (SC2BUF), and then compared with SC2BUF<RB7> when in 7-bit UART mode and with SC2MOD<RB8> when in 8-bit UART mode. If they are not equal, a parity error occurs, and SC2CR<PERR> flag is set. ## ® Error Flag Three error flags are provided to increase the reliability of receiving data. ### 1. Overrun error <OERR> If all bits of the next data are received in receiving buffer 1 while valid data are stored in receiving buffer 2 (SC2BUF), an overrun error will occur. ## 2. Parity error <PERR> The parity generated for the data shifted in receiving buffer 2 (SC2BUF) is compared with the parity bit received from RxD pin. If they are not equal, a parity error occurs. ## 3. Framing error <FERR> The stop bit of received data is sampled three times around the center. If the majority is "0", a framing error occurs. # 1 Generating Timing ### Receiving | Mode | 9 bit | 8 bit + parity | 8 bit, 7 bit + parity, 7 bit | |----------------------|--------------------|--------------------|------------------------------| | | (Note) | (Note) | | | Interrupt timing | Center of last bit | Center of last bit | Center of stop bit | | | (Bit 8) | (parity bit) | | | Framing error timing | Center of stop bit | Center of stop bit | Center of stop bit | | Parity error timing | _ | Center of last bit | Center of stop bit | | | | (parity bit) | | | Overrun error timing | Center of last bit | Center of last bit | Center of stop bit | | | (Bit 8) | (parity bit) | | Note: In 9-bit and 8-bit + parity modes, interrupts coincide with the ninth bit pulse. Thus, When servicing the interrupt, it is necessary to wait for a 1-bit period (to allow the stop bit to be transferred) to allow checking for a framing error. Transmitting | Mode | 9 bit | 8 bit + parity | 8 bit, 7 bit + parity, 7 bit | |------------------|-------|----------------|--------------------------------------| | Interrupt timing | 1 | | Just before last bit is transmitted. | ### 3.17.3 Operational Description ## (1) Mode 1 (7-bit UART Mode) 7-bit mode can be set by setting serial channel mode register SC2MOD <SM1,0> to "01". In this mode, a parity bit can be added, and the addition of a parity bit can be enabled or disabled by serial channel control register SC2CR<PE>, and even parity or odd parity is selected by SC2CR <EVEN> when <PE> is set to "1" (enable). Setting example: When transmitting data with the following format, the control registers should be set as described below. ## (2) Mode 2 (8-bit UART Mode) 8-bit UART mode can be specified by setting SC2MOD<SM1,0> to "10". In this mode, parity bit can be added, the addition of a parity bit is enabled or disabled by SC2CR<PE>, and even parity or odd parity is selected by SC2CR<EVEN> when <PE> is set to "1" (enable). Setting example: When receiving data with the following format, the control register should be set as described below. ## Main setting ``` 6 5 4 3 2 Select P71 (RxD) as the input pin. P7CR 0 _ X SC2MOD 0 Х 1 0 0 1 Enable receiving in 8-bit UART mode. SC2CR 0 Х Χ Χ 0 0 Add an odd parity. 1 0 0 0 Set transfer rate at 9600 bps. BR2CR Х 1 0 1 1 0 Enable INTRX interrupt and set interrupt level 4. <u>I</u>NTRXTX 0 ``` ### Interrupt processing ``` Acc ← SC2CR AND 00011100 } if Acc ≠ 0 then ERROR Acc ← Check for error. Acc ← SC2BUF Read the received data. Note: X; don't care —; no change ``` ## (3) Mode 3 (9-bit UART Mode) 9-bit UART mode can be specified by setting SC2MOD<SM1,0> to 11. In this mode, parity bit cannot be added. For transmission, the MSB (9th bit) is written in SC2MOD <TB8>, while in receiving it is stored in SC2CR<RB8>. For writing and reading the buffer, the MSB is read or written first then SC2BUF. ## Wake-up function In 9-bit UART mode, the wake-up function of slave controllers is enabled by setting SC2MOD<WU> to 1. The interrupt INTRX occurs only when<RB8> = 1. Note: TxD pin of the slave controllers must be in open drain output mode with ODCR1. Figure 3.17.10 Serial Link Using Wake-Up Function Protocol - ① Select the 9-bit UART mode for the master and slave controllers. - ② Set SC2MOD<WU> bit of each slave controller to "1" to enable data receiving. - ③ The master controller transmits one-frame data including the 8-bit select code for the slave controllers. The MSB (bit 8)<TB8> is set to 1. - Each slave controller receives the above frame, and clears WU bit to "0" if the above select code matches its own select code. - ⑤ The master controller transmits data to the specified slave controller whose SC2MOD<WU> bit is cleared to "0". The MSB (bit 8)<TB8> is cleared to 0. - ⑤ The other slave controllers (with the <WU> bit remaining at "1") ignore the receiving data because their MSBs (bit 8 or <RB8>) are set to 0 to disable the interrupt INTRX. - The slave controllers (<WU> = 0) can transmit data to the master controller, and it is possible to indicate the end of data receiving to the master controller by this transmission. Setting example: To link two slave controllers serially with the master controller, and use the internal clock fc/2 as the transfer clock. · Setting the master controller ### Main ``` P7FC X 1\ Select P70 as TxD pin and P71 as RxD pin. 0 P7CR -1] 0 0 INTRXTX 0 1 Enable INTTX and set the interrupt level 4. Enable INTTX and set the interrupt level 5. SC2MOD Set fc/2 as the transmission clock in 9-bit UART mode. 0 0 1 0 1 1 SC2BUF 0 0 0 0 0 Set the select code for slave controller 1. ``` ### INTTX interrupt ``` SC2MOD ← 0 - - - - - - Sets TB8 to 0. SC2BUF ← * * * * * * Set data for transmission. ``` ### setting the slave controller 2 Main ``` X ODCR1 x - Select P71 as RxD pin and P70 as TxD pin (open drain output). P7FC Х 1 \leftarrow P7CR 0 1 0 1 0 1 0 1 0 Enable INTRX and INTTX. INTRXTX 1 _SC2MOD 0 Set <WU> to 1 in the 9-bit UART transmission mode with transfer clock fc/2. ``` ## INTRX interrupt ``` Acc ← SC2BUF if Acc = Select code Then SC2MOD ← - - - 0 - - - Clear <WU> to 0. ``` ## 3.18 Serial Bus Interface (I2CBUS) The TMP93C071 has a 1-channel I<sup>2</sup>C bus I/F (I2CBUS). I2CBUS operates as a multi-master, and controls two bus I/F (P73/SDA0, P74/SCL0) and (PB4/SDA1, PB5/SCL1)). At the master mode, the I<sup>2</sup>CBUS can transfer many byte data continuously with the micro DMA. ## 3.18.1 Configuration Figure 3.18.1 Serial Bus Interface (I<sup>2</sup>CBUS) ## 3.18.2 Serial Bus Interface (I2CBUS) Control The following registers are used for control and operation status monitoring when using the serial bus interface (I<sup>2</sup>CBUS). - I<sup>2</sup>CBUS control register 1 (I2CCR1) - I<sup>2</sup>CBUS control register 2 (I2CCR2) - I<sup>2</sup>CBUS control register 3 (I2CCR3) - I<sup>2</sup>CBUS control register 4 (I2CCR4) - I<sup>2</sup>CBUS data buffer register (I2CDBR) - I<sup>2</sup>C bus address register (I2CAR) - I<sup>2</sup>CBUS status register (I2CSR) Refer to Section 3.18.4 I<sup>2</sup>Cbus Mode Control. ## 3.18.3 The Data Formats in the I<sup>2</sup>CBus The data formats when using the TMP93C071 in the I<sup>2</sup>Cbus are shown below. ### (a) Addressing format # (b) Addressing format (With restart) ## (c) Free data format (Notes) S: Start condition R/W: Direction bit ACK: Acknowlege bit P: Stop condition Figure 3.18.2 Data format in the I<sup>2</sup>CBus Mode ## 3.18.4 I2CBus Control Figure 3.18.3 Register for I<sup>2</sup>CBus Note 1: This register functions as the I2CSR by reading. Note 2: Switch a mode to the port mode after confirming that the bus is free. Switch a mode to the I<sup>2</sup>C bus mode after confirming that input signals via port are high level. Figure 3.18.4 Register for I<sup>2</sup>CBus Note: Bits 7 to 2 of this register function as the I2CCR2 by writing. Figure 3.18.5 Register for I<sup>2</sup>CBus I<sup>2</sup>CBUS control register 3 | I2CCR3 | | |---------|--| | (0085H) | | | Tobor dominor register o | | | | | | | | | | | | | |--------------------------|------------|---------------|---------------|---------|---------------------|---------|---------|---|-----|--------|---------------------|--| | | 7 | 6 | 5 | i | 4 | i | 3 | i | 2 | 1 | 0 | | | bit Symbol | DMAEN | DV4 | DV3 | - 1 | DV2 | ¦ | DV1 | 1 | DV0 | _ | SWRST | | | Read/Write | R/W | 1<br>1 | | | W | Ť | | , | | T<br>I | R/W | | | After reset | 0 | . 0 | <u> </u> | . ! | 0 | ! | 0 | ! | 0 | ! * | 0 | | | Function | micro DMA | Setting N-div | vider for gen | erating | transfer | clock | source. | | | i | I <sup>2</sup> CBUS | | | | transfer | 00000: (Res | erved) | 10000 | ): 7 <b>4</b> .6 (r | า = 16) | 1 | | | į | Software | | | | mode is | 100001: (Res | erved) | 10001 | l: 70.4 (r | n = 17) | i. | | | i | Reset | | | | enabled | 00010: 454. | 5 (n = 2) | 10010 | D: 66.7 (r | n = 18) | ) | | | 1 | | | | | | 00011: 333. | 3 (n = 3) | 10011 | l: 63.3 (r | า = 19) | , | | | 1 | | | | | 0: Disable | l00100: 263.: | 2 (n = 4) | 10100 | ): 60.2 (r | n = 20) | ) | | | 1 | | | | | | 00101: 217.4 | | | l: 57.5 (r | | | | | 1 | | | | | | 00110: 185.: | 2 (n = 6) | 10110 | ): <b>54</b> .9 (r | n = 22) | | | | 1 | | | | | | 00111: 161. | 3 (n = 7) | 10111 | l: 52.6 (r | n = 23) | ) | | | 1 | | | | | | 01000: 142. | 9 (n = 8) | 11000 | ): 50.5 (r | n = 24) | ) | | | 1 | | | | | | 101001: 128.: | 2 (n = 9) | 11001 | l: 48.5 (r | n = 25) | ) | | | 1 | | | | | | 01010: 116. | 3 (n = 10) | 11010 | D: 46.7 (r | n = 26) | • | | | | | | | | | 01011: 106.4 | 4 (n = 11) | 11011 | l: 45.0 (r | n = 27) | • | | | 1 | | | | | | 01100: 98.0 | (n = 12) | 11100 | ): 43.5 (r | n = 28) | ) | | | 1 | | | | | | 01101: 90.9 | (n = 13) | | l: 42.0 (r | | | | | 1 | | | | | | 01110: 84.7 | (n = 14) | | ): 40.7 (r | | | | | 1 | | | | | | 01111: 79.4 | (n = 15) | 11111 | l: 39.4 (r | n = 31) | ) | | | 1<br>1 | | | | | | (kHz) @20 N | | | ` | | | | | 1 | | | → I<sup>2</sup>CBUS Software Reset Figure 3.18.6 I2CCR4 (0086H) Figure 3.18.7 modifywrite I2CAR Prohibit modify- read- write | | Serial Bus Interface Data Buffer Register | | | | | | | | | | | | |----------|-------------------------------------------|-----|-----|-----|-------------|------------|-----|-----|-----|--|--|--| | I2CDBR | | 7 | 6 | 5 | 4 | 3 | 2 | i 1 | i 0 | | | | | (0082H) | bit Symbol | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | | | | Prohibit | Read/Write | | | | R (receive) | / W (send) | | | | | | | | read- | After reset | | | | Unde | fined | | | | | | | Note: When writing the send data, start from the MSB (bit7) Figure 3.18.8 Registers for I<sup>2</sup>C Bus Mode ## (1) Acknowledge mode specification Set I2CCR1<ACK> to 1 for operation in the acknowledge mode. The TMP93C071 generates an additional clock pulse for an acknowledge signal when operating in the master mode. In the transmitter mode during the clock pulse cycle, the SDA pin is released in order to receive the acknowledge signal from the receiver. In the receiver mode during the clock pulse cycle, the SDA pin is set to the low level in order to generate the acknowledge signal. Set <ACK> to 0 for operation in the non-acknowledge mode. The TMP93C071 does not generate a clock pulse for the acknowledge signal when operating in the master mode. ### (2) Number of transfer bits I2CCR1<BC2 to 0> are used to select a number of bits for transmitting and receiving data. Since <BC2 to 0> are cleared to 000 as a start condition, a slave address and direction bit transmissions are executed in 8 bits. Other than these, <BC2 to 0> retain a specified value. ### (3) Serial clock #### Clock source I2CCR3 <DV4 to 0> are used to select a maximum transfer frequency output on the SCL pin in the master mode. Figure 3.18.9 Clock Souce ## ② Clock synchronization In the I<sup>2</sup>C bus mode, in order to wired-AND a bus, a master device which drives a clock line to low-level, in the first place, invalidates a clock pulse of another master device which generates a high-level clock pulse. The master device with a high-level clock pulse needs to detect the situation and implement the following procedure. The TMP93C071 has a clock synchronization function for normal data transfer even when more than one master exists on a bus. The example explains clock synchronization procedures when two masters simultaneously exist on a bus. Figure 3.18.10 Clock Synchronization As Master A drives the internal SCL output to the low level at point "a", the SCL line of the bus becomes the low level. After detecting this situation, Master B resets a counter of an own clock pulse and sets the internal SCL output to the low level. Master A finishes counting low-level width of an own clock pulse at point "b" and sets the SCL pin to the high level. Since Master B holds the SCL line of the bus at the low level, Master A waits for counting high-level width of an own clock pulse. After Master B sets the internal SCL output to the high level at point "c" and Master A detects the SCL line of the bus at the high level and starts counting high-level of an own clock pulse. The clock pulse on the bus is determinded by the master device with the shortest high-level period and the master device with the longest low-level width from among those master devices connected to the bus. ## (4) Slave address and Address recognition mode specification When the TMP93C071 is used as a slave device, set the slave address (I2CAR <SA6 to 0>) and I2CAR <ALS>. Set <ALS> to 0 for the address recognition mode. #### (5) Master/slave selection Set I2CCR2 <MST> to 1 for operating the TMP93C071 as a master device. <MST> is cleared to 0 by the hardware after a stop condition on a bus is detected or arbitration is lost. #### (6) Transmitter/receiver selection Set I2CCR2 <TRX> to 1 for operating the TMP93C071 as a transmitter. Set <TRX> to 0 for operation as a receiver. When data with an addressing format is transferred in the slave mode, when a slave address with the same value that an I2CAR or the GENERAL CALL is received (all 8-bit data are 0 after the start condition), <TRX> is set to 1 by the hardware if the direction bit ( $R/\overline{W}$ ) sent from the master device is 1, and is set to 0 by the hardware if the bit is 0. In the master mode, after the acknowledge signal is returned from the slave device, <TRX> is set to 0 by the hardware if a transmitted direction bit is 1, and set to 1 by the hardware if it is 0. When the acknowledge signal is not returned, the current condition is maintained. <TRX> is cleared to 0 by the hardware after the stop condition on the I<sup>2</sup>C bus is detected or arbitration is lost. ### (7) Start/Stop Condition generation When I2CCR2 <BB> is 0, the start condition and 8-bit data are output by writing 1 to I2CCR2<MST, TRX, BB, PIN>. It is necessary to set 1 to I2CCR1<ACK> beforehand. Figure 3.18.11 Start Condition Generation and Slave Address Generation When I2CCR2 <BB> is 1, a sequence of generating the stop condition is started by writing 1 to <MST, TRX, PIN> and 0 to <BB>. Do not modify the contents of <MST, TRX, BB, PIN> until the stop condition is generated on a bus. Figure 3.18.12 Stop Condition Generation The bus condition can be indicated by reading the contents of <BB>. <BB> is set to 1 when the start condition on a bus is detected, and is set to 0 when the stop condition is detected. ## (8) Cancel interrupt service request When the serial bus interrupt request (INTI2CB) occurs, I2CCR2 <PIN> is set to 0. During the time that <PIN> is 0, the SCL pin is driven to the low level. <PIN> is set to 0 when 1-word of data is transmitted or received. Either writing/reading data to/from the I2CDBR sets <PIN> to 1. The time from <PIN> being set to 1 until the SCL pin is released takes t<sub>LOW</sub>. In the address recognition mode (I2CAR <ALS> = 0), <PIN> in the slaver mode is set to 0 when the received slave address is the same as the value set at the I2CAR or when the GENERAL CALL is received (all 8-bit data are 0 after the start condition). Although I2CCR2 <PIN> can be set to 1 by the program, <PIN> is not set to 0 when 0 is written. ## (9) Serial bus interface operation mode selection I2CCR2 <SBIM1, 0> is used to specify the serial bus interface operation mode. Set <SBIM1, 0> to "10" when used in the I<sup>2</sup>C bus mode after confirming that input signal via port is high level. Switch a mode to port after making sure 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 the transferred data. A 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 A and Master B output the same data until point "a". After Master A outputs "L" and Master B "H", the SDA line of the bus is wire-AND and the SDA line is driven to the low level by Master A. When the SCL line of the bus is pulled up at point "b", the slave device reads data on the SDA line, that is, data in Master A. A data transmitted from Master B becomes invalid. The state in Master B is called "arbitration lost". B master device which loses arbitration releases the SDA 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 3.18.13 Arbitration Lost The TMP93C071 compares levels of the SDA line of the bus with those of the TMP93C071 internal SDA output at the rising edge of the SCL line. If the levels are unmatched, arbitration is lost and I2CSR <AL> is set to 1. When <AL> is set to 1, <MST, TRX> are set to 0, the mode is switched to the slave receiver mode, and the TMP93C071 stops the clock pulse. <AL> is set to 0 by writing/reading data to/from the I2CDBR or writing data to the I2CCR2. Figure 3.18.14 Example of when TMP93C071 is a Master device #### (11) Slave address match detection monitor I2CSR <AAS> is set to 1 in the slave mode, in the address recognition mode (I2CAR <ALS> = 0) when receiving the GENERAL CALL or the slave address with the same value that is set to the I2CAR. When <ALS> is 1, <AAS> is set to 1 after receiving the first 1-word of data. <AAS> is set to 0 by writing/reading data to/from a data buffer register. ## (12) GENERAL CALL detection monitor I2CSR<AD0> is set to 1 in the slave mode, when the GENERAL CALL is received (all 8-bit data are 0 after the start condition). <AD0> is set to 0 when the start or stop condition is detected on a bus. ## (13) Last received bit monitor The SDA line value stored at the rising edge of the SCL line is sent to I2CSR <LRB>. In the acknowledge mode, immediately after the INTI2CB interrupt request is generated, the acknowledge signal is read by reading the contents of <LRB>. ## (14) Software Reset Function Software reset function is used to initialize the I<sup>2</sup>CBUS which is rocked by external noise, etc. When I2CCR3 <SWRST> is set to 1, the internal reset signal pulse is generated and inputted into the I<sup>2</sup>CBUS circuit. All command registers and state registers are initialized to initial values. <SWRST> is automatically set to 0 after the I<sup>2</sup>CBUS circuit is initialized. ### (15) I2CBUS Data Buffer Register (I2CDBR) The I2CDBR register can read out the receiving data and write the sending data. After the start condition generated in the master mode, set the slave address and the direction bit in this register. ## (16) I<sup>2</sup>C BUS Address Register (I2CAR) I2CAR<SA6 to 0> sets the slave address when the TMP93C071 are operated as the slave devices. Setting I2CAR<ALS> = 0, the slave address output from master device is recognized, and the data format is changed to the addressing format. Setting I2CAR<ALS> = 1, the slave address is not recognized, and the data format is changed to the free data format. ## 3.18.5 Data Transfer in I2C Bus #### (1) Device Initialization First, set I2CCR3 <DV4:0>, I2CCR1 <ACK, CHS>. Set the slave address <SA6 to 0> and <ALS> to I2CAR (<ALS> = 0 when the addressing format). Subsequently, set 0 to<MST, TRX, BB>; 1 to <PIN>; 10 to <SBIM1, 0>; and 0 to bits 0 and 1 in the I2CCR2. The slave receiver mode is set. ### (2) Start Condition and Slave Address Generation #### ① In cace of the master mode In case of the master mode, the start condition and the slave address are generated according to the following procedures. First, confirm a bus free status (when <BB>=0). Set<ACK> to 1 and specify the slave address and the direction bit to be transmitted to the I2CDBR. When <BB> is 0 and I2CCR2<MST, TRX, BB, PIN> is 1111, the start condition is generated. Subsequently, nine clocks are output from the SCL pin. Eight clocks output the slave address which is set in the I2CDBR and the direction bit. The SDA line is released at the ninth clock and the acknowledge signal is received. The INTI2CB interrupt request occurs at the ninth falling edge of the SCL clock cycle, and <PIN> is 0. The SCL pin is driven to the low level while <PIN> is 0. When an interrupt request occurs, <TRX> changes according to the direction bit only when an acknowledge signal is returned from the slave device. #### ② In case of the slave mode In case of the slave mode, the start condition and the slave address are received. After the start condition output from the master device is received, the slave address and the direction bit are received until the eighth clock. When the GENERAL CALL or the same address as the slave address set in I2CAR is received, the SDA line of the bus is set to the low level in the ninth clock, and the acknowledge signal is output. At the falling edge of the ninth clock, the INTI2CB interrupt request is generated and <PIN> is set to 0. Operating the slave mode, the SCL line is set to the low level during <PIN>="0". Only when the acknowledge signal is returned from the slave device, <TRX> is changed by the INTI2CB interrupt request according to the receiving direction bit. Figure 3.18.15 Start Condition Generation and Slave Address Transfer ## (3) 1-word Data Transfer Test <MST> by the INTI2CB interrupt process after a 1-word data transfer is completed, and determine whether the mode is a master or slave. ① When <MST> is 1 (Master mode). Test <TRX> and determine whether the mode is a transmitter or receiver. When <TRX> is 1 (Transmitter mode) Check I2CSR <LRB>. When <LRB> is 1, a receiver does not request data. Implement the process to generate the stop condition (described later) and terminate data transfer. When <LRB> is 0, the receiver requests new data. When the next transmitted data is 8-bits, write it to the I2CDBR. When the next transmitted data is other than 8 bits, set I2CCR <BC2 to 0>, set <ACK> to 1, and write the transmitted data to the I2CDBR. After writing the data, <PIN> becomes 1, the serial clock pulse is generated for transferring a new 1-word of data from the SCL pin, and then the 1-word data is transmitted. After the data is transmitted, the INTI2CB interrupt request occurs. <PIN> becomes 0 and the SCL pin is set to the low level. If the data to be transferred is more than one word in length, repeat the procedures from <LRB> test mentioned above. Figure 3.18.16 Example of when <BC2 to 0> = 000 <ACK> = 1 (Transmitter mode) When <TRX> is 0 (Receiver mode) When the next transmitted data is 8 bits, write the transmitted data to the I2CDBR. When the next transmitted data is other than 8 bits, set I2CCR1<BC2 to 0> again. Set <ACK> to 1 and read the received data from the I2CDBR to release the SCL line. (The read data is undefined immediately after the slave address is set.) After the data is read, <PIN> becomes 1. The TMP93C071 outputs the serial clock pulse to the SCL pin to transfer new 1-word of data and sets the SDA pin to 0, when the acknowledge signal is set to low level at the final bit. The INTI2CB interrupt request then occurs and <PIN> becomes 0. The SCL pin is set to the low level. The TMP93C071 outputs a clock pulse for 1-word of data transfer and the acknowledge signal each time that received data is read from the I2CDBR. Figure 3.18.17 Example of when <BC2 to 0> = 000, <ACK> = 1 (Receiver mode) In order to terminate the transmitting data to the transmitter, set <ACK> to 0 before reading data which is 1 word before the last data to be received. The last data does not generate a clock pulse for the acknowledge signal. After the data is transmitted and an interrupt request has occurred, set <BC2 to 0> to "001" and read the data. The TMP93C071 generates a clock pulse for a 1-bit data transfer. Since the master device is a receiver, the SDA line of the bus keeps the high level. The transmitter receives the high-level signal as the ACK signal. The receiver indicates to the transmitter that data transfer is complete. After 1-bit data is received and the interrupt request has occurred, the TMP93C071 generates the stop condition and terminates data transfer. Figure 3.18.18 Termination of data transfer in master receiver mode ## ② When < MST> is 0 (Slave mode) In the slave mode, an INTI2CB interrupt request occurs at the following timings. - When receiving the slave address set in the I2CAR of the TMP93C071 or the GENERAL CALL. - When data transfer is complete after the slave address or the GENERAL CALL is received. In the master mode, the TMP93C071 operates in the slave mode if the arbitration lost is detected. The INTI2CB interrupt request occurs when word data transfer terminates after losing arbitration. When the INTI2CB interrupt request occurs, I2CCR2<PIN> is set to 0, and the SCL pin is driven to the low level. Either reading/writing from/to the I2CDBR or setting<PIN> to 1 releases the SCL pin after taking $t_{LOW}$ time. In the slave mode, the TMP93C071 operates either in the normal slave mode or in the slave mode after losing arbitration. The TMP93C071 tests I2CSR<AL>, <TRX>, <AAS> and <AD0> and implements processes according to the conditions listed in the next table. Table 3.18.1 Operation in the Slave Mode | | | | | Table 3.18.1 Operation in the Slave N | | | | |-------------|-----------|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | <trx></trx> | <al></al> | <aas></aas> | <ad0></ad0> | Conditions | Process | | | | 1 | 1 | 1 | 0 | The TMP93C071 loss arbitration when transmitting a slave address and receives a slave address of which the direction bit sent from the master is 1. | Set the number of bits in 1 word to<br><bc2 0="" to=""> and write transmitted data<br/>to the I2CDBR.</bc2> | | | | | 0 | 1 | 0 | In the slave receiver mode, the TMP93C071 receives a slave address of which the direction bit sent from the master is 1. | | | | | | | 0 | 0 | In the slave transmitter mode, 1-word data is transmitted. | Check <lrb>. If <lrb> is set to 1, set <pin> to 1 since the receiver does not request next data. Then, clear <trx> to 0 release the bus. If <lrb> is set to 0, set the number of bits in a word to <bc2 0="" to=""> and write transmitted data to the I2CDBR since the receiver requests next data.</bc2></lrb></trx></pin></lrb></lrb> | | | | 0 | 1 | 1 | 1/0 | The TMP93C071 loses arbitration when transmitting a slave address and receives a slave address or GENERAL CALL of which the direction bit sent from another master is 0. | Read the I2CDBR for setting <pin> to 1 (reading dummy data) or write 1 to <pin>.</pin></pin> | | | | | | 0 | 0 | The TMP93C071 loses arbitration when transmitting a slave address or data and terminates transferring word data. | | | | | | 0 | 1 | 1/0 | In the slave receiver mode, the TMP93C071 receives a slave address or GENERAL CALL of which the direction bit sent from the master is 0. | | | | | | | 0 | 1/0 | In the slave receiver mode, the TMP93C071 terminates receiving of 1-word data. | Set the number of bits in a word to<br><bc 0="" to=""> and read received data<br/>from the I2CDBR.</bc> | | | ## (4) Stop Condition Generation When I2CSR <BB> is 1, a sequence of generating a stop condition is started by writing 1 to I2CCR2 <MST, TRX, PIN>, and 0 to <BB>. Do not modify the contents of <MST, TRX, BB, PIN> until the stop condition is generated on the bus. When the SCL line of the bus is driven by other device, the TMP93C071 generates the stop condition at rising of SDA pin after the SCL line is released. Figure 3.18.19 Stop Condition Generation ## (5) Restart Restart is used to change the direction of data transfer between the master device and the slave device during transferring data. The following explains how to restart when the TMP93C071 is in the master mode. Specify 0 to I2CCR2 <MST, TRX, BB> and 1 to I2CCR2 <PIN> and release the bus. The SDA pin retains the high level and the SCL pin is released. Since the stop condition is not generated on the bus, the other devices acknowledges the bus to be in a busy state. Check I2CSR <BB> until it becomes "0" to confirm that the SCL pin of the TMP93C071 is released. Check I2CSR <LRB> until it becomes "1" to confirm that the SCL line of the bus is not driven to the low level by other devices. After confirming that the bus stays in a free state, generate the start condition with procedure 3.18.4 (7). In order to meet setup time to restart, it is necessary to take the waiting time at least 4.7 µs from the time of restarting to confirm that the bus is free until the time to generate the start condition, which is set by software. Figure 3.18.20 Timing diagram when restarting the TMP93C071 ## 3.18.6 Micro DMA transfer mode (Only for the master mode) In addition to the transfer function to describe in 3.18.5, the I2CBUS has the data transfer function with the micro DMA for the master mode. (Hereafter, it is called the micro DMA transfer mode) The I2CBUS becomes the micro DMA transfer mode by setting I2CCR3<DMAEN> to "1". The micro DMA transfer mode is a mode which the I2CDBR access while data transfers from the start condition to the stop condition is operated by using the micro DMA function that the CPU core builds it into. The micro DMA transfer function can do a continuous transferring in two or more bytes without increasing the CPU load. ## (1) Function of the micro DMA transfer mode The micro DMA transfer mode has the following functions. - · A continuous transferring once is 16 bytes or less. It is possible to continuously transfer them two or more times every 16 bytes or less. - Two Interrupt request sources (INTI2DMA, INTI2CB) INTI2DMA: Interrupt request signal only for the micro DMA activation. The INTI2DMA occurs when the I2CDBR access is necessary. The reading and writing of the I2CDBR with the micro DMA is activated by the INTI2DMA. INTI2CB: Interrupt request signal of the transfer end/transfer error. The INTI2CB is occurred every end of transferring the number of bytes set by I2CCR4<C3:0>. The INTI2CB is also occurred when the I<sup>2</sup>CBUS has detected the arbitration lost or missing receiving of the acknowledge from the slaver-receiver(acknowledge error). · Acknowledge output control for the master-receiver The acknowledge output which instructs the transmit continuance and end to the slaver-transmitter is controlled. The acknowledge output is controlled by the state of the I2CCR4<C3:0> and <RCONT>. ## (2) Setting for the micro DMA Initializing the micro DMA beforehand when the micro DMA transferring mode is used is necessary. I/O to memory/byte transfer: (for the master- receiver) or Memory to I/O/byte transfer:(for the master-transmitter) are used as transfer mode. "I/O" is set to the I2CDBR address:(0082H). "Memory" is set to the memory address which correspond to the transmission buffer or the reception buffer. The INTI2DMA interrupt is enabled and the vector value "0FH" which corresponds to the INTI2DMA is set in micro DMA start vector register (DMA0V-DMA3V) so that the micro DMA operates for the INTI2DMA interrupt request. TOSHIBA Example 1): The master-transmitter with the micro DMA channel 0 LD XWA, 100H; LDC DMAS0, XWA; transmission buffer = 100H LD XWA, 82H LDC DMAD0, XWA; I2CDBR address LD WA, 0000H LDC DMAC0, WA; transfer counter=65536 times \*1) LD A, 04H LDC DMAM0, A; "Memory to I/O" "byte transfer" LD DMA0V, 0FH; INTI2DMA vector value \*2) LD INTTG1DMA, 6xH; INTI2DMA interrupt enable (Level 6) Example 2): The master-receiver with the micro DMA channel 1 LD XWA, 82H LDC DMAS1, XWA; I2CDBR address LD XWA, 200H; LDC DMAD1, XWA; reception buffer=200H LD WA, 0000H LDC DMAC1, WA; transfer counter=65536 times \*1) LD A. 00H LDC DMAM1, A; "I/O to Memory" "byte transfer" LD DMA1V, 0FH; INTI2DMA vector value \*2) LD INTTG1DMA, 6xH; INTI2DMA interrupt enable (Level 6) ## \*1) The transfer counter value of the micro DMA is decreased every micro DMA transfer. When this value becomes 0, the interrupt process branches out into the general-purpose interrupt process. The micro DMA transfer mode of the I2CBUS does not use this transfer counter. Therefore, the micro DMA transfer counter should be set regularly so that the general-purpose interrupt process is not occurred, or it should be set that the general-purpose interrupt process can be normally ended. #### \*2) The INTI2DMA is used for both transmitter and receiver. When the transmission and the reception are processed with the different micro DMA channel such as example 1) and 2), Please do not set the micro DMA start vector register corresponding to respectively at the same time. Only the micro DMA start vector register on the actual processing side has to be set. On the other hand, the micro DMA start vector register on the other side has to be set to "00H" and prohibit from activation of the micro DMA. #### (3) Procedure of the master transmission When the micro DMA transfer mode is used, the I2CCR1<ACK> must be set to 1, and the clock pulse for the acknowledge is generated. After initializing the I<sup>2</sup>CBUS and the micro DMA, (slave address + R/ $\overline{W}$ = 0) is set in the I2CDBR. When the I2CCR3<DMAEN> is set to "1", The I2CBUS operates as the micro DMA transfer mode, and the I2CCR4 can be set to any value. The I2CCR4<T/ $\overline{R}$ > is set to 1, the micro DMA transfer mode is set to the transmit mode, and the number of bytes of transferring data is set in the I2CCR4<C3 to 0> at the same time. After checking bus free, Sending of the start condition and slave address begins by setting the start command in the I2CCR2. If the acknowledge from the slaver can be received, the transmit data of the first byte is transferred to the I2CDBR with the micro DMA by generating the INTI2DMA interrupt. As for each byte following transferring, the micro DMA transfer is repeated by generating the INTI2DMA interrupt whenever the acknowledge from the slaver is received. The value of the I2CCR4<C3 to 0> is decreased at the time of each transmit data writing in the I2CDBR. When transferring the number of bytes set in I2CCR4<C3 to0> ends, the I2CCR4<DMAEND> is set to 1, and the INTI2CB interrupt is occurred. (The INTI2DMA interrupt is not occurred.) When transferring it continuously, the I2CCR4<RSTR> is set to 1 at the same time as setting the next transferred number of bytes in I2CCR4<C3 to 0>. The micro DMA transfer is restarted with the INTI2DMA interrupt by setting the I2CCR4<RSTR> to 1. At this time, the I2CCR4<DMAEND> is cleared to 0. Setting the I2CCR4<RSTR> is effective when the I2CCR4<DMAEND> is on 1. After transferring a setting byte ends, the I<sup>2</sup>CBUS transfer is ended with the stop condition by setting the stop command in the I2CCR2. When the arbitration lost is detected or the acknowledge from the slaver cannot be received while transferring the number of setting bytes from the slave address sending, the INTI2CB interrupt is occurred instead of the INTI2DMA interrupt. The transfer end and transfer error are distinguished by reading I2CSR<AL, LRB> and I2CCR4<DMAEND> in the INTI2CB interrupt routine. When the transfer error is occurred, the micro DMA transfer mode is released by setting the I2CCR3<DMAEN> to 0. When the I2CCR3<DMAEN> is set to 0, the I2CCR4 register is initialized. In case of the acknowledge error, transferring is ended by generating the stop condition with the I2CCR2. In case of the arbitration lost, the I²CBUS is operated as a slaver. #### (4) Procedure of the master reception When the micro DMA transfer mode is used, the I2CCR1<ACK> must be set to 1, and the clock pulse for the acknowledge is generated. After initializing the $I^2$ CBUS and the micro DMA, (slave address + R/ $\overline{W}$ = 1) is set in the I2CDBR. When the I2CCR3<DMAEN> is set to 1, The $I^2$ CBUS operates as the micro DMA transfer mode, and the I2CCR4 can be set to any value. The I2CCR4<T/ $\overline{R}$ > is set to 0, the micro DMA transfer mode is set to the receive mode, and the number of bytes of transferring data is set in the I2CCR4<C3 to 0> at the same time. At this time, when transferring is ended only by receiving the number of setting bytes, I2CCR4<RCONT> is set to 0. When the reception is continued up to the next number of transferring bytes, I2CCR4<RCONT> is set to 1 After checking bus free, Sending of the start condition and slave address begins by setting the start command in the I2CCR2. If the acknowledge from the slaver can be received, the clock output restarts automatically and the first byte data reception begins. At each byte reception end, the INTI2DMA interrupt is occurred, and the reception data is taken out from the I2CDBR by the micro DMA. The acknowledge is sent at each acknowledge timing from the 1st byte ahead of the final byte . The output of the acknowledge is controlled by the condition of <RCONT> at the acknowledge timing of the final byte. When the <RCONT> is set to 0, the acknowledge of the final byte is not sent and the slaver-transmitter ends the transmission. When the <RCONT> is set to 1, the acknowledge of the final byte is sent and the slaver-transmitter continues transmitting. The value of the I2CCR4<C3 to 0> is decreased at the time of each reading the reception data from the I2CDBR. When transferring the number of bytes set in I2CCR4<C3 to 0> ends, the I2CCR4<DMAEND> is set to 1 and the INTI2CB interrupt is occurred. (The INTI2DMA interrupt is not occurred) When transferring it continuously, the I2CCR4<RSTR> is set to "1" at the same time as setting the next transferred number of bytes to the I2CCR4<C3 to 0>. The clock for the next byte is restarted by setting the I2CCR4<RSTR> to 1. At each time the byte receive ends, the INTI2DMA interrupt is occurred and the micro DMA transfer is restarted. At this time, the I2CCR4<DMAEND> is cleared to 0. Setting the I2CCR4<RSTR> is effective when the I2CCR4<DMAEND> is on 1. After transferring a setting byte ends, transferring is ended with the stop condition by setting the stop command in the I2CCR2. When the arbitration lost is detected or the acknowledge from the slaver cannot be received while transferring the slave address byte, the INTI2CB interrupt is occurred instead of the INTI2DMA interrupt. The transfer end and transfer error are distinguished by reading I2CSR<AL, LRB> and I2CCR4<DMAEND> in the INTI2CB interrupt routine. When the transfer error is occurred, the micro DMA transfer mode is released by setting the I2CCR3<DMAEN> to 0. When the I2CCR3<DMAEN> is set to 0, the I2CCR4 register is initialized. In case of the acknowledge error, transferring is ended by generating the stop condition with the I2CCR2. In case of the arbitration lost, the I²CBUS is operated as a slaver. ## (5) Procedure of restart The restart operation can be done for the micro DMA transfer mode as well as a usual master operation. The procedure from the bus releasing to the restart is the same as 3.18.5 (5). Figure 3.18.6-1 Example for the 18-bytes transmit with micro DMA Example for the 18-bytes receive with micro DMA Figure 3.18.6-3 Example for the Acknowledge error at micro DMA transfer mode Figure 3.18.6-4 Example for the Arbitration lost at micro DMA transfer mode Figure 3.18.6-5 Example for the Restart sequence with micro DMA ## 3.18.7 Notes when I2CBUS is used ① When the I<sup>2</sup>CBUS is used for the multi master, being end the initialization of the I<sup>2</sup>CBUS including setting the port function is necessary before another master begins transferring. ② When the I²CBUS is used for the multi master, Please write the slave address byte after confirming bus free. Moreover, after writing the slave address byte, please end reconfirming bus free and setting the start command within one cycle at the minimum transferring cycle (start → slave address transmission → stop) assumed doing on the bus. ### 3.19 8-BIT A/D CONVERSION CIRCUIT (A/D) The TMP93C071 has an 8-bit A/D conversion circuit of high precision, the successive comparison type with 16-channels analog input. The 8-cannels (AlN3 to AlN10) of 16-channels analog input pin are also used as general purpose input ports (P40 to P47). The others 8-channels (AlN0 to AlN2, AlN11 to AlN15) are also used as I/O port (P55 to P57, PC0 to PC4). The A/D conversion ends in 9.5 µs (at 20 MHz) from the start of conversion. Figure 3.19.1-1 Configuration of 8-bit A/D Conversion Circuit ## 3.19.1 Operation of A/D Conversion Circuit ## (1) A/D conversion reference voltage The positive electrode of A/D conversion reference voltage connects to ADREF pin, and the negative electrode of A/D conversion reference voltage connects to ADGND (DGND2) pin. Apply positive of analog reference voltage to the ADREF pin and negative to the ADGND pin. The A/D conversion is carried out by splitting reference voltage between ADREF pin and ADGND pin to bit divided by 256 by ladder resister and making a judgment by comparing it with analog input voltage. #### (2) Analog input channels One of the 16-channels analog input (AIN0 to AIN15) is selected by the A/D conversion control register ADMOD<ADCH3-0>. The analog input channel selection register ADMOD<ADCH3 to 0> are initialized to "0, 0, 0" by reset operation, then the AIN0 (P55) is selected. When these ports are not used as the analog input ports, these ports can be used as general purpose input ports (Port 4, Port 5, Port C). When these ports are used as the output port, output level must not be changed during A/D conversion. (the A/D conversion value may be influenced.) Note: When P55/TI5/AIN0, P56/TI4/AIN1 and P57/TI0/AIN2 are used as an analog input (AIN0, AIN1 and AIN2), TI5, TI4 and TI0 for timer counter must be disabled by TCCR54 and TCCR10. (Select another source clock for timer counter.) #### (3) A/D conversion time The result of A/D conversion is stored into the A/D conversion value register (ADREG) after the passage of 95 states from setting the A/D conversion start register ADMOD<ADS> to 1. #### (4) Start A/D conversion start A/D conversion is started by setting the A/D conversion control register ADMOD<ADS> to "1". After A/D conversion starts, the A/D conversion busy flag ADMOD<ADBF> is set to 1. Note: If A/D conversion is restarted when <ADBF> is 1, A/D conversion is afraid stopped, after confirming <ADBF> to 0. ### (5) A/D conversion end After A/D conversion ends, the A/D conversion end flag ADMOD<br/>EOCF> which indicates the end of A/D conversion is set to 1, and the interrupt request signal (INTAD) is generated, and the <ADBF> is cleared to 0. ## (6) A/D conversion interruption (INTAD) After A/D conversion ends, the interrupt request signal (INTAD) is generated, and the A/D circuit requests CPU to interrupt. The interrupt request signal (INTAD) is cleared to "0" by reading out the ADREG in program. ## (7) Reading of A/D conversion values The results of A/D conversion is put into the A/D conversion value register (ADREG). The A/D conversion end flag ADCR<EOCF> is cleared to "0" by reading the ADREG. The value of the ADREG is an undefined data if the ADREG is read during A/D conversion. Figure 3.19 (2) shows the timing chart of A/D conversion operation. Figure 3.19.2 Shown in Timingchart of A/D Conversion Operation. Note: Executing the HALT instruction during A/D conversion that conversion operation is forced stop, and result in undefined ADREG value. At the same time, A/D control register (ADMOD) is initialized to initial value. ## 3.19.2 Control Register | | A/D converter control register | | | | | | | | | | | |---------|--------------------------------|---------------|--------------|----------------|---------------|-------------|---------------|---------|---------|--|--| | ADMOD | | 7 | 6 | 5 | 4 | 3 | ; 2 | ; 1 | ; 0 | | | | (005AH) | bit Symbol | | EOCF | ADBF | ADS | ADCH3 | ¦ ADCH2 | ¦ ADCH1 | ¦ ADCH0 | | | | (000,) | Read/Write | | R | . R | . R/W | ! | F | R/W | | | | | | After reset | 1 | 0 | 0 | 0 | 0 | i 0 | i 0 | i 0 | | | | | Function | Always set to | A/D | A/D | A/D | Analog chan | nel selection | | | | | | | | 1 | conversion | conversion | conversion | !<br>! | | | | | | | | | | flag | busy flag | start /status | 0000: AIN0 | 1010: AIN10 | | | | | | | | | !<br>! | | ! | 0001: AIN1 | 1011: AIN11 | | | | | | | | | 0: During or | 0: free (stop) | 0: — | 0010: AIN2 | 1100: AIN12 | | | | | | | | | before | 1: busy | 1: A/D | 0011: AIN3 | 1101: AIN13 | | | | | | | | | converting | | conversion | 0100: AIN4 | 1110: AIN14 | | | | | | | | | 1: Finish | | start | 0101: AIN5 | 1111: AIN15 | | | | | | | | | conversion | | ! | 0110: AIN6 | | | | | | | | | | !<br>! | ; | ; | 0111: AIN7 | | | | | | | | | | l<br>I | ! | : | 1000: AIN8 | | | | | | | | | | I<br>I | l<br>I | !<br>! | 1001: AIN9 | | | | | | | | A/D conversion value register | | | | | | | | | | |-----------------|-------------------------------|------|------|------|------|--------|------|------|------|--| | ADREG | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | (005BH) | bit Symbol | ADR7 | ADR6 | ADR5 | ADR4 | i ADR3 | ADR2 | ADR1 | ADR0 | | | Read/Write Read | | | | | | | | | | | | | After reset | * | * | * | 1 * | . * | . * | * | * | | \*: unknown after reset Figure 3.19.3 Registers for A/D converter **TOSHIBA** TMP93C071 ## 3.20 Watchdog Timer (Runaway Detecting Timer) TMP93C071 contains a watchdog timer of Runaway detecting. The watchdog timer (WDT) is used to return the CPU to the normal state when it detects that the CPU has started to malfunction (runaway) due to causes such as noise. When the watchdog timer detects a malfunction, it generates a non-maskable interrupt INTWD to notify the CPU of the malfunction. Connecting the watchdog timer output to the reset pin internally forces a reset. This watchdog timer consists of 22-stage binary counters. These binary counters are also used as a warm-up timer for the internal oscillator stabilization. This is used for releasing the STOP and before changing system clock. ## 3.20.1 Configuration Figure 3.20.1 shows the block diagram of the watchdog timer (WDT). Figure 3.20.1 Block Diagram of Watchdog Timer / Warm-up Timer The watchdog timer consists of 22-stage binary counters which use System clock ( $f_{SYS}$ ) as the input clock. The 22-stage binary counter has $f_{SYS}/2^{15}$ , $f_{SYS}/2^{17}$ , $f_{SYS}/2^{19}$ and $f_{SYS}/2^{21}$ output. Selecting one of the outputs with the WDMOD<WDTP1, 0> register generates a watchdog interrupt and outputs watchdog timer out when an overflow occurs. The binary counter for the watchdog timer should be cleared to "0" with runaway detecting result software (instruction) before an interrupt occurs. (Example) LDW (WDMOD), B100H ; disable LD (WDCR), 4EH ; write clear code SET 7, (WDMOD) ; enable again The runaway detecting result can also be connected to the reset pin internally. In this case, the watchdog timer resets itself. Figure 3.20.2 Normal Mode Figure 3.20.3 Reset Mode For warm-up counter, 2<sup>14</sup> and 2<sup>16</sup> output of 22-stage binary counter can be selected using WDMOD<WARM> register. TOSHIBA TMP93C071 ### 3.20.2 Control Registers Watchdog timer WDT is controlled by two control registers WDMOD and WDCR. - (1) Watchdog Timer Mode Register (WDMOD) - ① Setting the detecting time of watchdog timer <WDTP> This 2-bit register is used to set the watchdog timer interrupt time for detecting the runaway. This register is initialized to WDMOD<WDTP1, 0> = 00 when reset. The detecting time of WDT is shown Table 3.20.1. ② Watchdog timer enable/disable control register <WDTE> When reset, WDMOD<WDTE> is initialized to 1 enable the watchdog timer. To disable, it is necessary to set this bit to 0 and write the disable code (B1H) in the watchdog timer control register WDCR. This makes it difficult for the watchdog timer to be disabled by runaway. However, it is possible to return from the disable state to enable state by merely setting <WDTE> to 1. ③ Watchdog timer out reset connection<RESCR> This register is used to connect the output of the watchdog timer with RESET terminal, internally. Since WDMOD<RESCR>is initialized to 0 at reset, a reset by the watchdog timer will not be performed. (2) Watchdog Timer Control Register (WDCR) This register is used to disable and clear of binary counter the watchdog timer function. · Disable control By writing the disable code (B1H) in this WDCR register after clearing WDMOD<WDTE> to 0, the watchdog timer can be disabled. ``` WDMOD ← 0 - - - - - X X Clear WDMOD <WDTE> to 0. WDCR ← 1 0 1 1 0 0 0 1 Write the disable code (B1H). ``` Enable control Set WDMOD<WDTE>to 1. · Watchdog timer clear control The binary counter can be cleared and resume counting by writing clear code (4EH) into the WDCR register. WDCR $\leftarrow$ 0 1 0 0 1 1 1 0 Write the clear code (4EH). Figure 3.20.4 Watchdog Timer Mode Register Figure 3.20.5 Watchdog Timer Control Register Table 3.20.1 Watchdog Timer Detecting Time at fc = 20 MHz, fs = 32.768 kHz | | | | 40 E0 Wil 12 | -, 10 OE.1 OO KI IE | | | | | | |-----------------|----------|-------------------------------|--------------|---------------------|--|--|--|--|--| | System clock | | Watchdog Timer Detecting Time | | | | | | | | | selection | | WDMOD <wdtp1, 0=""></wdtp1,> | | | | | | | | | <sysck></sysck> | 00 | 01 | 10 | 11 | | | | | | | 1 (fs) | 2.000 s | 8.000 s | 32.000 s | 128.000 s | | | | | | | 0 (fc) | 3.277 ms | 13.107 ms | 52.429 ms | 209.715 ms | | | | | | ## 3.20.3 Operation The watchdog timer generates interrupt INTWD after the detecting time set in the WDMOD<WDTP1, 0>. The watchdog timer must be zero-cleared by software before an INTWD interrupt is generated. If the CPU malfunctions (runaway) due to causes such as noise, but does not execute the instruction used to clear the binary counter, the binary counter overflows and an INTWD interrupt is generated. The CPU detects malfunction (runaway) due to the INTWD Interrupt and it is possible to return to normal operation by an antimulfunction program. The watchdog timer restarts operation immediately after resetting is released. The watchdog timer stops its operation in the IDLE1 and STOP modes. In the RUN mode, the watchdog timer is enabled. However, the function can be disabled when entering the RUN, IDLE2 mode. ## Example: ① Clear the binary counter WDCR ←0 1 0 0 1 1 1 0 Write clear code (4EH). ② Set the watchdog timer detecting time to 2<sup>17</sup> / f<sub>SYS</sub> WDMOD ←101---XX 3 Disable the watchdog timer. WDMOD $\leftarrow$ 0 - - - - - X X Clear WDTE to "0". WDCR $\leftarrow$ 1 0 1 1 0 0 0 1 Write disable code (B1H). Set IDLE1 mode. WDMOD $\leftarrow$ 0 - - - 1 0 X X Disables WDT and sets IDLE1 mode. WDCR ←10110001 Executes HALT command Set the HALT mode Set the STOP mode (warming up time: 2<sup>16</sup> / f<sub>SYS</sub>) WDMOD ← - - - 1 0 1 X X Set the STOP mode. Executes HALT command. Execte HALT instruction. Set the HALT mode. Note: X; Don't care -; no change - 4. Electrical Characteristics(Preliminary) - 4.1 Absolute Maximum Rating | Parameter | Symbol | Rating | Unit | |-------------------------------|---------|-------------------|------| | Power Supply Voltage | Vcc | -0.5 to 6.5 | V | | Input Voltage | VIN | -0.5 to Vcc + 0.5 | V | | (Including Open drain ports) | VOUT | -0.5 to Vcc + 0.5 | V | | Output Current (Per 1 pin) | IOL | 3.2 | mA | | Output Current (Per 1 pin) | IOH | -3.2 | mA | | Output Current (total) | ΣΙΟL | 120 | mA | | Output Current (total) | ΣΙΟΗ | -120 | mA | | Power Dissipation (Ta = 70°C) | PD | 600 | mW | | Soldering Temperature (10sec) | TSOLDER | 260 | ů | | Storage Temperature | TSTG | -65 to 150 | °C | | Operating Temperature | TOPR | -10 to 70 | °C | 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. ## 4.2 DC Characteristics 1/2 $Ta = -10 \text{ to } 70^{\circ}C$ | Р | arameter | Symbol | Condition | Min | Тур. | Max | Unit | |---------|--------------------------------------------|--------------------------------|-----------------------------|-----------|------|-----------------------|------| | Power | Supply | Vcc | fc = 4 to 20 MHz | 4.5 | 7. | 5.5 | V | | Voltage | | | fs = 30 to 34 kHz | 2.7 | | | | | | D0-D15<br>P4, P6, P9,<br>PA,<br>PB0, 1, PC | VIL<br>(TTL)<br>VIL1<br>(CMOS) | Vcc ≧ 4 .5 V<br>Vcc < 4.5 V | -0.3 | | 0.8<br>0.6<br>0.3 Vcc | | | | RESET ,<br>INT0-4,<br>P5, P7, P8,<br>PB2-5 | VIL2<br>(Schmit) | Vcc = 2.7 to 5.5 V | | | 0.25 Vcc | V | | | ĒĀ, | VIL3 | | | | 0.3 | | | | A <u>M</u> 8/16<br>X1 | (Fixed)<br>VIL4<br>(Xtal) | | | | 0.2 Vcc | | | | | VIH | Vcc <u>≥</u> 4.5 V | 2.2 | | | | | | D0-D15 | (TTL) | Vcc < 4.5 V | 2.0 | | | | | | P4, P6, P9,<br>PA,<br>PB0, 1, PC | VIH1<br>(CMOS) | | 0.7 Vcc | | Vcc + 0.3 | V | | | RESET,<br>INT0-4,<br>P5, P7, P8,<br>PB2-5 | VIH2<br>(Schmit) | Vcc = 2.7 to 5.5 V | 0.75 Vcc | | | | | | EA ,<br>AM8/16 | VIH3<br>(Fixed) | | Vcc – 0.3 | | | | | | X1 | VIH4<br>(Xtal) | | 0.8 Vcc | | | | ## DC Characteristics 2/2 Ta= -10 to 70°C | Parameter | Symbol | Condition | Min | Тур. | Max | Unit | |-------------------|--------|-------------------------|-----|------|------|----------| | Output | | IOL = 1.6 mA | | | | | | Low Voltage | VOL | (Vcc = 2.7 to 5.5 V) | | | 0.45 | V | | Output High | | IOH = -400 μA | | | | | | Voltage | VOH | (Vcc = 2.7 to 5.5 V) | 2.4 | | | V | | | | IOH = -700 μA | | | | | | | VOH1 | (Vcc = 4.5 to 5.5V) | 4.1 | | | | | Input | ILI | | | | | | | Leakage Current | | 0.0 ≤ Vin ≥ Vcc | | 0.02 | ±5 | | | Output | ILO | | | | | μΑ | | Leakage Current | | 0.2 ≤ Vin ≥ Vcc-0.2 | | 0.05 | ±10 | | | Power Down | | VIL2 = 0.2 Vcc, | | | | | | Voltage | VSTOP | VIH2 = 0.8 Vcc | 2.0 | | 6.0 | V | | RESET | | Vcc = 5 V ± 10% | 50 | | 150 | | | Pull Up Resister | RRST | Vcc = 3 V ± 10% | 80 | | 200 | Ω | | Pin Capacitance | CIO | osc = 1 MHz/100 mVpp | | | 10 | pF | | Schmitt Width | VTH | | | 1.0 | | <b>\</b> | | RESET, INT0-4, | | | | | | | | P5, P7, P8, PB2-5 | | | | | | | | Operating Current | | Vcc = 5 V ± 10% | | | | | | • | | fc = 20 MHz | | | | | | (NORMAL) | Icc | | | 28 | 45 | | | RUN | [ | | | 22 | 35 | mΑ | | IDLE2 | Γ | | [ | 16 | 25 | | | IDLE1 | T | | | 3.5 | 8 | | | Operating Current | | Vcc = 3 V ± 10% | | | | | | (SLOW) | | fs = 32.768 kHz | | | | | | L | L | (Typ: Vcc = 3.0 V) | L | 40 | 70 | | | RUN | [ | | | 32 | 45 | μA | | IDLE2 | [ | | | 27 | 40 | | | IDLE1 | [ | | | 17 | 30 | | | STOP | | Vcc = 2.7 to 5.5 V | | 0.2 | 10 | μΑ | Note 1: Typical value are for Ta = 25°C and Vcc = 5 V unless otherwise noted. Only CPU is operational; output pins are open and input pins are fixed. Note 2: Icc measurement conditions (NORMAL, SLOW). ## 4.3 A/D Conversion Characteristics $Ta = -10 \text{ to } 70^{\circ}\text{C}, \ Vcc = 4.5 \text{ to } 5.5 \ \text{V}$ | Parameter | Symbol | Min | Тур. | Max | Unit | |---------------------------------|--------|---------|------|-------|------| | Analog Reference Voltage Supply | ADREF | Vcc-1.5 | Vcc | Vcc | V | | | ADGND | Vss | Vss | Vss | V | | Analog Input Voltage Range | VAIN | ADGND | _ | ADREF | ٧ | | Analog Current for ADREF | IREF | _ | 1.0 | 1.5 | mA | | Error | | | | ±3 | LSB | # 4.4 AC Electrical Characteristics(Preliminary) (Separated Bus) (1) $Vcc = 5 V \pm 10\%$ $Ta = -10 \text{ to } 70^{\circ}C$ | Parameter | Symbol | Var | iable | 20 N | Unit | | |--------------------------|--------|-----------|------------|------|------|----| | | · | Min | Max | Min | Max | | | OSC.Period(= X) | tOSC | 50 | 250 | 50 | | ns | | A0-23 Valid> RD/WR Fall | tAC | 1.0X – 25 | | 25 | | ns | | RD/WR Rise> A0-23 Hold | tCA | 0.5X - 25 | | 0 | | ns | | A0-23 Valid> D0-15 input | tAD | | 3.5X-65 | | 110 | ns | | RD fall> D0 – 15 input | tRD | | 2.5X-60 | | 65 | ns | | RD Low width | tRR | 2.5X - 40 | | 85 | | ns | | RD rise> D0 - 15 Hold | tHR | 0 | | 0 | | ns | | WR Low Pulse Width | tWW | 2.5X - 40 | | 85 | | ns | | D0-15 Valid> WR Rise | tDW | 2.0X - 55 | | 45 | | ns | | WR Rise> D0 – 15 Hold | tWD | 0.5X - 15 | | 10 | | ns | | A0-23 Valid> Port Input | tAPH | | 2.5X - 120 | | 5 | ns | | A0-23 Valid> Port Hold | tAPH2 | 2.5X + 50 | | 175 | | ns | | WR Rise> Port Valid | tCP | | 200 | | 200 | ns | AC Test Condition: Output Level: High = 2.2 V, Low = 0.8 V CL = 50pF (D0-D15, A0-23, $\overline{RD}$ , $\overline{WR}$ , $\overline{HWR}$ , CS0-CS2: CL = 100pF) Input Level: High = 2.4 V / Low = 0.45 V: D0-D15 High = 0.8 Vcc / Low = 0.2 Vcc: (except D0-D15) (2) $Vcc = 3 V \pm 10\%$ $Ta = -10 \text{ to } 70^{\circ}\text{C}$ | Parameter | Symbol | Vari | able | Unit | |----------------------------|--------|------------|------------|------| | | | Min | Max | | | OSC.Period(= X) | tOSC | 29400 | 33300 | ns | | A0-23 Valid> RD/WR Fall | tAC | 1.0X - 50 | | ns | | RD / WR Rise> A0 - 23 Hold | tCA | 0.5X - 40 | | ns | | A0-23 Valid> D0 – 15 input | tAD | | 3.5X - 125 | ns | | RD fall> D0 - 15 input | tRD | | 2.5X – 115 | ns | | RD Low width | tRR | 2.5X - 40 | | ns | | RD rise> D0 – 15 Hold | tHR | 0 | | ns | | WR Low Pulse Width | tWW | 2.5X - 40 | | ns | | D0 – 15 Valid> WR Rise | tDW | 2.0X - 120 | | ns | | WR Rise> D0 – 15 Hold | tWD | 0.5X - 40 | | ns | | A0 – 23 Valid> Port Input | tAPH | | 2.5X - 120 | ns | | A0 – 23 Valid> Port Hold | tAPH2 | 2.5X + 50 | | ns | | WR Rise> Port Valid | tCP | | 200 | ns | AC Test Condition: Output Level: High = $0.7 \times Vcc$ , Low = $0.3 \times Vcc$ CL = 50pF Input Level: High = $0.9 \times Vcc$ , Low = $0.1 \times Vcc$ ## (1) Read / Write cycle timing chart [Separated Bus] TOSHIBA TMP93C071 ## 4.5 Serial Channel Timing Chart tLOW = 8N/fc tHIGH =8N/fc + 12/fc + (1/2\*tR) fSCL = 1/(tLOW + tHIGH) N = Value of I2CCR3<DV4 - 0> ## (2) SIO0,1 SIO AC Electrical Characteristics (SCLK external input) Ta= -10 to $70^{\circ}$ C Vcc = $5 \text{ V} \pm 10\%$ | Parameter | Symbol | Varia | iable 20 I | | ИHz | Unit | |-----------------------------|--------|-------------------------------------|------------|-----------|-----|------| | | | Min | Max | Min | Max | | | SCLK cycle | tSCY | 2 <sup>5</sup> X (2 <sup>4</sup> X) | | 1.6 (0.8) | | us | | SCLK High pulse width | tSCH | tSCY/2-50 | | 750 (400) | | ns | | | | (tSYC/2) | | | | | | SCLK Low pulse width | tSCL | tSCY/2-50 | | 750 (400) | | ns | | | | (tSYC/2) | | | | | | SCLK shift edge -> SO delay | tSDO | | 6X + 50 | | 350 | ns | | SCLK shift edge -> SI setup | tSSDI | -X + 50 | | 0 | | ns | | SCLK shift edge -> SI hold | tSHDI | 6X + 50 | | 350 | | ns | note: These are value when SCxMOD<SIOxE> don't be disabled under transferring. (SCLK internal output) | Parameter | Symbol | Variable | | 20 MHz | | Unit | |-----------------------------|--------|-----------|------------------|--------|------|------| | | | Min | Max | Min | Max | | | SCLK cycle | tSCY | 2⁴X | 2 <sup>7</sup> X | 0.8 | 6.4 | us | | SCLK High pulse width | tSCH | tSCY/2-50 | tSCY/2 | 350 | 3200 | ns | | SCLK Low pulse width | tSCL | tSCY/2-50 | tSCY/2 | 350 | 3200 | ns | | SCLK shift edge -> SO delay | tSDO | | X + 50 | | 100 | ns | | SCLK shift edge -> SI setup | tSSDI | X + 50 | · | 100 | | ns | | SCLK shift edge -> SI hold | tSHDI | 0 | · | 0 | | ns | # 5. Table of Special Function Registers (SFR; Special Function Register) The special function registers (SFRs) include the I/O ports and peripheral control registers allocated to the 144-byte addresses from 000000H to 00008FH. ## Configuration of the table | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |--------|------|---------|----------|-------------------|---|---|---|---|---|---|--|--|--| | | | | | bit Symbol | | | | | | | | | | | | | | | Read/Write | | | | | | | | | | | | | | | Value after Reset | | | | | | | | | | | | | | Function | | | | | | | | | | | Note: Prohibit RMW in the table means that you cannot use RMW instructions on these registers. The LD (transfer) instruction must be used to write for Prohibit RMW registers. R/W: Read/Write R: Read-only W: Write-only Prohibit RMW: Prohibit read-modify-write (cannot be used the instruction such as RES, SET, TEST, CHG, STCF, ANDCF, ORCF, XORCF) Table 5. I/O register address map | Address | Name | Address | Name | Address | Name | Address | Name | Address | Name | |---------|------------|---------|---------|---------|------------|---------|-----------|---------|------------| | 000000H | (Reserved) | 20H | PBFC | 40H | PWM1DRL | 60H | SC0MOD | 80H | INTRTCR | | 1H | (Reserved) | 21H | ODCR3 | 41H | PWM1DRH | 61H | SC0BUF | 81H | I2CCR1 | | 2H | (Reserved) | 22H | ODCR4 | 42H | PWM2DRL | 62H | SC1MOD | 82H | I2CDBR | | 3H | (Reserved) | 23H | TBCMOD | 43H | PWM2DRH | 63H | SC1BUF | 83H | I2CAR | | 4H | (Reserved) | 24H | TBCDR0 | 44H | PWMDBR | 64H | SC2MOD | 84H | I2CCR2 | | 5H | (Reserved) | 25H | TBCDR1 | 45H | PWMCR | 65H | SC2CR | 85H | I2CCR3 | | 6H | P2 | 26H | TBCIF | 46H | CAPINCR0 | 66H | BR2CR | 86H | I2CCR4 | | 7H | (Reserved) | 27H | TRUN | 47H | CAPINCR1 | 67H | SC2BUF | 87H | PC | | 8H | (Reserved) | 28H | TCCR10 | 48H | CAPINCR2 | 68H | B0CS | 88H | PCCR | | 9H | P2FC | 29H | TREG0 | 49H | CAPINCR3 | 69H | B1CS | 89H | (Reserved) | | AH | P4 | 2AH | TREG1L | 4AH | CAPFST | 6AH | B2CS | 8AH | (Reserved) | | BH | P5 | 2BH | TREG1H | 4BH | CAP0L | 6BH | PAFC | 8BH | (Reserved) | | CH | P5CR | 2CH | TCCR32 | 4CH | CAP0M | 6CH | SYSCR2 | 8CH | (Reserved) | | DH | PRDSEL | 2DH | TCCR54 | 4DH | CAP0H | 6DH | SYSCR3 | 8DH | (Reserved) | | EH | P6 | 2EH | TREG2L | 4EH | CAP1L | 6EH | SYSCR0 | 8EH | (Reserved) | | FH | P7 | 2FH | TREG2H | 4FH | CAP1H | 6FH | SYSCR1 | 8FH | (Reserved) | | 10H | P6CR | 30H | TREG3L | 50H | CAP2L | 70H | INT0CP1 | | | | 11H | P7CR | 31H | TREG3H | 51H | CAP2H | 71H | INTCP0TG0 | | | | 12H | P6FC | 32H | TREG4L | 52H | CAPCR | 72H | INTTG1DMA | | | | 13H | P7FC | 33H | TREG4H | 53H | RMTCR | 73H | INTI2CTBC | | | | 14H | ODCR0 | 34H | TREG5L | 54H | VIVACR1 | 74H | INTSI0SI1 | | | | 15H | ODCR1 | 35H | TREG5H | 55H | VIVACR2 | 75H | INTRXTX | | | | 16H | P8 | 36H | TPG0CR | 56H | VASSDR | 76H | INTVA1 | | | | 17H | P9 | 37H | TPG0L | 57H | CSYNCR | 77H | INT23 | | | | 18H | P8CR | 38H | TPG0H | 58H | PVCR | 78H | INT4T0 | | | | 19H | P9CR | 39H | TPG0DR | 59H | (Reserved) | 79H | INTT1T2 | | | | 1AH | P9FC | 3AH | TPG1L | 5AH | ADMOD | 7AH | INTT3T4 | | | | 1BH | ODCR2 | 3BH | TPG1H | 5BH | ADREG | 7BH | INTT5AD | | | | 1CH | PA | 3CH | TPG1DR | 5CH | WDMOD | 7CH | DMA0V | | | | 1DH | PB | 3DH | PWMRUN | 5DH | WDCR | 7DH | DMA1V | | | | 1EH | PACR | 3EH | PWM0DRL | 5EH | IIMC0 | 7EH | DMA2V | | | | 1FH | PBCR | 3FH | PWM0DRH | 5FH | IIMC1 | 7FH | DMA3V | | | System Control/RTC | | | I | 1 | | stem Contro | | | 1 | | · | |--------|-----------|-----------|----------------|----------------|----------------|-----------------|--------------|---------------------------|--------------------|------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SYSCR0 | System | 00006EH | XEN | XTEN | RXEN | RXTEN | RSYSCK | WUEF | | _ | | | Control | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Register0 | | 1 | 0 | 1 | 0 | 0 | 0 | | | | | | | High | Low | High | Low | System | Warming up | | | | | | | frequency | frequency | frequency | frequency | clock after | timer | | | | | | | oscillator | oscillator | oscillator | oscillator (fs) | releasing | start/ | | | | | | | (fc: 20 MHz) | (fs: 32 kHz) | (fc) after | after | STOP mode | status flag | | | | | | | | | released | released | | | | | | | | | | | STOP mode | STOP mode | | (Write) | | | | | | | | | | | | 0: Don't | | | | | | | | | | | | care | | | | | | | | | 0: Stop | 0: Stop | 0: fc | 1: Start | | | | | | | 0: Stop | 0: Stop | 1: Oscillation | 1: Oscillation | (Normal) | timer | | | | | | | 1: Oscillation | 1: Oscillation | | | 1: fs | | | | | | | | | | | | (Slow) | (Read) | | | | | | | | | | | | 0: End of | | | | | | | | | | | | warming | | | | | | | | | | | | up | | | | | | | | | | | | 1: Under | | | | | | | | | | | | warming | | | | | | | | | | | | ир | | | | SYSCR1 | System | 00006FH | | _ | _ | _ | SYSCK | | | | | | control | | (set to 0) | | | | R/W | (set to 0) | (set to 0) | (set to 0) | | | Register1 | | 0 | | | | 0 | 0 | 0 | 0 | | | | | | | | | system clock | | | | | | | | | | | | - | | | | | | | | | | | | 0:fc | | | | | | | | | | | | (Normal) | | | | | | | | | | | | 1:fs | | | | | | | | | | | | (Slow) | | | | | SYSCR2 | System | 00006CH | | | _ | RTCCK | RTCST | RTCIS1 | RTCIS0 | _ | | | Control | | (set to 0) | (set to 0) | | R/W | R/W | R/ | W | | | | Register2 | | 0 | 0 | | 0 | 0 | ,,,, | | | | | | | | | | | RTC start | Interval time | | | | | | | | | | source select | | RTC interrup | | | | | | | | | | | | | - | | | | | | | | | 0: fs | 0: Stop & | 00: fc/2 <sup>17</sup> or | fs/2 <sup>15</sup> | | | | | | | | | (32 kHz) | Counter | (6.55 ms) (1 | | | | | | | | | | 1:fc | Clear | 01: fc/2 <sup>18</sup> or | fs/2 <sup>16</sup> | | | | | | | | | | 1: Start | 1 | s) | | | | | | | | | (== ······• | | 10: fc/2 <sup>16</sup> or | fs/2 <sup>14</sup> | | | | | | | | | | | 1 | .5 s) | | | | | | | | | | | 11: Reserved | d | | | | | | | | | | | [Hz | | | | SYSCR3 | System | 00006DH | | | | | | | | CLKEN | | 310010 | Control | - 00000DN | (set to 1) | (set to 1) | (set to 1) | (cot to 1) | (set to 0) | (set to 0) | | R/W | | | | | (set to 1) | <u> </u> | | (set to 1) | (set to 0) | (set to 0) | | 0 | | | Register2 | | <u> </u> | 1 | 1 | ' | U | J 0 | | | | | | | | | | | | | | 0: Disable | | | | | | | | | <u> </u> | | | 1: Enable | Watch DogTimer | | Water Dog Fine | | | | | | | | | | | | |--------|----------------|---------|------------|-------------------------------------------|----------|---------------------------|--------------|--------|------------|-------------|--|--| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | WDMOD | Watch Dog | 00005CH | WDTE | WDTP1 | WDTP0 | WARM | HALTM1 | HALTM0 | RESCR | DRVE | | | | | Timer | | R/W | R/ | W | R/W | R/W | | R/W | R/W | | | | | Mode | | 1 | ( | ) | 0 | 0 | | 0 | 0 | | | | | Register | | WDT | WDT detect | ion time | Warming up | Standby mode | | 0: — | 1:Drive the | | | | | | | control | | | timer | | | 1: Connect | pin in | | | | | | | | 00: 2 <sup>15</sup> /fsys | | source | 00: RUN | | internally | STOP | | | | | | | 0: Disable | 01: 2 <sup>17</sup> /fsys | | clock | 01: STOP | | WDTout | mode | | | | | | | 1: Enable | 10: 2 <sup>19</sup> /fsys | | selection | 10: IDLE1 | | to Reset | | | | | | | | | 11: 2 <sup>21</sup> /fsys | | | 11: IDLE2 | | pin | | | | | | | | | | | 0: 2 <sup>14</sup> /input | | | | | | | | | | | | fsys = 1/fc | or 1/fs | frequency | | | | | | | | | | | | | | 1: 2 <sup>16</sup> /input | | | | | | | | | | | | | | frequency | | | | | | | | | | | | | | laat | | | | | | | | | | | | | | Input<br>frequency | | | | | | | | | | | | | | = fc or fs | | | | | | | | WDCR | Watch Dog | 00005DH | | _ | | | | | | | | | | | Timer | | W | | | | | | | | | | | | Control | | | _ | | | | | | | | | | | Register | | | B1H: WDT disable code 4EH: WDT clear code | | | | | | | | | Time Base Counter (TBC) | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|-----------|-----------|--------------|--------------|---------------------|------------------|-----------------------|------------|-----------------------|---------|--| | TBCMOD | TBC Mode | 000023H | , | | TBC1E | TBC0E | INTTBC11 | INTTBC10 | | | | | '5005 | Register | 00002011 | (set to "0") | (set to "0") | R/W | | R/W | | R/W | | | | | Trogistor | | "0" | "0" | | ) | 0 | | 0 | | | | | | "Prohibit | | Ů | INTTBC inte | - | TBC1 interrupt source | | TBC0 interrupt source | | | | | | RMW" | | | enable/disa | • | clock select | • | clock selection | | | | | | | | | | | | | CIOCK SCIECTION | | | | | | | | | 00: Disable | | 00: TBC12 | | 00: TBC11 | | | | | | | | | 01: INTTBC | 0 | 01: TBC14 | | 01: TBC13 | | | | | | | | | 10: INTTBC | 1 | 10: TBC16 | | 10: TBC15 | | | | | | | | | 11: INTTBC | 0/1 | 11: TBC18 | 11: TBC18 | | | | | TBCDR0 | TBC Data | 000024H | TBCD7 | TBCD6 | TBCD5 | TBCD4 | TBCD3 | TBCD2 | TBCD1 | TBCD0 | | | | | | (TBC12) | (TBC11) | (TBC10) | (TBC9) | (TBC8) | (TBC7) | (TBC6) | (TBC5) | | | | Register0 | | | | | l | R | | | | | | | | | | | | | 0 | T | ı | | | | TBCDR1 | TBC Data | 000025H | TBCD15 | TBCD14 | TBCD13 | TBCD12 | TBCD11 | TBCD10 | TBCD9 | TBCD8 | | | | | | (TBC20) | (TBC19) | (TBC18) | (TBC17) | (TBC16) | (TBC15) | (TBC14) | (TBC13) | | | | Register1 | | | | | | R | | | | | | | | | | | | | 0 | | I | | | | TBCIF | ТВС | 000026H | | | TBC1F | TBC0F | | | _ | | | | | Interrupt | | (set to 0) | (set to 0) | R/ | W | | (set to 0) | | | | | | Flag | | 0 | 0 | | ) | | 0 | | | | | | Register | "Prohibit | | | TBC1 | TBC0 | | | | | | | | | | | | interrupt | interrupt | | | | | | | | | | | | request | request | | | | | | | | | | | | flag | flag | | | | | | | | | | | | 0. 440 01: | 0. 440 | | | | | | | | | | | | 0: (W)Clear | U: (VV)<br>Clear | | | | | | | | | RMW" | | | 1: (R)<br>Interrupt | 1: (R) | | | | | | | | | INIVIV | | | request | Interrupt | | | | | | | | | | | | request | request | | | | | | | | | 1 | l | l | I | Liequest | <u> </u> | | | | | # Timer/Counter0, 1 | | | | | | 17 Counton | -, - | | | | | |---------|-------------|-----------|------------------------------------------------------|----------------------------------------------------|------------|---------|-------------|------------|------------|---------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TRUN | Timer Start | 000027H | _ | _ | T5RUN | T4RUN | T3RUN | T2RUN | T1RUN | TORUN | | | Control | | | | | | R | W | | | | | Register | | | | | | | 0 | | | | | _ | | | | | | 0:STOP | 1:RUN | | | | TCCR10 | Timer/ | 000028H | CLBC1 | T1CL | T1CLK1 | T1CLK0 | CLBC0 | T0CL | T0CLK1 | T0CLK0 | | | Counter | | R/W | R/W | R/ | W | R/W | R/W | R/ | W | | | Control | | 0 | 0 | ( | ) | 0 | 0 | ( | ) | | | Register10 | | TC1 timer/ | TC1 timer/ | TC1 source | clock | TC0 timer/ | TC0 timer/ | TC0 source | clock | | | | | counter | counter | selection | | counter | counter | selection | | | | | | match | clear | | | match | clear | | | | | | | clear | | | | | | | | | | | | enable | | | | | | | | | | | | | 1: Clear | 10: TBC4 | | | 1: Clear | 01: TI0 | | | | | | 0: Disable | (One-shot) | 11: IBC6 | | 0: Disable | (One-shot) | 10: TBC6 | | | TDEGG | T:/ | 00000011 | 1: Enable | TO/TD00 | TOTTOE | TO/TD04 | 1: Enable | TOTTOO | 11: TBC10 | тостроо | | TREG0 | Timer/ | 000029H | TC/TR07 | TC/TR06 | TC/TR05 | TC/TR04 | TC/TR03 | TC/TR02 | TC/TR01 | TC/TR00 | | | Counter | | | | | | /W | | | | | | Register0 | | | 1.4 | / MARCO TO | | 0 | . TOO | | | | TDEOU | Time and | 00000011 | TO/TD47 | | | | r R: Readin | × | | TOTOTO | | TREG1L | Timer/ | 00002AH | TC/TR17 | TC/TR16 | TC/TR15 | TC/TR14 | TC/TR13 | TC/TR12 | TC/TR11 | TC/TR10 | | | Counter | | | | | | /W | | | | | | Register1L | | 0 W: Writing TREG1L register R: Reading TC1L counter | | | | | | | | | TDECALL | Time and | 000000011 | TO/TD4E | | | | | | | TOTOTO | | TREG1H | Timer/ | 00002BH | TC/TR1F | TC/TR1E | TC/TR1D | TC/TR1C | TC/TR1B | TC/TR1A | TC/TR19 | TC/TR18 | | | Counter | | R/W<br>0 | | | | | | | | | | Register1H | | · · | | | | | | | | | | | | | W: Writing TREG1H register R: Reading TC1H counter | | | | | | | # Timer/Counter2,3 | TOODOO | | | | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------|---------|----------------------------------------------------|--------------------------------------------------------------------------------------|-------------|---------|------------|------------|------------|---------| | TCCR32 | Timer/ | 00002CH | CLBC3 | T3CL | T3CLK1 | T3CLK0 | CLBC2 | T2CL | T2CLK1 | T2CLK0 | | 1 | Counter | | R/W | R/W | R/ | W | R/W | R/W | R/ | W | | 1 | Control | | 0 | 0 | ( | ) | 0 | 0 | ( | ) | | 1 | Register32 | | TC3 timer/ | TC3 timer/ | TC3 source | clock | TC2 timer/ | TC2 timer/ | TC2 source | clock | | | | | counter | counter | selection | | counter | counter | selection | | | 1 | | | match | clear | | | match | clear | | | | 1 | | | clear | | 00: TI3 | | clear | | 00: TI2 | | | | | | enable | Ψ. | 01: TBC2 | | enable | 0: — | 01: TBC2 | | | 1 | | | l. <u>-</u> | | 10: TBC4 | | l | 1: Clear | 10: TBC4 | | | 1 | | | 0: Disable | [(0.00 0.00)] | | | | | | | | | | | 1: Enable | | | | | | | | | TREG2L | Timer/ | 00002EH | TC/TR27 | ТС/ТR27 ТС/ТR26 ТС/ТR25 ТС/ТR24 ТС/ТR23 ТС/ТR22 ТС/ТR21 ТС/ТR20<br>R/W | | | | | | | | 1 | Counter | | | | | | | | | | | | Register2L | | | | | | 0 | | | | | | | | | | Writing TRE | | | | | | | TREG2H | Timer/ | 00002FH | TC/TR2F | TC/TR2E | TC/TR2D | TC/TR2C | TC/TR2B | TC/TR2A | TC/TR29 | TC/TR28 | | 1 | Counter | | | | | | /W | | | | | 1 | Register2H | | | | | | 0 | | | | | | | | | | Writing TRE | | | | | | | TREG3L | Timer/ | 000030H | TC/TR37 | TC/TR36 | TC/TR35 | TC/TR34 | TC/TR33 | TC/TR32 | TC/TR31 | TC/TR30 | | 1 | Counter | | | | | R/ | w | | | | | 1 | Register3L | | | | | ` | 0 | | | | | | | | W: Writing TREG3L register R: Reading TC3L counter | | | | | | | | | TREG3H | Timer/ | 000031H | TC/TR3F | TC/TR3E | TC/TR3D | TC/TR3C | TC/TR3B | TC/TR3A | TC/TR39 | TC/TR38 | | I | Counter | | R/W | | | | | | | | | | Register3H | | 0 | | | | | | | | | I | | | W: Writing TREG3H register R: Reading TC3H counter | | | | | | | | # Timer/Counter4, 5 | | | | | 7 6 5 4 3 2 1 0 | | | | | | | |--------|------------|---------|----------------------------------------------------|----------------------------------------------------|-------------|-------------|-------------|-------------|------------|---------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TCCR54 | Timer/ | 00002DH | CLBC5 | T5CL | T5CLK1 | T5CLK0 | CLBC4 | T4CL | T4CLK1 | T4CLK0 | | | Counter | | R/W | R/W | R/ | W | R/W | R/W | R/ | w | | | Control | | 0 | 0 | ( | ) | 0 | 0 | ( | ) | | | Register54 | | TC5 timer/ | TC5 timer/ | TC5 source | clock | TC4 timer/ | TC4 timer/ | TC4 source | clock | | | | | counter | counter | selection | | counter | counter | selection | | | | | | match | clear | | | match | clear | | | | | | | clear | | 00: TI5 | | clear | | 00: TI4 | | | | | | enable | 0: — | 01: CSYNC | A | enable | 0: — | 01: CFGTM | | | | | | | 1: Clear | (from V- | sepa) | | 1: Clear | (from CA | PIN) | | | | | 0: Disable | , | | | | | | | | | | | 1: Enable | | | | | | | | | TREG4L | Timer/ | 000032H | TC/TR47 | | | | | | | TC/TR40 | | | Counter | | | R/W | | | | | | | | | Register4L | | | | | ( | 0 | | | | | | | | | W: | Writing TRE | G4L registe | r R: Readin | g TC4L cour | nter | | | TREG4H | Timer/ | 000033H | TC/TR4F | TC/TR4E | TC/TR4D | TC/TR4C | TC/TR4B | TC/TR4A | TC/TR49 | TC/TR48 | | | Counter | | | | | R | w | | | | | | Register4H | | | | | ( | 0 | | | | | | | | | W: | Writing TRE | G4H registe | r R: Readin | g TC4H cou | nter | | | TREG5L | Timer/ | 000034H | TC/TR57 | TC/TR56 | TC/TR55 | TC/TR54 | TC/TR53 | TC/TR52 | TC/TR51 | TC/TR50 | | | Counter | | | | | R | W | | | | | | Register5L | | | | | ( | 0 | | | | | | | | W: Writing TREG5L register R: Reading TC5L counter | | | | | | | | | TREG5H | Timer/ | 000035H | TC/TR5F | TC/TR5E | TC/TR5D | TC/TR5C | TC/TR5B | TC/TR5A | TC/TR59 | TC/TR58 | | | Counter | | R/W | | | | | | | | | | Register4H | | 0 | | | | | | | | | | | | | W: Writing TREG5H register R: Reading TC5H counter | | | | | | | | | | | | | | | | | | | Timing Pulse Generator 0 (TPG 0) | | | | | | | or U (TPG | | | | | | | |---------|----------|-----------|--------------|--------------|--------------|--------------|-------------|--------------|------------|------------|--|--| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TPG0CR | TPG0 | 000036H | | | FEMPIE | TPFUL0 | TPEMP0 | TPF02 | TPF01 | TPF00 | | | | | Control | | (set to 0) | | W | R | R | | R | | | | | | Register | | 0 | | 0 | 0 | 1 | | 0 | | | | | | | | | | INTTPG0 | TPG0 | TPG0 | TPG0 FIFO | | | | | | | | | | | FIFO | FIFO full | FIFO | (Stored da | | | | | | | | | | | empty | flag | empty | 000: Empty | | | | | | | | | | | interrupt | _ | | 001: 1 word | | | | | | | | | | | enable | 0: — | 0: — | 010: 2 word | | | | | | | | | | | | 1: FIFO full | | 011: 3 word | | | | | | | | | | | 0:— | | empty | 100: 4 word | | | | | | | | | | | 1: Enable | | | 1101. 5 Word | | | | | | | | | | | | | | 111: 7 word | | | | | | TPG0L | TPG0 | 000037H | TPG0D7 | TPG0D6 | TPG0D5 | TPG0D4 | TPG0D3 | TPG0D2 | TPG0D1 | TPG0D0 | | | | 11 002 | Lower | 00000711 | 11 000, | 11 0000 | 11 0000 | 11 0004 | 11 0000 | 11 0002 | 11 0021 | 11 0000 | | | | | Timing | | | | l | \/\rite | e-only | l | ı | ı | | | | | Data | | | | | 71110 | only | | | | | | | i | Register | | | | | | | | | | | | | TPG0H | TPG0 | 000038H | TPG0DF | TPG0DE | TPG0DD | TPG0DC | TPG0DB | TPG0DA | TPG0D9 | TPG0D8 | | | | 11 0011 | Higher | 00000011 | '' 305' | 11 0002 | '' 0000 | 11 0000 | 11 3000 | I II GODA | 11 3000 | 11 3000 | | | | | Timing | | | | | Write | e-only | | | | | | | | Data | | | | | | _ | | | | | | | | Register | | | | | | | | | | | | | TPG0DR | TPG0 | 000039H | _ | _ | TPGD05 | TPGD04 | TPGD03 | TPGD02 | TPGD01 | TPGD00 | | | | ., 5551 | Output | ********* | | | 0500 | '' 550' | 5255 | 5552 | 5541 | '' 5500 | | | | | Data | | | | | Write | e-only | | | | | | | l | Register | | | | | _ | | | | | | | | | | | | | | | | | | | | | | CAPCR | Capture | 000052H | CAP2T | CAP1T | CAPCL | VISFRS | VASFRS | TPR\$0 | CFGCL | CAFRS | | | | | Control | | (CFG) | (DFG) | | | | | | | | | | | Register | | R | R | | | R | W | • | • | | | | | - | | 0 | 0 | | | | 0 | | | | | | | | | CAP2 | CAP1 | CAP1/ | VISS | VASS | TPG0 | CFG flag | Capture0 | | | | | | | trigger | trigger | CAP2 | detect flag | detect flag | FIFO | clear | FIFO | | | | | | | input status | input status | status clear | clear | clear | counter | | counter/ | | | | | | | | | | | | clear & | | status | | | | | | | 0: | 0: | 0: — | | 0: — | INTTPG0 | 0: — | clear | | | | | | | No trigger | | | 0: — | 1: Clear | disable | 1: Clear | | | | | | | | input | input | (One-shot) | 1: Clear | (One-shot) | 0: — | (One-shot) | 0: — | | | | | | | 1: Trigger | 1: Trigger | | (One-shot) | | 1: Clear & | | 1: Clear | | | | | | | input | input | | | | Inhibit | | (One-shot) | | | | | | | | | | | | (One-shot) | | | | | Timing Pulse Generator 1 (TPG1) | | | | | g . u.e. | Oomorate | ( | • / | | | | |--------|------------|---------|-----------------------------------------------------------------------|----------|----------|--------|--------|--------|--------|--------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TPG1L | TPG1 | 00003AH | TPG1D7 | TPG1D6 | TPG1D5 | TPG1D4 | TPG1D3 | TPG1D2 | TPG1D1 | TPG1D0 | | | Lower | | | | | | | | | | | | Timing | | | | | ν | ٧ | | | | | | Data | | | | | ( | ) | | | | | | Register1L | | | | | | | | | | | TPG1H | TPG1 | 00003BH | TPG1DF TPG1DE TPG1DD TPG1DC TPG1DB TPG1DA TPG1D9 TPG1D8 | | | | | | | TPG1D8 | | | Higher | | | | | | | | | | | | Timing | | | | | ٧ | ٧ | | | | | | Data | | | | | ( | ) | | | | | | Register1H | | | | | | | | | | | TPG1DR | TPG1 | 00003CH | _ | _ | _ | _ | TPGD13 | TPGD12 | TPGD11 | TPGD10 | | | Output | | | | | | | | | | | | Data | | W | | | | | | | | | | Register | | | | | | | | | | | | | | | | | | · | | | · | # 14BIT PWM 0, 1, 2 | | | | | T T V VIVI O | | | | | | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PWM | 00003DH | _ | _ | _ | _ | _ | PWM2- | PWM1- | PWM0- | | Start | | | | | | | -RUN | -RUN | -RUN | | Control | | | | | | | | R/W | | | Register | | | | | | | | 0 | | | | | | | | | | 0: | Stop 1: R | ın | | PWM0 | 00003EH | PWM0D7 | PWM0D6 | PWM0D5 | PWM0D4 | PWM0D3 | PWM0D2 | PWM0D1 | PWM0D0 | | lower | | | | | Write | e-only | | | | | Data | | | | | _ | _ | | | | | Register | | | | | | | | | | | PWM0 | 00003FH | _ | _ | PWM0DD | PWM0DC | PWM0DB | PWM0DA | PWM0D9 | PWM0D8 | | Higher | | | | | | Write | -only | | | | Data | | | | | | _ | _ | | | | Register | | | | | | | | | | | PWM1 | 000040H | PWM1D7 | PWM1D6 | PWM1D5 | PWM1D4 | PWM1D3 | PWM1D2 | PWM1D1 | PWM1D0 | | Lower | | | | | Write | -only | | | | | Data | | | | | _ | _ | | | | | Register | | | | | | | | | | | PWM1 | 000041H | _ | _ | PWM1DD | PWM1DC | PWM1DB | PWM1DA | PWM1D9 | PWM1D8 | | Higher | | | | | | Write | -only | | | | Data | | | | | | _ | _ | | | | Register | | | | | | | | | | | PWM2 | 000042H | PWM2D7 | PWM2D6 | PWM2D5 | PWM2D4 | PWM2D3 | PWM2D2 | PWM2D1 | PWM2D0 | | Lower | | | | | Write | -only | | | | | Data | | | | | _ | _ | | | | | Register | | | | | | | | | | | PWM2 | 000043H | _ | _ | PWM2DD | PWM2DC | PWM2DB | PWM2DA | PWM2D9 | PWM2D8 | | Higher | | | | | | Write | ⊢only | | | | Data | | | | | | _ | _ | | | | Register | | | | | | | | | | | | PWM Start Control Register PWM0 lower Data Register PWM0 Higher Data Register PWM1 Lower Data Register PWM1 Lower Data Register PWM1 Higher Data Register PWM2 Lower Data Register PWM2 Higher Data Register PWM2 Higher Data | PWM 00003DH Start Control Register PWM0 00003EH lower Data Register PWM0 00003FH Higher Data Register PWM1 000040H Lower Data Register PWM1 000041H Higher Data Register PWM2 000042H Lower Data Register PWM2 000043H Higher Data Register PWM2 000043H Higher Data Register | PWM Start 00003DH — Control Register — — PWM0 lower Data Register — — PWM0 higher Data Register — — PWM1 Lower Data Register — — PWM1 Higher Data Register — — PWM1 Higher Data Register — — PWM2 Lower Data Register — — PWM2 Lower Data Register — — PWM2 NM2 NM2D7 — — PWM2 NM2 NM3 | PWM Start 00003DH — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | PWM Start 00003DH — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | PWM Start 00003DH — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | PVM Start Control Register PVM0 O0003EH PVM0D7 PVM0D6 PVM0D5 PVM0D4 PVM0D3 PVM0D6 PVM0D5 PVM0D6 PVM1D6 PVM | PWM Start 00003DH — — — — PWM2-RUN Control Register — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | PWM Start 00003DH Start — — — — PWM2 - RUN PWM1 - RUN Control Register — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | ## 8BIT PWM 3 - 11 | | | | | <b>v</b> | | | | | | | |--------|----------|---------|-----------|----------|---------|--------------|----------------|----------------|-----------------------------------------------|-----------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PWMDBR | 8bit PWM | 000044H | PWMDBR7 | PWMDBR6 | PWMDBR5 | PWMDBR4 | PWMDBR3 | PWMDBR2 | PWMDBR1 | PWMDBR0 | | | Data | | | | | Write | e-only | | | | | | Buffer | | | | | _ | _ | | | | | | Register | | | | 8-1 | oit PWM data | a buffer regis | ter | | | | PWMCR | 8bit PWM | 000045H | PWMEOT | _ | | _ | PWMDLS3 | PWMDLS2 | PWMDLS1 | PWMDLS0 | | | Control | | R | | | | | WRITE | ONLY | | | | Register | | 0 | | | | | ( | ) | | | | | | End flag | | | | PWM chann | el select and | d data transf | er | | | | | of | | | | The PWMD | BR data is st | ored to the | selected | | | | | PWM data | | | | PWM chann | el after setti | ng this chan | nel code. | | | | | transfer | | | | This code m | ust be set w | hen <pwme< td=""><td>EOT&gt; = 0</td></pwme<> | EOT> = 0 | | | | | | | | | | D. | | | | | | | 0: End of | | | | 0000: PWM | | | : PWM11 | | | | | transfer | | | | 0001: PWM | 4 0101: PV | VM8 | | | | | | 1: Under | | | | 0010: PWM | 5 0110: PV | VM9 | | | | | | transfer | | | | 0011: PWM | 6 0111: PV | VM10 | | Capture Control | | | | | | pture Con | | т | 1 | | | |----------|-----------|---------|--------------|-------------|---------------|----------------|---------------|----------------|----------------|-------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | ,0 | | CAPINCR0 | Capture | 000046H | CAP2E | CAP1E | CAP05E | CAP04E | CAP03E | CAP02E | CAP01E | CAP00E | | | | | (CFG) | (DFG) | (DPG) | (EXT) | (CTL) | (VS) | (RMTD) | (RMTU) | | | Input | | | | | R | /W | | | | | | Control | | | | | į | 0 | | | | | | Register0 | | | | Capture 0, 1 | /2 input sour | ce enable/di | sable contro | | | | | | | | | | 0: Disable | 1: Enable | | | | | CAPINCR1 | Capture | 000047H | PCTLCK1 | PCTLCK0 | PCPR5 | PCPR4 | PCPR3 | PCPR2 | PCPR1 | PCPR0 | | | Input | | R | /W | | | R | W | | | | | Control | | | 0 | | | ( | ) | | | | | Register1 | | CTL duty m | easure | | 6-bit | programmal | ole divider co | ontrol | | | | | | clock select | | Dividing rate | e selection fo | or CTLIN (fro | m P80) and | CFGIN (from | P85). | | | | | (VIVACR2< | PCTLCKS> | | | | | | | | | | | = 0) | | 000000: 1/1 | | | | | | | | | | | | 000001:1 /2 | : 111111: | 1/64 | | | | | | | | 00: TBC3 | 01: TBC5 | | | | | | | | | | | 10: TBC7 | 11: TBC10 | | | , | | | | | CAPINCR2 | Capture | 000048H | | RMTST | RMTP0 | RMTBP | CFGMCP | DPCP2 | DPCP1 | DPCP0 | | | Input | | | R/W | R/W | R/W | R | | R/W | | | | Control | | | 0 | 0 | 0 | 0 | | 0 | | | | Register2 | | | RMTIN | RMTIN | Noise | CFG status | 3-bit progra | mmable divid | der control | | | | | | start/stop | input | canceller/ | flag | Dividing rate | e selection fo | or DFGIN | | | | | | control | polarity | correction | | (from P81) | | | | | | | | | selection | circuit | | | | | | | | | | | | control | | 000: 1/1 | | | | | | | | 0: Stop & | 0: Positive | | | 001: 1/2 1 | 11: 1/8 | | | | | | | counter | (+) | 0: Active | 0: Normal | | | | | | | | | clear | 1: Negative | 1: Bypass | 1: Error | | | | | | | | | 1: Start | (-) | | | | | T | | CAPINCR3 | Capture | 000049H | | CTLPO | CFGPO | DPGEG | DFGEG | CFGWPR | CFGEG | CTLEG | | | Input | | | R/W | | Control | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Register3 | | | CTL input | CFG input | Edge | Edge | Dividing | Edge | Edge | | | | | | polarity | polarity | selection | selection | rate | selection | selection | | | | | | selection | selection | for DPG | for DFG | selection | for CFG | for CTLIN | | | | | | | | input | input | for CFG | input | input | | | | | | | | | | input | | | | | | | | 0.00 | D D | | | | 0.5.11 | 0:Rising | | | | | | 0: Positive | 0: Positive | | | | 0: Both | 1: Both | | | | | | (+) | (+) | O. Dialar | O. Dining | 0. 4/4 | rising | rising | | | | | | 1 * | 1: Negative | 1 | 0: Rising | 0: 1/1 | and | and | | | | | | (-) | (-) | 1: Falling | 1: Falling | 1 :1/2 | falling | falling | | | | | | | l | | | | 1: Rising | | Capture 0 | CVMBOL | Nome | Address | 7 | | Jule 0 | 4 | 2 | 2 | 1 | 0 | |-------------------|---------------|----------|---------------------|---------------------------|---------------|---------------------|------------|----------------|--------------|------------| | SYMBOL<br>VIVACR2 | Name<br>VISS/ | 000055H | 7<br>PCTLPO | 6<br>PCTLCKS | 5<br>MSK1 | 4<br>MSK0 | 3<br>VISS3 | 2<br>VISS2 | VISS1 | 0<br>VISS0 | | VIVACRZ | VASS | 00005511 | R/W | R/W | R/W | R/W | VISSS | | W | V1550 | | | Control | | 0 | 0 | 0 | 0 | | | )<br>D | | | | | | | CTL duty | Dividing | | | | npare data | | | | Register2 | | CTL signal polarity | 1 ' | | masking control for | | VISS COII | ipare data | | | | | | selection | measuring clock selection | CTLIN | CFG input | Thosa | A bit data s | are compare | d with | | | | | Selection | Clock selection | input | 0: Mask | l | | 6-bit CTL co | | | | | | 0: Positive | 0: Selected | Imput | 1: Bypass | Iligile | 1 4DIL OI LITE | 0-DIL CTL C | Juniei | | | | | (+)(when | 1 | 0: Divide | т. Буразз | | | | | | | | | duty is | CAPINCR1 | 1: Bypass | | | | | | | | | | less than | 1 | | | | | | | | | | | 50%, | 2> | | | | | | | | | | | VIVACR1 | _ | | | | | | | | | | | l | 1: Automatic | | | | | | | | | | | is set to 1) | selection | | | | | | | | | | | <b>'</b> | | | | | | | | | | | | 1: Negative | | | | | | | | | | | | (-)(when | | | | | | | | | | | | duty is | | | | | | | | | | | | less than | | | | | | | | | | | | 50%, | | | | | | | | | | | | VIVACR1 | | | | | | | | | | | | <ctldty></ctldty> | | | | | | | | | | | | is set to 0) | | | | | | | | | | | | | | | | | | I | | | CAPFST | Capture0 | 00004AH | CAPF7 | CAPF6 | CAPF5 | CAPF4 | CAPF3 | CAPF2 | CAPF1 | CAPF0 | | | | | (FIFO8) | (FIFO7) | (FIFO6) | (FIFO5) | (FIFO4) | (FIFO3) | (FIFO2) | (FIFO1) | | | FIFO | | | | | Read-or | nly | | | | | | Status | | | | | 0 | | | | | | | Register | | | | | tus 0: Empt | ř · | | | | | CAP0L | Capture0 | 00004BH | CAP0D7 | CAP0D6 | CAP0D5 | CAP0D4 | CAP0D3 | CAP0D2 | CAP0D1 | CAP0D0 | | | Lower | | | | | Read-or | nly | | | | | | Data | | | | | | | | | | | | Register | | | | | | | | | | | 0.4.004.4 | 0 | 00004011 | 0450545 | 0450544 | LOADOD40 | 0.4.000.4.0 | 0450544 | 0.4.000.4.0 | 045050 | 045050 | | CAP0M | Capture0 | 00004CH | CAP0D15 | CAP0D14 | CAPOD13 | CAP0D12 | | CAP0D10 | CAP0D9 | CAP0D8 | | | Middle | | | | | Read-or | пу | | | | | | Data | | | | | | | | | | | | Register | | | | | | | | | | | CAROLL | Camting | 00004511 | CAPOTE | CAPOTA | CAPOTO | CAROTO | CAPOT | CAROTO | CADOD47 | CADODAG | | CAP0H | Capture0 | 00004DH | CAP0T5 | CAP0T4 | CAP0T3 | CAP0T2 | CAP0T1 | CAP0T0 | CAP0D17 | | | | Higher | | | | Read-oi | าเง | | | Read | i-only | | | Data | | | | | | | | | | | | Register | | | | | | | | - | | | | | | | | Frigger input | | inn | | Capture0 h | igner data | | | | | | 0: No trigge | er input | 1: Trigger | input | | | | Capture 1, 2 | | | | | | zapiule i, | | | | | | |---------|----------|----------|----------|----------|------------|---------|---------|----------|---------|---------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CAP1L | Capture1 | 00004EH | CAP1D7 | CAP1D6 | CAP1D5 | CAP1D4 | CAP1D3 | CAP1D2 | CAP1D1 | CAP1D0 | | | Lower | | | | | Read | l-only | | | | | | Data | | | | | | | | | | | | Register | | | | | | _ | | | | | CAP1H | Capture1 | 00004FH | CAP1D15 | CAP1D14 | CAP1D13 | CAP1D12 | CAP1D11 | CAP1D10 | CAP1D9 | CAP1D8 | | OAI III | Higher | 00004111 | OAI IBIO | OAI IBI4 | OAI IDIO | | l-only | OAI IDIO | OAI 100 | OAI IDO | | | Data | | | | | | · | | | | | | Register | | | | | _ | _ | | | | | | | | | | | | | | | | | CAP2L | Capture2 | 000050H | CAP2D7 | CAP2D6 | CAP2D5 | CAP2D4 | CAP2D3 | CAP2D2 | CAP2D1 | CAP2D0 | | | Lower | | | | | Read | l-only | | | | | | Data | | | | | | | | | | | | Register | | | | | | | | | | | | | | | | | | ı | | | | | CAP2H | Capture2 | 000051H | CAP2D15 | CAP2D14 | CAP2D13 | CAP2D12 | CAP2D11 | CAP2D10 | CAP2D9 | CAP2D8 | | | Higher | | | | | Read | l-only | | | | | | Data | | | | | | | | | | | | Register | | | | | _ | _ | | | | | | | | 1 | | | | | | | | Remote Control Input (RMTIN) | | Trainete Control Input (Timens) | | | | | | | | | | | |--------|---------------------------------|---------|-------|----------------------------|-------------|-------|----------------------------|---|--------------|---|--| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RMTCR | RMTIN | 000053H | RMTD7 | RMTD6 | RMTD5 | RMTD4 | RMTD3 RMTD2 RMTD1 RMTD | | | | | | | Control | | | R/ | W | | R/W | | | | | | | Register | | | ( | ) | | | ( | ) | | | | | | | ŀ | level Noise | cancel widt | า | L level Noise cancel width | | | | | | | | | 4 | 4-bit data (TBC8: 25.6 μs) | | | | | 3C8: 25.6 µs | ) | | # VISS/VASS | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |---------|-----------|---------|------------------------------------------------------|------------------------|--------|--------------|--------------|-------------------------------|-------------|-------------|--|--|--|--| | VIVACR1 | VISS/ | 000054H | | _ | _ | _ | _ | CTLDTY | VISSFL | VASSFL | | | | | | | VASS | | (set to 0) | | | | | R | R | R | | | | | | | Control | | 0 | | | | | 0 | 0 | 0 | | | | | | | Register1 | | | | | | | | VISS detect | VASS | | | | | | | | | | | | | | | flag | detect flag | | | | | | | | | | | | | | detector | | | | | | | | | | | | | | | | monitor flag | | 0: — | | | | | | | | | | | | | | | | 1: VASS | | | | | | | | | | | | | | 0: CTL duty<br>greater | detected | detected | | | | | | | | | | than 50% | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | (VIVACR2 | | | | | | | | | | | | | | | | | | | | = 0) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1: CTL duty | | | | | | | | | | | | | | | | less than | | | | | | | | | | | | | | | | 50% | | | | | | | | | | | | | | | | (VIVACR2<br><pctlpo></pctlpo> | | | | | | | | | | | | | | | | = 0) | | | | | | | | VASSDR | VASS Data | 000056H | VASS7 | VASS6 | VASS5 | VASS4 | VASS3 | VASS2 | VASS1 | VASS0 | | | | | | | Register | | | | | VASS lowe | r 8-bit data | | | | | | | | | | | | VASS15 | VASS14 | VASS13 | VASS12 | VASS11 | VASS10 | VASS9 | VASS8 | | | | | | | | | | VASS higher 8-bit data | | | | | | | | | | | | | | | | | | Read | l-only | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | vice reading | | | | | | | | | | | | | The First is lower 8-bit, the second is higher 8-bit | | | | | | | | | | | | # CSYNC, PV, CR/HA | | | | | | 110, 1 4, 0 | | | | | | |--------|------------|-----------|------------|---|-------------|--------------|------------|------------|-------------------|------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CSYNCR | CSYNC | 000057H | COMPS | - | | CSYNCPO | SEPMOD | CSYNBP | HSEN | MASK | | | Control | | R/W | | | R/W | R/W | R/W | R/W | R/W | | | Register | | 0 | | | 0 | 0 | 0 | 0 | 0 | | | | | COMPIN | | | CSYNC | 7-bit | CSYNC | Pseudo-Hsync | Vsync | | | | | input | | | input signal | counter | bypass | generation to | mask | | | | | control | | | , , | up/down | control | PV/PH | control | | | | | | | | selection | count | l | | 0: — | | | | | 0: Disable | | | | selection | | | 1: Release | | | | | (TPG00/ | | | | (duty) | 1: Bypass | synchronized | | | | | | TPG05 | | | 1: Negative | | | | (One-shot) | | | | | Output) | | | | = 1/1 | | input | | | | | | 1. Enable | | | | 1: up/down | | 1: synchronize | | | | | | 1: Enable | | | | = 1/2 | | with Csync | | | D) (OD | 5) ( 0 ( ) | 000000011 | | | | | 51.10.0137 | B) (OEL O | input | D) (05) 0 | | PVCR | PV Control | 000058H | | _ | | | PHMIX | PVSEL2 | PVSEL1 | PVSEL0 | | | Register | | | | | | R/W | | R/W | | | | | | | | | | 0 | | 0 | | | | | | | | | | PH mixing | PV/PH outp | out format contro | l | | 1 | | | | | | | | | | | | 1 | | | | | | | 0: OFF | | | | | | | | | | | | 1: ON | | | | # 8-bit A/D Converter | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|---------|------------|------------|----------------|---------------|------------|---------------|-------|-------| | ADMOD | A/D | 00005AH | | EOCF | ADBF | ADS | ADCH3 | ADCH2 | ADCH1 | ADCH0 | | | Converter | | (set to 1) | R | R | R/W | | R/ | N | | | | Control | | 1 | 0 | 0 | 0 | | C | ) | | | | Register | | | A/D | A/D | A/D | Analog cha | nnel selectio | n | | | | | | | conversion | conversion | conversion | | | | | | | | | | flag | busy flag | start /status | 0000: AIN0 | 1001: AIN9 | ı | | | | | | | | | | 0001: AIN1 | 1010: AIN1 | 0 | | | | | | | 0: During | 0: free (stop) | 0: — | 0010: AIN2 | 1011: AIN1 | 1 | | | | | | | or before | 1: busy | 1: A/D | 0011: AIN3 | 1100: AIN1 | 2 | | | | | | | converting | | conversion | 0100: AIN4 | 1101: AIN1 | 3 | | | | | | | 1: Finish | | start | 0101: AIN5 | 1110: AIN1 | 4 | | | | | | | conversion | | | 0110: AIN6 | 1111: AIN | 15 | | | | | | | | | | 0111: AIN7 | | | | | | | | | | | | 1000: AIN8 | | | | | ADREG | A/D | 00005BH | ADR7 | ADR6 | ADR5 | ADR4 | ADR3 | ADR2 | ADR1 | ADR0 | | | Converted | | | | | Read-on | ly | | | | | | Data | | | | | _ | | | | | | | Register | | | | | | | | | | # SIO 0 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------|---------|--------------|--------------|-------------|------------|-------------|------------|--------------|------------| | SCOMOD | Serial I/O | 000060H | FF0SI | S0RES | S0MOD1 | S0MOD0 | SIFT0 | CLK0SI | SCK0S | SIO0E | | | Channel 0 | | R | R/W | R/ | W | R/W | R/W | R/W | R/W | | | Mode | | 1 | 0 | ( | ) | 0 | 0 | 0 | 0 | | | Register | | Transfer | Serial | Transfer mo | ode select | Shift edge | Internal | Serial clock | Serial | | | | | monitor flag | transfer | | | select | clock rate | source | transfer | | | | | | terminate | 00: Transm | it mode | | select | select | enable/ | | | | | 0: Under | | 01: Receive | mode | 0: Leading | | | disable | | | | | transferring | 0: — | 10: — | | (Falling) | 0: TBC3 | 0: Internal | | | | | | 1: Stop | 1: Terminate | 11: Transm | it/receive | 1: Trailing | (0.8 µs) | clock | 0: Disable | | | | | | | mode | | (Rising) | 1: TBC7 | 1: External | 1: Enable | | | | | | | | | | (6.4 µs) | clock | | | SC0BUF | Serial I/O | 000061H | TRB07 | TRB06 | TRB05 | TRB04 | TRB03 | TRB02 | TRB01 | TRB00 | | | Channel 0 | | | | | R/V | ٧ | | | | | | Buffer | | | | | _ | | | | | | | Register | | | • | | • | | | • | | # SIO 1 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------|---------|--------------|--------------|-------------|------------|-------------|------------|--------------|------------| | SC1MOD | Serial I/O | 000062H | FF1SI | \$1RES | S1MOD1 | S1MOD0 | SIFT1 | CLK1SI | SCK1S | SIO1E | | | Channel 1 | | R | R/W | R/ | W | R/W | R/W | R/W | R/W | | | Mode | | 1 | 0 | C | ) | 0 | 0 | 0 | 0 | | | Register | | Transfer | Transfer | Transfer mo | de select | Shift edge | Internal | Serial clock | Serial | | | | | monitor flag | terminate | | | select | clock rate | source | transfer | | | | | | | 00: Transm | it mode | | select | select | enable/ | | | | | 0: Under | 0: — | 01: Receive | mode | 0: Leading | | | disable | | | | | transferring | 1: Terminate | 10: — | | (Falling) | 0: TBC3 | 0: Internal | | | | | | 1: Stop | | 11: Transm | it/receive | 1: Trailing | (0.8 µs) | clock | 0: Disable | | | | | | | mode | | (Rising) | 1: TBC7 | 1: External | 1: Enable | | | | | | | | | | (6.4 µs) | clock | | | SC1BUF | Serial I/O | 000063H | TRB17 | TRB16 | TRB15 | TRB14 | TRB13 | TRB12 | TRB11 | TRB10 | | | Channel 1 | | | | | R/V | ٧ | | | | | | Buffer | | | · | · | _ | - | | | · | | | Register | | · | · | · | | · | · | | | # SIO 2 (UART) | | | | | | <del>- (- (- (- (- (- (- (- (- (- (- (- (- (-</del> | | | | | | |---------|------------|----------|------------|---------|-----------------------------------------------------|------------|---------------|---------------|---------------|--------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SC2MOD | Serial I/O | 000064H | TB8 | CTSE | RXE | WU | SM1 | SM0 | SC1 | SC0 | | | Mode | | R/W | R/W | R/W | R/W | R | w | R/ | W | | | Control | | 0 | 0 | 0 | 0 | ( | ) | ( | ) | | | Register2 | | Transmit | Hand | Receiver | Wake up | Serial transf | er mode | Serial transt | er clock | | | | | data bit 8 | shake | function | function | | | (UART) | | | | | | | control | | | 00: (Reserv | ed) | | | | | | | | 0: CTS | 0: Receive | 0: Disable | 01: 7-bit UA | RT | 00: Timer 0 | - | | | | | | disable | disable | 1: Enable | 10: 8-bit UA | RT | 01: Baud ra | te generator | | | | | | 1: CTS | 1: Receive | | 11: 9-bit UA | RT | 10: Internal | clock: fc/2 | | | | | | enable | enable | | | ı | 11: (Reserv | ed) | | SC2CR | Serial | 000065H | RB8 | EVEN | PE | OERR | PERR | FERR | _ | _ | | | Control | | R | R/W | R/W | R(cleare | ed to Zero wh | en read) | | | | | Register2 | | | 0 | 0 | 0 | 0 | 0 | | | | | | | Received | Parity | Parity | Overrun | Parity error | Framing | | | | | | | data bit 8 | check | check | error flag | flag | error flag | | | | | | | | mode | | | | | | | | | | | | 0: Odd | 0: Disable | 0: — | 0: — | 0: — | | | | | | | | 1: Even | 1: Enable | 1: Error | 1:Error | 1: Error | | | | BR2CR | Baud Rate | 000066H | | | BR0CK1 | BR0CK0 | BR0S3 | BR0S2 | BR0S1 | BR0S0 | | | Generator | | (set to 0) | | R. | W | | R | /W | | | | Control | | 0 | | , | 0 | | | 0 | | | | Register | | | | Selecting th | e input | Divider for b | aud rate ger | nerator | | | | | | | | clock of bau | ıd rate | | | | | | | | | | | generator | | 0000: 1/16 | | | | | | | | | | | | 0001: 1/1 | | | | | | | | | | 00: TBC1 (0 | • ' | 0010 to 111 | 1: 1/2 to 1/1 | 5 | | | | | | | | 01: TBC2 (0 | | | | | | | | | | | | 10: TBC3 (0 | | | | | | | | | | | | 11; TBC4 (1 | - / | | | | | | 0005::- | | 2005 | | | @fc = 20 | | | | | <b>-</b> | | SC2BUF | Serial | 000067H | TB7 | TB6 | TB5 | TB4 | TB3 | TB2 | TB1 | TB0 | | | Transmit/ | | <u> </u> | | | | ansmit) | | | | | | Receive | | RB7 | RB6 | RB5 | RB4 | RB3 | RB2 | RB1 | RB0 | | | Buffer2 | Prohibit | | | | R: (Re | eceive) | | | | | | | RMW | | | | | | | | | I<sup>2</sup>CBUS (1) | | | | | | 1 0000 (1 | 7 | | | | | |--------|---------------------|----------|--------|---------------|-----------------------|---------------|----------------|--------|--------|----------------------------------------------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | I2CCR1 | I <sup>2</sup> CBUS | 000081H | BC2 | BC1 | BC0 | ACK | CHS | 1 | - | - | | | Control | | | WRITE | | R/W | R/W | | | | | | Register1 | | 0 | 0 | 0 | 0 | 0 | | | | | | | | Numb | er of transfe | rred bits | Clock pulse | Channel | | | | | | | | ACK = | | | generation | selection | | | | | | | | | | bits | for acknow- | | | | | | | | | 000: 8 | | 8 | -ledge bit | 0: Channel 0 | | | | | | | | 001: 1 | 1 2 | 1 | | (SCL0, | | | | | | | | 010: 2 | 2 3 | 2<br>3<br>4<br>5<br>6 | 0: Don't | SDA0) | | | | | | | | 011: 3 | 3 4 | 3 | l. <u>-</u> . | l. <u>-</u> | | | | | | | | 100: 4 | 4 5 | 4 | 1: Generate | 1: Channel1 | | | | | | | | 101: 5 | 5 6 | 5 | | (SCL1, | | | | | | | Prohibit | 110: 6 | | | | SDA1) | | | | | 100000 | 1200110 | RMW | 111: 7 | | 7 | 1000004 | IODDDO | 100000 | IODDD1 | LIODEDO | | I2CDBR | I <sup>2</sup> CBUS | 000082H | I2DBR7 | I2DBR6 | I2DBR5 | I2DBR4 | I2DBR3 | I2DBR2 | I2DBR1 | I2DBR0 | | | Data | | | _ | | , <u>R</u> / | W | | 1 | | | | Buffer | | | | | | | | | | | | Register | | | | | | MSB for transr | | | | | I2CAR | I <sup>2</sup> CBUS | 000083H | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 | SA0 | ALS | | | Address | | | | _ | Write-only | | | | W | | | Register | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | TMP93C07 | 1 slave addre | ess selection | | | Addressing<br>mode<br>specifi-<br>-cation | | | | | | | | | | | | 0: Slave<br>address<br>1: (free<br>data<br>format) | I<sup>2</sup>CBUS (2) | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------------------|-------------|-----------|--------------|-------------|----------------|-------------------------|---------------|--------------|--------------| | I2CCR2 | I <sup>2</sup> CBUS | 000084H | MST | TRX | BB | PIN | SBIM1 | SBIM0 | (set to "0") | (set to "0") | | | Control | (Write) | 0 | 0 | 0 | 1 | 0 | 0 | * | * | | | Register2 | | Master/ | Transmitter/ | Start/stop | Cancel | Serial bus ir | nterface | | | | 1 | | | slave | receiver | condition | interrupt | operation m | ode selection | | | | | | | selection | selection | generation | service | | | | | | 1 | | | _ | | _ | | 00: Port mo | | | | | | | | | 0: Receiver | | | | tput disable) | | | | | | | 1: Master | 1: Transmit- | | | 01: (Reserv | | | | | | | B b. 16. 11 | | ter | 1: Start | interrupt | 10: I <sup>2</sup> CBUS | | | | | | | Prohibit | | | condition | service | 11: (Reserv | ed) | | | | | 1200110 | RMW | | | | request | | | | | | I2CSR | I <sup>2</sup> CBUS | 000084H | MST | TRX | BB | PIN | AL | AAS | AD0 | LRB | | | Status | (Read) | 0 | 0 | 0 | 1 | 0 | 0 | * | * | | | Register | | Status | Status | Status | | Arbitration | Slave | GENERAL | Last | | 1 | | | monitor | monitor | monitor | | lost | address | CALL | received | | | | | l | | | request status | | match | detection | bit monitor | | 1 | | | | 0: Receiver | | | monitor | detection | monitor | | | | | | 1: Master | | 1: Bus busy | | _ | monitor | l_ | 0: Last | | | | | | ter | | 0: Requested | | 0: — | 0: — | received | | 1 | | | | | | | 1: Arbitra- | 1: Slave | 1: GENERAL | bit 0 | | 1 | | | | | | 1: Released | tion lost | address | CALL | 1: Last | | | | | | | | | detected | match or | detected | received | | I | | | | | | | | GENERAL | | bit 1 | | I | | | | | | | | CALL | | | | | | | | | | | | detected | | | # I<sup>2</sup>CBUS (3) | | | | | | 1 0000 | (-) | | | | | |--------|---------------------|----------|------------|----------------|-------------|-----------------|------------------|------------|---|----------------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | I2CCR3 | I <sup>2</sup> CBUS | 000085H | DMAEN | DV4 | DV3 | DV2 | DV1 | DV0 | _ | SWRST | | | Control | | R/W | | | W | | | | R/W | | | Register3 | | 0 | 0 | 0 | 0 | 0 | * | * | 0 | | | | | micro DMA | Setting N-divi | der for gen | erating transfe | er clock sour | ce. | | I2CBUS | | | | | transfer | | | | | | | Software Reset | | | | | mode is | 00000: (Rese | rved) | 10000: (N=16 | 3); 74.6 | | | | | | | | enabled | 00001: (Rese | rved) | 10001: (N=17 | 7); 70. <b>4</b> | | | 0: — | | | | | | 00010: (N = 2 | 2); 454.5 | 10010: (N = | 18); 66.7 | | | (Initial state) | | | | | 0: Disable | 00011: (N = 3 | 3); 333.3 | 10011: (N = | 19); 63.3 | | | 1: Initialize | | | | | 1: Enable | 00100: (N = 4 | ); 263.2 | 10100: (N = 2 | 20); 60.2 | | | I <sup>2</sup> CBUS | | | | | | 00101: (N = 5 | 5); 217.4 | 10101: (N = 2 | 21); 57.5 | | | block | | | | | | 00110: (N = 6 | 5); 185.2 | 10110: (N = 2 | 22); 54.9 | | | (After | | | | | | 00111: (N = 7 | '); 161.3 | 10111: (N = 2 | 23); 52.6 | | | initialize | | | | | | 01000: (N = 8 | 3); 142.9 | 11000: (N = 2 | 24); 50.5 | | | I <sup>2</sup> CBUS, | | | | | | 01001: (N = 9 | • • | 11001: (N = 2 | 25); 48.5 | | | SWRST is | | | | | | 01010: (N = 1 | • | 11010: (N = 2 | 26); 46.7 | | | automatically | | | | | | 01011: (N = 1 | | 11011: (N = 2 | • | | | cleared to 0.) | | | | | | 01100: (N = 1 | * * | 11100: (N = 2 | * - | | | | | | | | | 01101: (N = 1 | • • | 11101: (N = 2 | | | | | | | | Prohibit | | 01110 :(N = 1 | · · | 11110: (N = 3 | ** | | | | | | | RMW | | 01111: (N = 1 | 5); 79.4 | 11111: (N = 3 | 31); 39.4 (kH | z) @20 MHz | | | I<sup>2</sup>CBUS (4) | | | | | | 1-CBUS (4 | '/ | | | | | |--------|---------------------|----------|-------------|-------------|---------------------|-----------------|------------|-------------------|----------------|------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | I2CCR4 | I <sup>2</sup> CBUS | 000086H | RSTR | T/R | DMAEND | RCONT | C3 | C2 | C1 | C0 | | | Control | | W | R/W | R | R/W | | F | ₹/W | | | | Register4 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Continuous | micro DMA | micro DMA | Continuous | Set | ting the num | ber of transfe | er byte | | | | | transfer | transfer | transfer end | receive mode | 0000: 16 b | yte 10 | 000: 8 byte | | | | | | command at | Transmit/ | flag | set at micro | 0001: 1 by | te 10 | 001: 9 byte | | | | | | micro DMA | Receive | | DMA transfer | 0010: 2 by | te 10 | 010: 10 byte | | | | | | transfer | mode | 0:— | mode | 0011: 3 by | te 10 | 011: 11 byte | | | | | | mode. | selection. | 1: Transfer | | 0100: 4 by | te 1 | 100: 12 byte | | | | | | This | | end | (receive). | 0101: 5 by | te 1 | 101: 13 byte | | | | | | command is | 0: Receive | | If the receive | 0110: 6 by | te 1 <sup>-</sup> | 110: 14 byte | | | | | | available | 1: Transmit | (set | mode is set | 0111: 7 by | te 1 | 111: 15 byte | | | | | | while | | condition) | to "Receiving | (slave add | ress + R/ W | ) is not conta | iined. | | | | | DMAEND = | | | over(C3-0) | The value | of (C3-0) is | decreased by | each micro | | | | | 1. | | Transmit: | byte", set this | DMA trans | fer (I2CDBR | access). | | | | | | | | I <sup>2</sup> CBUS | bit at a time. | This value | must be set | after (slave a | address + | | | | | | | has | | R/ W ) has | been set to | I2CDBR. | | | | | | 0: — | | transmitted | 0: Receive | | | | | | | | | 1: Restart | | the last | end mode | | | | | | | | | micro | | data. | 1: Receive | | | | | | | | | DMA | | | continuous | | | | | | | | | transfer | | Receive: | mode | | | | | | | | | for (C3-0) | | micro DMA | | | | | | | | | | set at a | | has read a | | | | | | | | | | time. | | data after | | | | | | | | | | | | I <sup>2</sup> CBUS | | | | | | | | | | (note) | | has | | | | | | | | | | T/R bit | | received | | | | | | | | | | must be set | | the last | | | | | | | | | | a previous | | data. | | | | | | | | | | value. | | | | | | | | | | | | | | (reset | | | | | | | | | | | | condition) | | | | | | | | | | | | | | | | | | | | | | | | Reset, | | | | | | | | | | | | Start/Stop | | | | | | | | | | | | command | | | | | | | | | | | | have been | | | | | | | | | | | | executed. | | | | | | | | | | | | RSTR | | | | | | | | | Prohibit | | | command | | | | | | | | | RMW | | | has been | | | | | | | | | | | | executed. | | | | | | # Interrupt priority setting register (1/2) (Prohibit read-modify-write) | SYMBOL Name Address 7 6 5 4 3 2 1 | | |-----------------------------------------------------------------------------------------------------------|------------| | | 0 | | INTOCP1 INTO/ 0070H INTCAP1 INTO | | | CAP1 ICAP1C ICAP1M2 ICAP1M1 ICAP1M0 IOC IOM2 IOM | IOM0 | | Interrupt "Prohibit R/W W W R/W W | W | | Setting RMW" 0 0 0 0 0 0 0 | 0 | | INTCP0TG0 CAP0/ 0071H INTTPG0 INTCAP0 | | | TPG0 ITPG0C ITPG0M2 ITPG0M1 ITPG0M0 ICAP0C ICAP0M2 ICAP0 | I1 ICAP0M0 | | Interrupt "Prohibit R/W W W R/W W | w | | Setting RMW" 0 0 0 0 0 0 | 0 | | INTTG1DMA TPG1/ 0072H INTI2DMA INTTPG1 | | | I2DMA II2DMAC II2DMAM II2DMAM II2DMAM ITPG1C ITPG1M2 ITPG1 | I1 ITPG1M0 | | 2 1 0 | | | Interrupt "Prohibit R/W W W R/W W W | W | | Setting RMW" 0 0 0 0 0 0 | 0 | | INTI2CTBC I2CBUS/ 0073H INTTBC INTI2CB | | | TBC ITBCC ITBCM2 ITBCM1 ITBCM0 II2CC II2CM2 II2CM | II2CM0 | | Interrupt | W | | Setting RMW" 0 0 0 0 0 0 | 0 | | INTSIOSI1 | | | SIO1 ISIO1C ISIO1M2 ISIO1M1 ISIO1M0 ISIO0C ISIO0M2 ISIO0I | 1 ISIO0M0 | | Interrupt "Prohibit R/W W W R/W W W | W | | Setting RMW" 0 0 0 0 0 0 | 0 | | INTRXTX RX/ 0075H INTTX INTRX | | | TX ITXC ITXM2 ITXM1 ITXM0 IRXC IRXM2 IRXM | IRXM0 | | Interrupt "Prohibit R/W W W R/W W W | W | | Setting RMW" 0 0 0 0 0 0 | 0 | | INTVA1 VA/ 0076H INT1 INTVA | | | INT1 I1C I1M2 I1M1 I1M0 IVAC IVAM2 IVAM | IVAM0 | | Interrupt | W | | Setting RMW" 0 0 0 0 0 0 | 0 | | INT23 INT2/ 0077H INT3 INT2 | | | INT3 I3C I3M2 I3M1 I3M0 I2C I2M2 I2M <sup>2</sup> | 12M0 | | Interrupt | W | | Setting RMW" 0 0 0 0 0 0 | 0 | | INT4T0 INT4/ 0078H INTT0 INT4 | | | Timer0 | 14M0 | | 1100 110112 110111 110110 110 111112 111111 | | | Interrupt | W | | Interrupt priority setting register (2/2) | Interrupt | priority | setting | register | (2/2) | |-------------------------------------------|-----------|----------|---------|----------|-------| |-------------------------------------------|-----------|----------|---------|----------|-------| | | | | IIICI | iupt piloi | ity octang | register | (2/2) | (Pro | hibit read-r | nodify-write | |---------|-----------|----------|------------|------------|-------------|------------|--------|--------|--------------|--------------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | INTT1T2 | Timer1/ | 0079H | | INI | T2 | | | INT | ΓT1 | | | | Timer2 | | IT2C | IT2M2 | IT2M1 | IT2M0 | IT1C | IT1M2 | IT1M1 | IT1M0 | | | Interrupt | Prohibit | R/W | W | W | W | R/W | W | W | w | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | INTT3T4 | Timer3/ | 007AH | | INI | T <b>4</b> | | | INT | ГТ3 | | | | Timer4 | | IT4C | IT4M2 | IT4M1 | IT4M0 | IT3C | IT3M2 | IT3M1 | IT3M0 | | | Interrupt | Prohibit | R/W | W | W | V | R/W | W | W | w | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | INTT5AD | Timer5/ | 007BH | | INT | AD | | | IN | TT5 | | | | AD | | IADCC | IADM2 | IADM1 | IADM0 | IADC | IADM2 | IADM1 | IADM0 | | | Interrupt | Prohibit | R/W | W | V | W | R/W | W | W | W | | | Setting | RMW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | INTRTCR | | 0080H | | (Always s | set to "0") | | | INT | RTC | | | | RTC | | (set to 0) | (set to 0) | (set to 0) | (set to 0) | IRTCMA | IRTCM2 | IRTCM1 | IRTCM0 | | | Interrupt | Prohibit | (R/W) | (R/W) | (W) | (W) | R/W | W | W | W | | | Setting | RMW | (0) | (0) | (0) | (0) | 0 | 0 | 0 | 0 | | | | | | <u> </u> | | | | | | | | ≽[ | lxxM2 | lxxM1 | lxxM0 | Function(Write) | |----|-------|-------|-------|-----------------------------------| | | 0 | 0 | 0 | Prohibit interrupt request. | | | 0 | 0 | 1 | Set interrupt request level to 1. | | | 0 | 1 | 0 | Set interrupt request level to 2. | | | 0 | 1 | 1 | Set interrupt request level to 3. | | | 1 | 0 | 0 | Set interrupt request level to 4. | | | 1 | 0 | 1 | Set interrupt request level to 5. | | | 1 | 1 | 0 | Set interrupt request level to 6. | | | 1 | 1 | 1 | Prohibit interrupt request. | | | IxxC | Function (Read) | Function (Write) | |---------------|------|---------------------------------|--------------------------------| | $\rightarrow$ | 0 | Indicates no interrupt request. | Clears interrupt request flag. | | | 1 | Indicates interrupt request. | don't care | ## Note 1: Read-modify-write is prohibited. ## Note 2: Note about clearing interrupt request flag. The interrupt request flag of INTCAP1, INTCAP0, INTSIO1, INTSIO1, INTRX and INTAD are not cleared by writing 0 to IxxC of they are level interrupts. They can be cleared only by resetting, reading captured data / ADREG /SC2BUF or reading/writing SC0BUF / SC1BUF. #### Note 3: Note about clearing interrupt request flag When the INTTPG0 is used for a FIFO empty interrupt (a level signal), the interrupt controller also leaves a request flag (Flip/Flop) after clearing FIFO empty by setting next TPG0 data in an interrupt routin. Therefore, in this case, the INTTPG0 request flag has to be cleared before executing RETI instruction. ## Micro DMA Start Vector | | WICO DIVIA Statt Vector | | | | | | | | | | | |--------|-------------------------|---------|---|---|-------------------------------------------|--------|---------------|----------------|---------|--------|--| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DMA0V | micro | 00007CH | | | DMA0V5 | DMA0V4 | DMA0V3 | DMA0V2 | DMA0V1 | DMA0V0 | | | | DMA0 | | | | | W (Re | ad-modify-w | rite is not po | ssible) | | | | | Start | | | | | | ( | ) | | | | | | Vector | | | | | S | Set micro DM | A start vector | or | | | | DMA1V | micro | 00007DH | | | DMA1V5 DMA1V4 DMA1V3 DMA1V2 DMA1V1 DMA1V | | | | | | | | | DMA1 | | | | W (Read-modify-write is not possible) | | | | | | | | | Start | | | | 0 | | | | | | | | | Vector | | | | Set micro DMA start vector | | | | | | | | DMA2V | micro | 00007EH | | | DMA2V5 | DMA2V4 | DMA2V3 | DMA2V2 | DMA2V1 | DMA2V0 | | | | DMA2 | | | | | W (Re | ad-modify-w | rite is not po | ssible) | | | | | Start | | | | | | ( | ) | | | | | | Vector | | | | | 5 | Set micro DM | IA start vecto | or | | | | DMA3V | micro | 00007FH | | | DMA3V5 DMA3V4 DMA3V3 DMA3V2 DMA3V1 DMA3V0 | | | | | | | | | DMA3 | | | | W (Read-modify-write is not possible) | | | | | | | | | Start | | | | 0 | | | | | | | | | Vector | | | | | 8 | Set micro DIV | IA start vecto | or | | | # Port2 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|---------|---------|----------|------------|------------|--------------|--------------|--------------|--------------| | P2 | PORT2 | 000006H | P27 | P26 | P25 | P24 | - | - | - | - | | | Register | | | R/ | W | | | | | | | | | | | | 1 | | 1 | 1 | 1 | 1 | | P2FC | PORT2 | 000009H | P27F | P26F | P25F | P24F | (set to "1") | (set to "1") | (set to "1") | (set to "1") | | | Function | | | V | ٧ | | | | | | | | Register | | | | 1 | | | | | | | | | | 0: PORT | 1: ADDRE | SS BUS (A2 | 23 to A20) | | | | | # Port 4 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |------------|----------|---------|-----|------------|-----|-----|-----|-----|--------------|--------------|--|--| | P <b>4</b> | Port4 | 00000AH | P47 | P46 | P45 | P44 | P43 | P42 | P <b>4</b> 1 | P <b>4</b> 0 | | | | | Register | | | R | | | | | | | | | | | | | | Input mode | | | | | | | | | ## Port 5 | | | | | | FULU | | | | | | | | |--------|-----------|---------|-------------|--------------|--------------|-------------------------|---------------------------|------------|--------------------------------------------------|------------------------|--|--| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | P5 | Port5 | 00000BH | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | | | | | Register | | | | | R | /W | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | P5CR | Port5 | 00000CH | P57C | P56C | P55C | P54C | P53C | P52C | P51C | P50C | | | | | Control | | | | | 1 | Ν | | | | | | | | Register | | | | | | 0 | | | | | | | | | | | | | 0:IN 1:OUT | | | | | | | | IIMC0 | Interrupt | 00005EH | _ | _ | – | I4IE | I3IE | I2IE | IIIE | IOIE | | | | | | | | | | (INT4) | (INT3) | (INT2) | (INT1) | (INT0) | | | | | Input | | | | | | | W | | | | | | | Mode | | | | | | | | | | | | | | Control | | | | | | | 0 | | | | | | | Register0 | | | | | | External interrupt enable | | | | | | | | | | | | | | 0: Di: | sable 1: E | nable<br>T | | | | | IIMC1 | Interrupt | 00005FH | I4EG | I3EG | I2EG | I1EG | I0EG | _ | <del> </del> | INTTPG0S | | | | | Input | | | | W | | | | R/W | R/W | | | | | Mode | | | | | | | | | | | | | | Control | | | l | 0 | I | T | | 0 | 0 | | | | | Register1 | | INT4 edge | INT3 edge | INT2 edge | INT1 | INTO | | INTTPG0 | INTTPG0 | | | | | | | selection | selection | selection | edge/level<br>selection | edge/level<br>selection | | interrupt<br>TPG03 | interrupt<br>selection | | | | | | | 0: Rising | 0: Rising | 0: Rising | Selection | selection | | edge | selection | | | | | | | 1: Falling | 1: Falling | 1: Falling | 0: Rising | 0: Rising | | selection | 0: FIFO | | | | | | | 17. Talling | T. T Gilling | T. T Gilling | edge | edge | | Colocaton | empty | | | | | | | | | | 1: Level | 1: Level | | 0: Rising | interrupt | | | | | | | | | | | | | 1: Falling | 1: FIFO | | | | | | | | | | | | | | empty/ | | | | | | | | | | | | | | TPG03 | | | | | | | | | | | | | | interrupt | | | ## Port 6 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------|-----------|---------|-----------|-----------|-----------|-----------|-----------|-----------------|-----------------|-----------------|--| | P6 | Port6 | 00000EH | P67 | P66 | P65 | P64 | P63 | P62 | P61 | P60 | | | | Register | | | | | F | Z/W | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | P6CR | Port6 | 000010H | P67C | P66C | P65C | P64C | P63C | P62C | P61C | P60C | | | | Mode | | | | | | W | | | | | | | Register | | | | | | 0 | | | | | | | | | | | | 0:IN | 1:OUT | | | | | | P6FC | Port6 | 000012H | P67F | P66F | P65F | P64F | P63F | P62F | P61F | P60F | | | | Function | | | W | | | | | | | | | | Register | | | | | | 0 | | | | | | | | | 0: Port67 | 0: Port66 | 0: Port65 | 0: Port64 | 0: Port63 | B2CS | B1CS | B0CS | | | | | | 1: PWM11 | 1: PWM10 | 1: PWM9 | 1: PWM8 | 1: PWM7 | <cs2en></cs2en> | <cs1en></cs1en> | <cs0en></cs0en> | | | | | | | | | | | = 0 | = 0 | = 0 | | | | | | | | | | | 0: Port62 | 0: Port61 | 0: Port60 | | | | | | | | | | | 1: PWM6 | 1: PWM5 | 1: PWM4 | | | ODCR0 | Open | 000014H | POD67 | POD66 | POD65 | POD64 | POD63 | POD62 | POD61 | POD60 | | | (P6ODCR) | Drain | | | | | | W | | | | | | | Control | | 0 | | | | | | | | | | | Register0 | | | | 0: 1 | oush-pull | 1: Open | drain | | | | ## Port 7 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|---------|--------------------|------|-----------------|--------------|-----------|------|------|--------------------| | P7 | Port7 | 00000FH | P77 | P76 | P75 | P74 | P73 | P72 | P71 | P70 | | | Register | | | | | F | R/W | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | P7CR | Port7 | 000011H | P77C | P76C | P75C | P74C | P73C | P72C | P71C | P70C | | | Control | | | | | | W | | | | | | Register | | | | | | 0 | | | | | | | | | | | 0:IN | 1:OUT | | | | | P7FC | Port6 | 000013H | P77F | _ | P75F | P74F | P73F | _ | _ | P70F | | | Function | | W | | | W | | | | W | | | Register | | 0 | | | 0 | | | | 0 | | | | | 0: Port77 | | 0: Port75 | 0: Port74 | 0: Port73 | | | 0: Port70 | | | | | 1: SCK0 | | 1: SO0 | 1: SCL0 | 1: SDA0 | | | 1: TXD | | ODCR1 | Open | 000015H | POD77 | _ | POD75 | POD74 | POD73 | _ | _ | POD70 | | | Drain | | W | | | W | | | | W | | | Control | | 0 | | | 0 | | | | 0 | | | Register1 | | 0: Push- | | | 0: Push-pul | l | | | 0: Push-pull | | | | | pull | | | 1: Open drai | in | | | 1: Open- | | | | | 1: Open- | | | | | | | drain | | | | | drain | | | T | T | | | | | PRDSEL | P7 | 00000DH | PR77 | _ | PR75 | PR74 | PR73 | _ | _ | PR70 | | | Register | | W | | | W | | | | W | | | Read | | 0 | | | 0 | | | | 0 | | | Value | | | | 0.5: | | | | | | | | Selection | | 0: Pin | | 0: Pin value | | | | | 0: Pin | | | | | value | | 1: Output value | | | | | value | | | | | 1: Output<br>value | | | | | | | 1: Output<br>value | | | 1 | | value | | | | | | | value | # Port 8 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|---------|------|------|------|-------|--------|------|------|------| | P8 | P8 | 000016H | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | | Register | | | | | R/ | W | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | P8CR | P8 | 000018H | P87C | P86C | P85C | P84C | P83C | P82C | P81C | P80C | | | Control | | | | | V | ٧ | | | | | | Register | | | | | ( | ) | | | | | | | | | | | 0: IN | 1: OUT | | | | ## Port 9 | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------|-----------|---------|--------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--| | P9 | P9 | 000017H | P97 | P96 | P95 | P94 | P93 | P92 | P91 | P90 | | | | | Register | | | | | R | /W | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | P9CR | P9 | 000019H | P97C | P96C | P95C | P94C | P93C | P92C | P91C | P90C | | | | | Control | | | | | ١ | N | | | | | | | | Register | | | 0 | | | | | | | | | | | | | 0: IN 1: OUT | | | | | | | | | | | P9FC | P9 | 00001AH | P97F | P96F | P95F | P94F | P93F | P92F | P91F | P90F | | | | | Function | | | | | 1 | Ν | | | | | | | | Register | | | | | | 0 | | | | | | | | | | 0: Port97 | 0: Port96 | 0: Port95 | 0: Port94 | 0: Port93 | 0: Port92 | 0: Port91 | 0 :Port90 | | | | | | | 1: TPG11 | 1: TPG10 | 1: TPG13 | 1: TPG04 | 1: TPG03 | 1: TPG02 | 1: TPG01 | 1: TPG12 | | | | ODCR2 | Open | 00001BH | POD97 | POD96 | POD95 | POD94 | POD93 | POD92 | POD91 | POD90 | | | | | Drain | | W | | | | | | | | | | | | Control | | | 0 | | | | | | | | | | | Register2 | | | | 0: F | oush-pull | 1: Open- | drain | · | · | | | #### Port A | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|----------|---|-----------------------------|----------------------|--------------|----------------------|----------|-------------|-----------------------| | PA | PortA | 00001CH | - | _ | PA5 | PA4 | PA3 | PA2 | PA1 | PA0 | | | Register | | | | | | R/ | W | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | PACR | PortA | 00001EH | | _ | PA5C | PA4C | PA3C | PA2C | PA1C | PA0C | | | Control | | | | | | ν | ٧ | | | | | Register | | | | | | ( | 0 | | | | | | | | | | | 0: IN | 1: OUT | | | | ODCR3 | Open | 000021H | _ | _ | _ | PWMOD1 | PWMOD0 | PODA5 | PODA4 | PODA3 | | | | | | | | (PWM1) | (PWM0) | (PortA5) | (PortA4) | (PortA3) | | | Drain | | | | | w w | | | | | | | Control | | | | | ( | 0 | | 0 | | | | Register3 | | | | | PWM0, 1 O | pen drain | PortA | Open drain | control | | | | | | | | control | | | | | | | | | | | | l | | 0: Push | -pull 1: Op | en drain | | | | | | | | 0: Push-pull | | | | | | DAFO | Dowl | 00000011 | | DA SE4 | DASEO | 1: Open dra | | DAGE | DA4E | DAGE | | PAFC | PortA | 00006BH | | PA5F1 | PA5F0 | PA4F | PA3F | PA2F | PA1F | PA0F | | | Function | | | W | W | W | W | W | W | W | | | Register | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | D: PORTAS<br>/PWM3 | 0: PORTA5<br>1: PWM3 | 1: WR | 0: PORTA3<br>1: PWM2 | 1: CR | 1: HA | 0: PORTA0<br>1: PV/PH | | | | | | /PVVIVI3<br><pa5f0></pa5f0> | I . PVVIVI3 | I. AAK | 1. PVVIVIZ | (TPG00) | (TPG05) | 1. PV/PH | | | | | | 1: HWR | | | | (1500) | (1500) | | | | | | | 1. 114411 | | | | | | | ## Port B | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|-----------|---------|---------------------------------------------|----------|--------------------------------------------|-----------|-----------|---------------|--------------|------------|--| | PB | PortB | 00001DH | _ | _ | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | | | | Register | | | | | F | R/W | | R/\ | N | | | | | | | | | | 1 | | 1 | | | | | | | | | | | | | (SYSCR0<) | (TEN> = 0) | | | PBCR | PortB | 00001FH | _ | _ | PB5C | PB4C | PB3C | PB2C | PB1C | PB0C | | | | Control | | | | | | | W | | | | | | Register | | | | 0 | | | | 0 | | | | | | | | | 0: IN 1: OUT | | | | 0: IN 1: OUT | | | | PBFC | PortB | 000020H | | | PB5F | PB4F | PB3F | PB2F | _ | 1 | | | | Function | | | | W | W | W | W | | | | | | Register | | | | 0 | 0 | 0 | 0 | | | | | | | | | | 0: PORTB5 | 0: PortB4 | 0: PORTB3 | 0: PORTB2 | | | | | | | | | | 1: SCL1 | 1: SDA1 | 1: SCK1 | 1: SO1/SI1 | | | | | ODCR4 | | 000022H | PRB5 | PRB4 | PRB3 | PRB2 | PODB5 | PODB4 | PODB3 | PODB2 | | | | Open | | (PortB5) | (PortB4) | (PortB3) | (PortB2) | (Portb5) | (PortB4) | (PortB3) | (PortB2) | | | | Drain | | · | | W | | | | | · | | | | Control | | 0 0 | | | | | | | | | | | Register4 | | PortB Read Value selection PortB Open drain | | | | | drain control | | | | | | | | 0: P | in value | 1: Output value 0: Push-pull 1: Open drain | | | | | in | | ## Port C | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|----------|---------|---|---|---|--------------|------|------|------|------| | PC | PC | 000087H | _ | _ | _ | PC4 | PC3 | PC2 | PC1 | PC0 | | | Register | | | | | R/W | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | PCCR | PC | 000088H | _ | _ | _ | PC4C | PC3C | PC2C | PC1C | PC0C | | Control | | | | | | W | | | | | | | Register | | | | | 0 | | | | | | | | | | | | 0: IN 1: OUT | | | | | Chip select/wait control register | | | | | | | itroi regist | | | | | |--------|----------|---------|---|----------------|---|--------------|-------------------|------|------------------------|------| | SYMBOL | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | B0CS | Block0 | 000068H | _ | CS0EN | _ | B0BUS | B0W1 | B0W0 | B0C1 | B0C0 | | | CS/WAIT | | | W | | W | W | | W | | | | Control | | | 0 | | 0 | 0<br>Wait Control | | 0 | | | | Register | | | 0: PORT60 | | BUS Width | | | 00: 2090H to 3FFFFFH | | | | | | | /PWM4 | | Control | | | 01: 400000H to 7FFFFFH | | | | | | | (P6FC | | | 00: 0 Wait | | 10: 800000H to BFFFFFH | | | | | | | <p60f>)</p60f> | | 0: 16-bit | 01: 1 Wait | | 11: C00000H to FFFFFFH | | | | | | | | | bus | 10: 1 Wait | | | | | | | | | 1: CS0 | | 1: 8-bit | 11: 2 Wait | | | | | | | | | | | bus | | | | | | B1CS | Block1 | 000069H | _ | CS1EN | | B1BUS | B1W1 | B1W0 | B1C1 | B1C0 | | | CS/WAIT | | | W | | W | \ | ٧ | | W | | | Control | | | 0 | | 0 | 00: 0 Wait 1 | | 0 | | | | Register | | | 0: PORT61 | | BUS Width | | | 00: 2090H to 3FFFFFH | | | | | | | /PWM5 | | Control | | | 01: 400000H to 7FFFFFH | | | | | | | (P6FC | | | | | 10: 800000H to BFFFFFH | | | | | | | <p61f>)</p61f> | | 0:16-bit | | | 11: C00000H to FFFFFH | | | | | | | | | bus | | | | | | | | | | 1: CS1 | | 1: 8-bit | | | | | | | | | | | | bus | | | | | | B2CS | Block2 | 00006AH | | CS2EN | _ | B2BUS | B2W1 | B2W0 | B2C1 | B2C0 | | | CS/WAIT | | | W | | W | W | | W | | | | Control | | | 0 | | 0 | 00: 0 Wait | | 0 | | | | Register | | | 0 :PORT62 | | BUS Width | | | 00: 2090H to 3FFFFFH | | | | | | | /PWM6 | | Control | | | 01: 400000H to 7FFFFFH | | | | | | | (P6FC | | | | | 10: 800000H to BFFFFFH | | | | | | | <p62f>)</p62f> | | 0: 16bit | | | 11: C00000H to FFFFFH | | | | | | | | | bus | 11: 2 Wait | | | | | | | | | 1: CS2 | | 1: 8bit | | | | | | | | | | | | bus | | | | | # 6. Port Section Equivalent Circuit Diagram · Reading the circuit diagram Basically, the gate symbols written are the same as those used for the standard CMOS logic IC [74HCxx] series. The dedicated signal is described below. STOP: This signal becomes active 1 when the halt mode setting register is set to the STOP mode (WDMOD<HALT1, 0> = 0, 1) and the CPU executes the HALT instruction. When the drive enable bit WDMOD<DRVE> is set to 1, however, STOP remains at 0. · The input protection resistans ranges from several tens ohms to several hundreds of ohms. P24/A20 to P27/A23, A0 to A19, RD P50/INT4/TI3 to P52/INT2/TI1, P71/RXD, P72/ CTS, P76/SI0, P80/CTLIN to P87/COMPIN # P53/INT1 to P54/INT0 # D0 to D15, PA0/PV-PH to PA2/CR (TPG00) # P40/AIN3 to P47/AIN10 ## P55/TI5/AIN0 to P57/TI0/AIN2 ## PC0/AIN11 to PC4/AIN15 # P60/PWM4/ CS0 to P67/PWM11, P90/TPG12 to P97/TPG11, PA3/PWM2 to PA5/PWM3/ HWR # P70/TXD, P73/SDA0 to P75/SO0, P77/SCK0, PB2/SO1/SI1 to PB5/SCL1 ## PB0/XT1, PB1/XT2 **TOSHIBA** X1, X2 # RESET # AM8/16 $\overline{\mathsf{EA}}$ # PWM0, PWM1 # ADREF, ADGND Note: IREF flows continuously at standby. TOSHIBA #### 7. Points of Concern and Restriction - (1) Notation - ① Explanation of a built-in I/O register: Register Symbol <Bit Symbol> - e.g.) TRUN<T0RUN> ··· Bit T0RUN of Register TRUN - ② Read, Modify and Write Instruction An instruction in which the CPU executes following by one instruction. - 1. CPU reads data of the memory. - 2. CPU modifies the data. - 3. CPU writes the data to the same memory. ex1) SET 3, (TRUN) set bit 3 of TRUN ex2) INC 1, (100H) increment the data of 100H A sample Read, Modify and Write instructions using the TLCS-900 ``` Exchange EX (mem), R Arithmetic Operation ADD (mem), R/# ADC (mem), R/# (mem), R/# SUB (mem), R/# SBC INC #3, (mem) DEC #3, (mem) Logical Operation (mem), R/# OR (mem), R/# AND XOR (mem), R/# Bit Manipulation STCF #3/A, (mem) SET #3, (mem) RES #3, (mem) TEST #3, (mem) CHG #3, (mem) Rotate and Shift (mem) RRC RLC (mem) RL (mem) RR (mem) SLA SRA (mem) (mem) SLL (mem) SRL (mem) RLD (mem) RRD (mem) ``` The clock frequency input from pins X1 and X2 pin is called fc, and the clock frequency input from XT1, XT2 pin is called fs. The clock frequency selected by SYSCR1<SYSCK, GEAR2 to 0 > is called system clock f<sub>FPH</sub>, and the clock frequency given by f<sub>FPH</sub> divided by 2 is called f<sub>SYS</sub>. One cycle of f<sub>SYS</sub> is called 1 state. <sup>3</sup> fc, fs, f<sub>FPH</sub>, f<sub>SYS</sub>, 1 state #### (2) Care Points #### ① EA EA, AM8 / 16 pin Fix these pins Vcc or Vss unless changing voltage. #### ② Warmingup Counter The warm-up counter operates when STOP mode is released even if the system is using an external oscillator. As a result, it takes warm-up time from inputting the releasing request to outputting the system clock. #### 3 WatchDog Timer The watchdog timer starts operation immediately after the reset is released. When the watchdog timer is not used, disable it. #### Only the "LDC cr, r", "LDC r, cr" instructions can be used to access the control registers in the CPU (like the transfer source address register (DMASn)). #### ⑤ POP SR instruction Execute the POP SR instruction during DI. Set "1" to SYSCR3<CLKEN> for stabilizing the operation current in slow mode and stop mode.