# **TOSHIBA** 16 Bit Microcontroller TLCS-900/L1 Series TMP91CW60FG TMP91CW60DFG Revision 1.0 **TOSHIBA CORPORATION** The information contained herein is subject to change without notice. TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property. In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc. The Toshiba products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These Toshiba products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. The products described in this document shall not be used or embedded to any downstream products of which manufacture, use and/or sale are prohibited under any applicable laws and regulations. The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patents or other rights of TOSHIBA or the third parties. Please contact your sales representative for product-by-product details in this document regarding RoHS compatibility. Please use these products in this document in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances. Toshiba assumes no liability for damage or losses occurring as a result of noncompliance with applicable laws and regulations. © 2007 TOSHIBA CORPORATION All Rights Reserved # Revision History | Date | Revision | | | |------------|----------|-------------|--| | 2007/12/03 | 1.0 | New release | | ## CMOS 16 Bit Microcontroller # TMP91CW60FG/DFG | Product No. | ROM<br>(Flash ROM) | RAM | Package | |--------------|--------------------|----------|----------------------| | TMP91CW60FG | 128K bytes | 8K bytes | LQFP100-P-1414-0.50F | | TMP91CW60DFG | 120K byles | on bytes | QFP100-P-1420-0.65A | #### 1.1 **Features** - High-speed 16-bit CPU (900/L1 CPU) - Instruction mnemonics are upward-compatible with TLCS-900,900/H,900/L - 16 Mbytes of linear address space - General-purpose registers and register banks - 16-bit multiplication and division instructions; bit transfer and arithmetic instructions - Micro DMA: 4 channels (800ns/2 bytes at 20MHz) - Minimum instruction execution time: 200ns (at 20MHz) - · Built-in memory - ROM:128K bytes (Flash ROM) - RAM:8K bytes - · External memory expansion - Expandable up to 16 Mbytes (shared program/data area) - Can simultaneously support 8/16-bit width external data bus Dynamic data bus syzing - 8-bit timers: 6 channels - 16-bit timers: 5 channels - General-purpose serial interface: 5 channels - UART/Synchronous mode: 3 channels - I<sup>2</sup>C bus mode: 2 channels - 10-bit AD converter (Built-in Sample hold circuit): 16 channels - Special timer for CLOCK This product uses the Super Flash® technology under the licence of Silicon Storage Technology, Inc. Super Flash® is registered trademark of Silicon Storage Technology, Inc. 20070701-EN - The information contained herein is subject to change without notice. TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property. In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc. The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic applicances, etc.). These TOSHIBA products are neither - intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunctionor failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk - The products described in this document shall not be used or embedded to any downstream products of which manufacture, use and/or sale are prohibited under any applicable laws and regulations - The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by impli- - Please contact your sales representative for product-by-product details in this document regarding RoHS compatibility. Please use these products in this document in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances. Toshiba assumes no liability for damage or losses occurring as a result of noncompliance with applicable laws and regulations. Page 1 **TMP91CW60** - · Watchdog timer - Program patch logic: 6 banks - Chip select/wait controller: 4 channels - Interrupts: 57 interrupts - 9 CPU interrupts: Software interrupt instruction and illegal instruction - 36 internal interrupts: 7 priority levels are selectable - 12 external interrupts: 7 priority levels are selectable (among 1 interrupts are selectable edge mode) - Input/output ports: 83 pins - Standby function: Three HALT modes: IDLE2 (Programmable), IDLE1 and STOP - · Clock controller - Clock gear function: Select a High-frequency clock fc/1 to fc/16 - Oscillator for CLOCK (fs = 32.768 kHz) - · Operating voltage Flash read operation > Vcc=4.5 V - 5.5 V (fc max = 20MHz) - Package - LQFP100-P-1414-0.50F (TMP91CW60FG) - QFP100-P-1420-0.65A (TMP91CW60DFG) Page 2 2007-12-03 # 1.2 Pin Assignment Diagram Page 3 2007-12-03 Page 4 2007-12-03 # 1.3 Block Diagram Figure 1-3 Block Diagram Page 5 2007-12-03 # 1.4 Pin Names and Functions Table 1-1 Pin Names and Functions(1/3) | Pin<br>Name | Pin<br>Number | Input<br>/<br>Output | Functions | |-------------------------------|---------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P00-P07<br>AD0-AD7 | 8 | 10<br>10 | Port 0: I/O port that allows I/O to be selected at the bit level<br>Address data (Lower): 0 to 7 address/data bus | | P10-P17<br>AD8-AD15<br>A8-A15 | 8 | 10<br>10<br>0 | Port1: I/O port that allows I/O to be selected at the bit level Address data (Upper): 8 to 15 of address/data bus Address: 8 to 15 of address bus | | P20-P27<br>A0-A7<br>A16-A23 | 8 | 10<br>0 | Port 2: I/O port that allows I/O to be selected at the bit level Address: 0 to 7 of address bus Address: 16 to 23 of address bus | | PZ0<br>RD | 1 | 0 0 | Port Z0: Output port<br>Read:Strobe signal for reading external memory | | PZ1<br>WR | 1 | 0 | Port Z1: Output port Write: Strobe signal for writing data to pins AD0 to AD7 | | PZ2<br>HWR | 1 | 10<br>0 | Port Z2: I/O port (with pull-up resistor) High write: Strobe signal for writing data to pins AD8 to AD15 | | PZ3<br>R/W | 1 | 10<br>0 | Port Z3: I/O port (with pull-up resistor) Read/Write: 1 represents Read or Dummy cycle; 0 represents Write cycle. | | P30<br>TB3IN0<br>INT3<br>SDA0 | 1 | 10<br> <br> <br> <br> <br> | Port 30: I/O port 16-bit timer 3 input 0:Timer B3 count/capture trigger Input 0 Interrupt Request Pin 3: Interrupt request pin with programmable rising edge / falling edge. Serial bus interface data 0 in I2C bus Mode. | | P31<br>TB3IN1<br>INT4<br>SCL0 | 1 | 10<br>1<br>10 | Port 31: I/O port 16-bit timer 3 input 1:Timer B3 count/capture trigger Input 1 Interrupt Request Pin 4: Interrupt request on rising edge Serial bus interface clock 0 in I2C bus Mode. | | P32<br>WAIT<br>TB3OUT0 | 1 | 0-10 | Port 32: I/O port Wait: Pin used to request CPU bus wait ((1 N) wait mode) 16-bit timer 3 output 0: Timer B3 Output 0 | | P33<br>TB3OUT1 | 1 | 0 | Port 33: I/O port 16-bit timer 3 output 1: Timer B3 Output 1 | | P40<br>CS0<br>SCOUT | 1 | ) IO<br>O<br>O | Port 40: I/O port (with pull-up resistor) Chip Select 0: Outputs 0 when address is within specified address area System Clock Output: Outputs f <sub>SYS</sub> or fs clock. | | P41<br>CS1<br>TXD2 | 1 | 00 | Port.41: I/O port (with pull-up resistor) Chip Select 1: Outputs 0 when address is within specified address area Serial Send Data 2 | | P42<br>CS2<br>RXD2 | 1 | 10<br>0<br>1 | Port 42: I/O port (with pull-up resistor) Chip Select 2: Outputs 0 when address is within specified address area Serial Receive Data 2 | | P43<br>CS3<br>SCLK2<br>CTS2 | 1 | 10<br>0<br>10<br>1 | Port 43: I/O port (with pull-up resistor) Chip Select 3: Outputs 0 when address is within specified address area Serial Clock I/O 2 Serial Data Send Enable 2 (Clear to Send) | | P44<br>ALE | 1 | 10<br>0 | Port 44: I/O port (with pull-up resistor) Address Latch Enable | | P50-57<br>AN0-AN7 | 8 | 10<br>1 | Port 5: I/O port Analog input: Pin used to input to AD converter | Page 6 2007-12-03 Table 1-1 Pin Names and Functions(2/3) | Pin<br>Name | Pin<br>Number | Input<br>/<br>Output | Functions | |-----------------------|---------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P60-67<br>AN8-AN15 | 8 | IO<br>I | Port 6: I/O port Analog input: Pin used to input to AD converter | | P70<br>TAOIN | 1 | IO<br>I | Port 70: I/O port<br>8-bit timer 0 input: Timer A0 Input | | P71<br>TA1OUT | 1 | 10<br>0 | Port 71: I/O port<br>8-bit timer 1 output:Timer A1 Output | | P72<br>TA3OUT | 1 | 10<br>0 | Port 72: I/O port<br>8-bit timer 3 output:Timer A3 Output | | P73<br>TA4IN | 1 | IO<br>I | Port 73: I/O port<br>8-bit timer 4 input: Timer A4 Input | | P74<br>TA5OUT | 1 | 10<br>0 | Port 74: I/O port<br>8-bit timer 5 output:Timer A5 Output | | P75<br>INT0 | 1 | IO<br>I | Port 75: I/O port Interrupt Request Pin 0: Interrupt request pin with programmable level / rising edge / falling edge. | | P80<br>TB0IN0<br>INT5 | 1 | 10<br> <br> | Port 80: I/O port 16-bit timer 0 input 0:Timer B0 count/capture trigger Input 0 Interrupt Request Pin 5: Interrupt request pin with programmable rising edge / falling edge. | | P81<br>TB0IN1<br>INT6 | 1 | 10<br> <br> | Port 81: I/O port 16-bit timer 0 input 1:Timer B0 count/capture trigger Input 1 Interrupt Request Pin 6: Interrupt request on rising edge | | P82<br>TB0OUT0 | 1 | 10<br>0 | Port 82: I/Q port) 16-bit timer 0 output 0: Timer B0 Output 0 | | P83<br>TB0OUT1 | 1 | 10 | Port 83: I/O port<br>16-bit timer 0 output 1: Timer B0 Output 1 | | P84<br>TB1IN0<br>INT7 | 1 | IO | Port 84: I/O port 16-bit timer 1 input 0:Timer B1 count/capture trigger Input 0 Interrupt Request Pin 7: Interrupt request pin with programmable rising edge / falling edge. | | P85<br>TB1IN1<br>INT8 | 1 | IO | Port 85: I/O port 16-bit timer 1 input 1:Timer B1 count/capture trigger Input 1 Interrupt Request Pin 8: Interrupt request on rising edge | | P86<br>TB1OUT0 | | ) O | Port 86: I/O port 16-bit timer 1 output 0: Timer B1 Output 0 | | P87<br>TB1OUT1 | | 10 | Port 87: I/O port 16-bit timer 1 output 1: Timer B1 Output 1 | | P90<br>TXD0 | <b>)</b> 1 | 10 | Port 90: I/O port<br>Serial Send Data 0 | | P91<br>RXD0 | 1 | 10<br>I | Port 91: I/O port<br>Serial Receive Data 0 | | P92<br>SCLK0<br>CTS0 | 1 | 10<br>10<br>1 | Port 92: I/O port Serial Clock I/O 0 Serial Data Send Enable 0 (Clear to Send) | | P93<br>TXD1 | 1 | 10<br>0 | Port 93: I/O port<br>Serial Send Data 1 | | P94<br>RXD1 | 1 | IO<br>I | Port 94: I/O port<br>Serial Receive Data 1 | Page 7 2007-12-03 Table 1-1 Pin Names and Functions(3/3) | Pin<br>Name | Pin<br>Number | Input<br>/<br>Output | Functions | |--------------------------------|---------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P95<br>SCLK1<br>CTS1 | 1 | 10<br>10<br>1 | Port 95: I/O port Serial Clock I/O 1 Serial Data Send Enable 1 (Clear to Send) | | P96<br>XT1 | 1 | 10 | Port 96: I/O port<br>Low-frequency oscillator connection pin | | P97<br>XT2 | 1 | 10<br>0 | Port 97: I/O port Low-frequency oscillator connection pin | | PA0<br>TB2IN0<br>INT1 | 1 | 10<br>1<br>1 | Port A0: I/O port 16-bit timer 2 input 0:Timer B2 count/capture trigger Input 0 Interrupt Request Pin 1: Interrupt request pin with programmable rising edge / falling edge. | | PA1<br>TB2IN1<br>INT2 | 1 | 10<br> <br> | Port A1: I/O port 16-bit timer 2 input 1:Timer B2 count/capture trigger Input 1 Interrupt Request Pin 2: Interrupt request on rising edge | | PA2<br>TB2OUT0 | 1 | 10<br>0 | Port A2: I/O port<br>16-bit timer 2 output 0: Timer B2 Output 0 | | PA3<br>TB2OUT1 | 1 | 10<br>0 | Port A3: I/O port<br>16-bit timer 2 output 1: Timer B2 Output 1 | | PB0<br>TB4IN0<br>INT9<br>SDA1 | 1 | 10<br>1<br>1<br>10 | Port B0: I/O port 16-bit timer 4 input 0:Timer B4 count/capture trigger Input 0 Interrupt Request Pin 9: Interrupt request pin with programmable rising edge / falling edge. Serial bus interface data 1 in I2C bus Mode. | | PB1<br>TB4IN1<br>INT10<br>SCL1 | 1 | 10<br> <br> <br> <br> <br> | Port B1: I/O port 16-bit timer 4 input 1:Timer B4 count/capture trigger Input 1 Interrupt Request Pin 10: Interrupt request on rising edge Serial bus interface clock 1 in I2C bus Mode. | | PB2<br>TB4OUT0 | 1 | 10 | Port B2: I/O port<br>16-bit timer 4 output 0: Timer B4 Output 0 | | PB3<br>TB4OUT1 | 1 | 10 | Port B3: I/O port<br>16-bit timer 4 output 1: Timer B4 Output 1 | | NMI | 1 | 7 | Non-Maskable Interrupt Request Pin: Interrupt request pin with programmable falling edge or both edge. | | AM0-1 | 2 | 1 | Operation mode:Fixed to AM1 "1", AM0 "1". | | EMU0-1 | 2 | 0 | Set to Open pins | | RESET | <i>)</i> | 1 / | Reset: initializes TMP91CW60. (with pull-up resistor) | | VREFH | 1 | | Pin for reference voltage input to AD converter | | AVCC | 1 | | Power supply pin for AD converter | | AVSS | 1 | | GND pin for AD converter (0 V) | | X1/X2 | 2 | Ю | High frequency oscillator connection pins | | DVCC | 3 | | Power supply pins (All DVCC pins should be connected with the power supply pin.) | | DVSS | 3 | | GND pins (0 V) (All DVSS pins should be connected with the GND (0V) pin.) | Note: All pins that have built-in pull-up resistors (other than the RESET pin) can be disconnected from the built-in pull-up resistor by software. Page 8 2007-12-03 TOSHIBA TMP91CW60 ## CPU The TMP91CW60 incorporates a high-performance 16-bit CPU (The 900/L1-CPU). For CPU operation, see the "TLCS-900/L1 CPU". The following describe the unique function of the CPU used in the TMP91CW60; these functions are not covered in the TLCS-900/L1 CPU section. #### 2.1 RESET When resetting the TMP91CW60 microcontroller, ensure that the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then hold the RESET input to low level at least for 10 system clocks (1us at 20 MHz). Thus, when turn on the switch, be set to the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then hold the RESET input to Low level at least for 10 system clocks. It means that the system clock mode $f_{SYS}$ is set to fc/2. When the reset is accept, the CPU: 1. Sets as follows the program counter (PC) in accordance with the reset vector stored at address FFFF00H to FFFF02H: - PC (7:0) <- Value at FFFF00H address - PC (15:8) <- Value at FFFF01H address - PC (23:16) <- Value at FFFF02H address - 2. Sets the stack pointer (XSP) to 100H. - 3. Sets bits<IFF2:0> of the status register (SR) to 111 (Sets the interrupt level mask register to level 7). - 4. Sets the <MAX> bit of the status register (SR) to 1 (MAX mode). - 5. Clears bits<RFP2:0> of the status register (SR) to 000 (Sets the register bank to 0). When reset is released, the CPU starts executing instructions in accordance with the program counter settings. CPU internal registers not mentioned above do not change when the reset is released. When the reset is accepted, the CPU sets internal I/O, ports, and other pins as follows. - 1. Initializes the internal I/O registers. - 2. Sets the port pins, including the pins that also act as internal I/O, to general-purpose input or output port mode. - 3. Sets ALE pin to high impedance. Note 1: The CPU internal register (except to PC, SR, XSP in CPU) and internal RAM data do not change by resetting. Note 2: It is necessary to re-set up a stack pointer XSP by the user program. Figure 2-1 is a reset timing chart of the TMP91CW60. Page 9 2007-12-03 Figure 2-1 TMP91CW60 Reset Timing Chart Page 10 2007-12-03 # 2.2 Memory Map Figure 2-2 is a memory map of the TMP91CW60. Figure 2-2 TMP91CW60 Memory Map Page 11 2007-12-03 TMP91CW60 # 2.3 System Clock Function and Standby Control TMP91CW60 contains a clock gear, stand-by controller and noise-reduction circuit. It is used for low-noise systems. The clock operating modes are as follows: (a) Single clock mode (X1 and X2 pins only), (b) Dual clock mode (X1,X2,XT1 and XT2 pins). Figure 2-3 shows a transition figure. Figure 2-3 TMP91CW60 Clock Operating Mode Note: The clock frequency input from the X1 and X2 pins is called f<sub>OSCH</sub> and the clock frequency input from the XT1 and XT2 pins is called fs. The clock frequency selected by SYSCR1<SYSCK> is called f<sub>FPH</sub>. The system clock f<sub>SYS</sub>is defined as the divided clock of f<sub>FPH</sub>, and one cycle of f<sub>SYS</sub> is regret to as one state. # 2.3.1 Block Diagram of System Clock Figure 2-4 Block Diagram of System Clock Page 13 2007-12-03 ## 2.3.2 SFR Table 2-1 SFR for System Clock | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|-------------|-------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------------------| | | Bit Symbol | XEN | XTEN | RXEN | RXTEN | RSYSCK | WUEF | PRCK1 | _ | | | Read/Write | | | | R/W | | (77) | | = | | | After reset | 1 | 0 | 1 | 0 | 0 | (0) | 0 | _ | | SYSCR0<br>(00E0H) | Function | High-<br>frequency<br>oscillator<br>0:Stop<br>1:Oscillation | Low-<br>frequency<br>oscillator<br>0:Stop<br>1:Oscillation | High-<br>frequency<br>oscillator<br>(fc) after<br>release of<br>STOP mode<br>0:Stop<br>1:Oscillation | Low- frequency oscillator (fs) after release of STOP mode 0:Stop 1:Oscillation | Selects<br>clock after<br>release of<br>STOP mode<br>0:fc<br>1:fs | Warm-up timer control 0 Write: Don't care 1 Write: Start warm-up 0 Read: End warm-up 1 Read: Do not end warm-up | Select pres-<br>caler clock<br>0:f <sub>FPH</sub><br>1:fc/16 | > | | | Bit Symbol | - | _ | -( | | SYSCK | GEAR2 | GEAR1 | GEAR0 | | | Read/Write | - | - | | <u> </u> | | ( ) R | R/W | | | | After reset | - | - | 4-1 | > - // | 0 | 0 | 0 | 0 | | SYSCR1<br>(00E1H) | Function | _ ( | | | | Select system clock 0: fc 1: fs | Select gear v. 000:fc 001:fc/2 010:fc/4 011:fc/8 100:fc/16 101:reserved 110:reserved 111:reserved | alue of high frec | uency (fc) | | | Bit Symbol | // -) \_ | SCOSEL | WUPTM1 | WUPTM0 | HALTM1 | HALTM0 | _ | DRVE | | | Read/Write | \\/\_ | 7 | | R/W | | | - | R/W | | | After reset | | 0 < | 1 | 0 | 1 | 1 | - | 0 | | SYSCR2<br>(00E2H) | Function | )<br>)<br>) | Select<br>SCOUT<br>0:fs<br>1:f <sub>SYS</sub> | Select warm-<br>oscillator<br>00:2 <sup>18</sup> /inputte<br>01:2 <sup>8</sup> /inputtec<br>10:2 <sup>14</sup> /inputte<br>11:2 <sup>16</sup> /inputte | ed frequency<br>If frequency<br>and frequency | HALT mode<br>00:reserved<br>01:STOP mod<br>10:IDLE1 mod<br>11:IDLE2 mod | de | - | Pin state<br>control in<br>STOP mode<br>0: I/O off<br>1: Remains<br>the state<br>before HALT | Note 1: "-" = Don't care Note 2: SYSCR0<br/>bit0>,SYSCR1<br/>bit 7:4>,SYSCR2<br/>bit7,bit1> are read as undefined value. Note 3: As for the serial channels SIO0, SIO1 and SIO2, a baud rate generator is unavailable as an input clock of an I/O interface and a clock for a serial transfer if a prescaler clock is set to fc/16 when SYSCR0<PRCK1> is "1". Page 14 2007-12-03 TMP91CW60 ## 2.3.3 System Clock Controller The system clock controller generates the system clock signal ( $f_{SYS}$ ) for the CPU core and internal I/O.It contains two oscillation circuits and a clock gear circuit for high-frequency (fc) operation. The register SYSCR1<SYSCK> changes the system clock to either fc or fs, SYSCR0<XEN> and SYSCR0<XTEN> control enabling and disabling of each oscillator, and SYSCR1<GEAR2:0> sets the high-frequency clock gear to either 1, 2, 4, 8 or 16 (fc, fc/2, fc/4, fc/8 or fc/16). These functions can reduce the power consumption of the equipment in which the device is installed. The combination of settings $\langle XEN \rangle = "1"$ , $\langle XTEN \rangle = "0"$ , $\langle SYSCK \rangle = "0"$ and $\langle GEAR2:0 \rangle = "000"$ will cause the system clock ( $f_{SYS}$ ) to be set to fc/2 (=fc x 1/2) after a Reset. For example, $f_{SYS}$ is set to 8 MHz when the 16 MHz oscillator connected to the X1 and X2 pins. ### (1) Switching from NORMAL mode to SLOW mode When the resonator is connected to the X1 and X2 pins, or to the XT1 and XT2 pins, the warm-up timer can be used to change the operation frequency after stable oscillation has been attained. The warm-up time can be selected using SYSCR2<WUPTM1:0>. This warm-up timer can be programmed to start and stop as shown in the following examples 1 and 2. Table 2-2 shows the warm-up time. Note 1: When using an oscillator (other than a resonator) with stable oscillation, a warm-up timer is not needed. Note 2: The warm-up timer is operated by an oscillation clock. Hence, there may be some variation in warm-up time. Note 3: Note of using low-frequency oscillator When connect low-frequency oscillator to ports 96 and 97, need below setting for cut consumption power. (Case of resonators) Set P9CR<P96C, P97C> = "11", P9<P96:97> = "00" (Case of oscillator) Set P9CR<P96C, P97C> = "11", P9<P96:97> = "10" Table 2-2 Warm-up Times (when changing clock) | Select Warm-up Time<br>SYSCR2 <wuptm1:0></wuptm1:0> | Change to NORMAL (fc) | Change to SLOW (fs) | |-----------------------------------------------------|-----------------------|---------------------| | 01(2 <sup>8</sup> /frequency) | 12.8[us] | 7.8[ms] | | 10(2 <sup>14</sup> /frequency) | 0.819[ms] | 500[ms] | | 11(2 <sup>16</sup> /frequency) | 3.277[ms] | 2000[ms] | | 00(2 <sup>18</sup> /frequency) | 13.107[ms] | 8000[ms] | Note: At f<sub>OSCH</sub>=20MHz, fs=32.768kHz Page 15 2007-12-03 ### Example 1: Changing from high frequency (fc) to low frequency (fs). SYSCR0 EQU 00E0H SYSCR1 **EQU** 00E1H SYSCR2 EQU 00E2H LD (SYSCR2),X-11--X-B Sets warm-up time to 216/fs. **SET** 6,(SYSCR0) Enables low-frequency oscillation. **SET** 2,(SYSCR0) Clears and starts warm-up timer. WUP: BIT 2,(SYSCR0) Detects stopping of warm-up timer. JR NZ,WUP SET 3,(SYSCR1) ; Changes f<sub>SYS</sub> from fc to fs. RES 7,(SYSCR0) ; Disables high-frequency oscillation. Figure 2-5 Changing from high frequency (fc) to low frequency (fs) Page 16 2007-12-03 Example 2: Changing from low frequency (fs) to high frequency (fc). | SYSCR0 | EQU | 00E0H | | |--------|-----|------------------|---------------------------------------------| | SYSCR1 | EQU | 00E1H | | | SYSCR2 | EQU | 00E2H | | | | LD | (SYSCR2),X-10X-B | ; Sets warm-up time to 2 <sup>14</sup> /fc. | | | SET | 7,(SYSCR0) | ; Enables high-frequency oscillation. | | | SET | 2,(SYSCR0) | ; Clears and starts warm-up timer. | | WUP: | BIT | 2,(SYSCR0) | ; Detects stopping of warm-up timer. | | | JR | NZ,WUP | ; | | | RES | 3,(SYSCR1) | ; Changes f <sub>sys</sub> from fs to fc | | | RES | 6,(SYSCR0) | ; Disables low-frequency oscillation. | | | | | 1// | Note: X: Don't care, -: No change Figure 2-6 Changing from low frequency (fs) to high frequency (fc) ## (2) Clock gear controller When the high-frequency clock fc is selected by setting SYSCR1<SYSCK> = "0", $f_{FPH}$ is set according to the contents of the clock gear select register SYSCR1<GEAR2:0> to either fc, fc/2, fc/4, fc/8 or fc/16. Using the clock gear to select a lower value of $f_{FPH}$ reduces power consumption. Below show example of changing clock gear. Page 17 2007-12-03 #### Example 3: Changing to a clock gear SYSCR1 EQU 00E1H LD (SYSCR1),XXXX0000B ; Changes f<sub>SYS</sub> to fc/2 X:Don't care (Clock gear changing) To change the clock gear, write the register value to the SYSCR1<GEAR2:0> register. It is necessary the warm-up time until changing after writing the register value. There is the possibility that the instruction next to the clock gear changing instruction is executed by the clock gear before changing. To execute the instruction next to the clock gear switching instruction by the clock gear after changing, input the dummy instruction as follows (instruction to execute the write cycle). SYSCR1 EQU 00E1H LD (SYSCR1),XXXX0000B ; Changes f<sub>SYS</sub> to fc/2 LD (DUMMY),00H ; Dummy instruction Instruction to be executed after clock gear has changed #### (3)Internal clock output The f<sub>SYS</sub> or fs internal clock can be driven out from the P40/SCOUT pin. The P40/SCOUT pin is configured as SCOUT (System clock output) by programming the port 4 registers as follows: P4CR<P40C> = "1" and P4FC<P40F> = "1". The output clock is selected through the SYSCR2<SCOSEL> bit. Table 2-3 shows the pin states in each clocking mode when the P40/SCOUT pin is configured as SCOUT. Table 2-3 SCOUT Output States | | NORMAL SLOW | $\rightarrow$ | HALT mode | _ | |-----------------------|-------------------------------------------|---------------|-----------|--------------------| | | NORWAL SLOW | IDLE2 | IDLE1 | STOP | | <scosel>="0"</scosel> | The fs clock is driven out. | | | HOLD at either "1" | | <scosel>="1"</scosel> | The f <sub>SYs</sub> clock is driven out. | | | or "0" | ## 2.3.4 Prescaler Clock Controller For the internal I/O (TMRA01 to TMRA45, TMRB0 to TMRB4, SIO0 to SIO2, SBI0, SBI1) there is a prescaler which can divide the clock. The $\phi$ T0 clock input to the prescaler is either the clock f<sub>FPH</sub> divided by 2 or the clock fc/16 divided by 4. The setting of the SYSCR0<PRCK1> register determines which clock signal is input. Page 18 2007-12-03 ## 2.3.5 Runaway provision with SFR protection register (Purpose) Provision in runaway of program by noise mixing. Write operation to specified SFR is prohibited so that provision program in runaway prevents that it is it in the state which is fetch impossibility by stopping of clock, memory control register (CS/WAIT controller) is changed. #### Specified SFR list CS/WAIT controller BOCS, B1CS, B2CS, B3CS, BEXCS, MSAR0, MSAR1, MSAR2, MSAR3, MAMR0, MAMR1, MAMR2, MAMR3 Clock gear (write enable only EMCCR1) SYSCR0, SYSCR1, SYSCR2 (Block diagram) Protect register EMCCRO<PROTECT> Write except "1FH" to EMCCRI S Q Write signal to specified SFR Write "1FH" to EMCCRI R Write signal to other SFR (Setting method) If writing except "1FH" code to EMCCR1 register, it become protect ON. By this operation, write operation to specified SFR is disabling. If writing "1FH" to EMCCR1 register, it become protect OFF. State of protect can to confirm by reading EMCCR0<PROTECT>. Table 2-4 SFR for EMCCR | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|-------------|-------------------------------------|----------------------|------------|------------|------------|------------|------------|------------| | | Bit Symbol | PROTECT | ) ( <del>-</del> ) / | - | - | - | - | - | - | | | Read/Write | R | | | | R/W | | | | | EMCCR0<br>(00E3H) | After reset | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | | (UUESH) | Function | Protect flag<br>0: OFF<br>1: ON | Write "0". | Write "1". | Write "0". | Write "0". | Write "0". | Write "1". | Write "1". | | | Bit Symbol | | | | | | | | | | EMCCR1 | Read/Write | Protect OFF by writing "1FH". | | | | | | | | | (00E4H) | After reset | Protect ON by writing except "1FH". | | | | | | | | | | Function | | | | | | | | | Page 19 2007-12-03 ## 2.3.6 Standby Controller #### (1)HALT modes When the HALT instruction is executed, the operating mode switches to IDLE2, IDLE1 or STOP mode, depending on the contents of the SYSCR2<HALTM1:0> register. The subsequent actions performed in each mode are as follows: 1. IDLE2: Only the CPU halts. The internal I/O is available to select operation during IDLE2 mode by setting the following register. Shows the registers of setting operation during IDLE2 mode. Table 2-5 SFR Setting Operation during IDLE2 Mode | | | | _ | |--------------|---------------------------|---|---| | Internal I/O | SFR | | | | TMRA01 | TA01RUN <i2ta01></i2ta01> | | S | | TMRA23 | TA23RUN <i2ta23></i2ta23> | | s | | TMRA45 | TA45RUN <i2ta45></i2ta45> | < | s | | TMRB0 | TB0RUN <i2tb0></i2tb0> | | s | | TMRB1 | TB1RUN <i2tb1></i2tb1> | | s | | TMRB2 | TB2RUN <i2tb2></i2tb2> | / | A | | TMRB3 | TB3RUN <i2tb3></i2tb3> | > | W | | TMRB4 | TB4RUN <i2tb4></i2tb4> | | | | Internal I/O | SFR | |--------------|--------------------------| | SIO0 | SC0MOD1 <i2s0></i2s0> | | SIO1 | SC1MOD1 <l2s1></l2s1> | | SIO2 | SC2MOD1 <i2s2></i2s2> | | SBI0 | SBI0BR <i2sbi0></i2sbi0> | | SBI1 | SBI1BR <i2sbi1></i2sbi1> | | AD | ADCCR2 <i2ad></i2ad> | | WDT | WDMOD <i2wdt></i2wdt> | | | | - 2. IDLE1: Only the oscillator and the RTC (Real time clock) continue to operate. - 3. STOP: All internal circuits stop operating. The operation of each of the different HALT modes is described in Table 2-6. Table 2-6 I/O Operation during HALT Modes | HALT mode | | IDLE2 | IDLE1 | STOP | | |-----------|-----------------------------|-------------------------------------|---------------------------------------|------|--| | S | YSCR2 <haltm1:0></haltm1:0> | 7 11 | 10 | 01 | | | _ | CPU | Stop | | | | | | I/O port | Keep the state when the executed. | he HALT instruction was See Table 2-9 | | | | | TMRA,TMRB | | | | | | Block | RTC | > | Operate enable | | | | | SIO,SBI | Available to select operation block | | | | | | AD | ., | Stop | | | | | WDT | | | | | | | Interrupt controller | Operate | | | | Page 20 2007-12-03 #### (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 combination between the states of interrupt mask register <IFF2:0> and the HALT modes. The details for releasing the halt status are shown in Table 2-7. #### 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 interrupt mask register, the interrupt due to the source is processed after releasing the HALT mode, and CPU status 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 INTO and RTC 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, and CPU starts executing the instruction next to the HALT instruction, but the interrupt request flag is held at "1". Note: Usually, interrupts can release all halts status. However, the interrupts (\overline{NMI}, INTO, INTRTC) which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 5 clocks of f<sub>FPH</sub>) with IDLE1 or STOP mode (IDLE2 is not applicable to this case). (In this case, an interrupt request is kept on hold internally.) If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficulty. The priority of this interrupt is compared with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt. #### Releasing by resetting Releasing all halt status is executed by resetting. When the STOP mode is released by RESET, it is necessary enough resetting time (See Table 2-6)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 settings contents are initialized. (Releasing due to interrupts keeps the state before the "HALT" instruction is executed.) Table 2-7 Source of Halt State Clearance and Halt Clearance Operation | Status of Received Interrupt | | Interrupt Enable<br>(Interrupt level) ≥ (Interrupt mask) | | Interrupt Disable<br>(Interrupt level) < (Interrupt mask) | | | | | |--------------------------------|-----------|----------------------------------------------------------|----------------|-----------------------------------------------------------|-------------------|-------------------|------------|------------------------| | | HALT mode | | IDLE2 | IDLE1 | STOP | IDLE2 | IDLE1 | STOP | | | | NMI | • | • | <b>♦</b> *1 | - | (-)r | <del>-</del> | | | Interrupt | INTWDT | • | × | × | - ( | 77/ | - | | Φ | | INT0(Note 1) | • | • | <b>♦</b> *1 | 0 | $\bigcirc$ | O*1 | | Source of Halt state clearance | | INTRTC | • | • | × | 0 | 0 | × | | | | INT1-INT10 | ♦ (Note 2) | × | × | × | × | × | | | | INTTA0-INTTA5 | • | × | × | × | × | × | | | | INTTB00-40,INTTB01-41 | • | × | (× <sub>7</sub> ) | × | × | × | | | | INTTB0F0-4 | • | × | $(\times)$ | × < | , X | × | | | | INTRX0-INTRX2,TX0-TX2 | • | ×_( | × | × | X / | $\mathcal{O}_{\times}$ | | | | INTSBI0-1 | • | × | × | × (( | × | × | | | | INTAD | • | X | > × | ( <del>*</del> 7) | × | × | | | RESET | | Initialize LSI | | | | | | - ♦: After clearing the HALT mode, CPU starts interrupt processing. - O:After clearing the HALT mode, CPU resumes executing starting from instruction following the HALT instruction. (Interrupt routine don't execute.) - ×:It can not be used to release the HALT mode. - :The priority level (Interrupt request level) of non-maskable interrupts is fixed to 7, the highest priority level. There is not this combination type. - \*1:Releasing the HALT mode is executed after passing the warm-up time. - Note 1: When the HALT mode is cleared by an INTO interrupt of the level mode in the interrupt enabled status, hold high level until starting interrupt process. If low level was set before interrupt process is stared, interrupt process is not started correctly. - Note 2: If using external interrupt INT1 to INT10 in IDLE2 mode, set 16-bit timer RUN register TB0RUN<I2TB0>, TB1RUN<I2TB1>, TB2RUN<I2TB2>, TB3RUN<I2TB3>, TB4RUN<I2TB4> to "1". Page 22 2007-12-03 ### Example:Clearing halt state An INT0 interrupt clears the halt state when the device is in IDLE1 mode. #### (3)Operation #### 1. IDLE2 mode In IDLE2 mode only specific internal I/O operations, as designated by the IDLE2 setting register, can take place. Instruction execution by the CPU stops. Figure 2-7 illustrates an example of the timing for clearance of the IDLE2 mode halt state by an interrupt. Figure 2-7 Timing Chart for IDLE2 Mode Halt State Cleared by Interrupt 2007-12-03 Page 23 ### 2. IDLE1 mode In IDLE1 mode, only the internal oscillator and the RTC continue to operate. The system clock in the MCU stops. In the halt state, the interrupt request is sampled asynchronously with the system clock; however, clearance of the Halt state (e.g., restart of operation) is synchronous with it. Figure 2-8 illustrates the timing for clearance of the IDLE1 mode halt state by an interrupt. Figure 2-8 Timing Chart for IDLE1 Mode Halt State Cleared by Interrupt Page 24 2007-12-03 #### 3. STOP mode When STOP mode is selected, all internal circuits stop, including the internal oscillator. Pin status in STOP mode depends on the settings in the SYSCR2<DRVE> register. Table 2-9 summarizes the state of these pins in STOP mode. After STOP mode has been cleared, system clock output starts when the warm-up time has elapsed, in order to allow oscillation to stabilize. After STOP mode has been cleared, either NORMAL mode or SLOW mode can be selected using the SYSCRO<RSYSCK> register. Therefore, <RSYSCK>, <RXEN> and <RXTEN> must be set. See the sample warm-up times in Table 2-8. Figure 2-9 illustrates the timing for clearance of the STOP mode halt state by an interrupt. Figure 2-9 Timing Chart for STOP Mode Halt State Cleared by Interrupt Table 2-8 Sample Warm-up Times after Clearance of STOP Mode | SYSCR0 | SYSCR2 <wuptm1:0></wuptm1:0> | | | | | | |-------------------|------------------------------|----------------------|----------------------|----------------------|--|--| | <rsysck></rsysck> | 01(2 <sup>8</sup> ) | 10(2 <sup>14</sup> ) | 11(2 <sup>16</sup> ) | 00(2 <sup>18</sup> ) | | | | 0(fc) | 12.8us | 0.819ms | 3.277ms | 13.107ms | | | | 1(fs) | 7.8ms | 500ms | 2000ms | 8000ms | | | Note: f<sub>OSCH</sub>=20MHz, fs=32.768kHz Page 25 2007-12-03 #### Example: "The STOP mode is entered when the low-frequency operates, and high-frequency operates after releasing due to NMI. 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 6 state). In the system which accepts the interrupts during execution "HALT" instruction, set the same operation mode before and after the STOP mode. Table 2-9 Input/output Buffer State Table | Port Name | Input / Output | <drve>=0</drve> | <drve>=1</drve> | |-------------------|-------------------------------------------|------------------|------------------| | P00-07 | input mode<br>output mode<br>AD0-AD7 | -<br>-<br>- | -<br>output | | P10-17 | input mode<br>output mode<br>AD8-AD15 | -<br>-<br>- | output | | P20-27 | input mode<br>output mode,A0-A7/A16-A23 | | output | | PZ0(RD),PZ1(WR) | output | - (( | output | | PZ2(HWR),PZ3(R/W) | input mode<br>output mode | PU*<br>PU* | PU*<br>output | | P30-33 | input mode<br>output mode | | -<br>output | | P40-44 | input mode output mode | PU* | PU* | | P50-57 | input mode<br>output mode<br>analog input | | output - | | P60-67 | input mode<br>output mode<br>analog input | | output - | | P70-74 | input mode<br>output mode | | input<br>output | | P75 | input mode<br>output mode | input - | input<br>output | | P80-87 | input mode<br>output mode | | -<br>output | | P90-97 | input mode<br>output mode | | -<br>output | | PA0-A3 | input mode<br>output mode | ( | -<br>output | | PB0-B3 | input mode<br>output mode | | -<br>output | | ⟨NMI/⟩ | input | input | input | | RESET | input | input | input | | AM0,AM1 | input | input | input | | X1 | input | - | - | | X2 | output | "H" level output | "H" level output | Input for input mode / input pins is invalid; output mode / output pin is at high impedance. input: Input gate in operation. Fix input voltage to "L" or "H" so that input pin stays constant. output: Output state PU\*: Programmable pull-up pin. Input gate disable state. No through current even if the pin is set high impedance. Page 27 2007-12-03 TOSHIBA TMP91CW60 # Interrupts Interrupts are controlled by the CPU interrupt mask register SR<IFF2:0> and by the built-in interrupt controller. The TMP91CW60 has a total of 57 interrupts divided into the following three types: - Interrupts generated by CPU: 9 sources (Software interrupts, illegal instruction interrupt) - Interrupts on external pins (NMI, INT0 to INT10): 12 sources - Internal interrupts: 36 sources A (fixed) individual interrupt vector number is assigned to each interrupt. One of six (Variable) priority level can be assigned to each maskable interrupt. The priority level of non-maskable interrupts are fixed at 7 as the highest level. When an interrupt is generated, the interrupt controller sends the priority of that interrupt to the CPU. If multiple interrupts are generated simultaneously, the interrupt controller sends the interrupt with the highest priority to the CPU. (The highest priority is level 7 using for non-maskable interrupts.) The CPU compares the priority level of the interrupt with the value of the CPU interrupt mask register <IFF2:0>. If the priority level of the interrupt is higher than the value of the interrupt mask register, the CPU accepts the interrupt. The interrupt mask register <IFF2:0> value can be updated using the value of the EI instruction ("EI num" sets <IFF2:0> data to num). For example, specifying "EI3" enables the maskable interrupts which priority level set in the interrupt controller is 3 or higher, and also non-maskable interrupts. Operationally, the DI instruction (<IFF2:0> "7") is identical to the "EI7" instruction. DI instruction is used to disable maskable interrupts because of the priority level of maskable interrupts is 0 to 6. The EI instruction is valid immediately after execution. In addition to the above general-purpose interrupt processing mode, TLCS-900/L1 has a micro DMA interrupt processing mode as well. The CPU can transfer the data (1/2/4 bytes) automatically in micro DMA mode, therefore this mode is used for speed-up interrupt processing, such as transferring data to the internal or external peripheral I/O. Moreover, TMP91CW60 has software start function for micro DMA processing request by the software not by the hardware interrupt. Figure 3-1 shows the overall interrupt processing flow. Page 28 2007-12-03 Page 29 2007-12-03 TOSHIBA TMP91CW60 # 3.1 General-purpose Interrupt Processing When the CPU accepts an interrupt, it usually performs the following sequence of operations. That is also the same as TLCS-900/L and TLCS-900/H. - The CPU reads the interrupt vector from the interrupt controller. If the same level interrupts occur simultaneously, the interrupt controller generates an interrupt vector in accordance with the default priority and clears the interrupt request. (The default priority is already fixed for each interrupt. The smaller vector value has the higher priority level.) - 2. The CPU pushes the value of program counter (PC) and status register (SR) onto the stack area (Indicated by XSP). - 3. The CPU sets the value which is the priority level of the accepted interrupt plus 1 (+1) to the interrupt mask register <IFF2:0>. However, if the priority level of the accepted interrupt is 7, the register's value is set to 7. - 4. The CPU increases the interrupt nesting counter INTNEST by 1 (+1). - 5. The CPU jumps to the address indicated by the data at address "FFFF00H + Interrupt vector" and starts the interrupt processing routine. The above processing time is 18 states (1.8 µs at 20 MHz) as the best case (16-bit data bus width and 0 waits). When the CPU completed the interrupt processing, use the RETI instruction to return to the main routine. RETI restores the contents of program counter (PC) and status register (SR) from the stack and decreases the interrupt nesting counter INTNEST by 1 (-1). Non-maskable interrupts cannot be disabled by a user program. Maskable interrupts, however, can be enabled or disabled by a user program. A program can set the priority level for each interrupt source. (A priority level setting of 0 or 7 will disable an interrupt request.) If an interrupt request which has a priority level equal to or greater than the value of the CPU interrupt mask register <IFF2:0> comes out, the CPU accepts its interrupt. Then, the CPU interrupt mask register <IFF2:0> is set to the value of the priority level for the accepted interrupt plus 1 (+1). Therefore, if an interrupt is generated with a higher level than the current interrupt during its processing, the CPU accepts the later interrupt and goes to the nesting status of interrupt processing. Moreover, if the CPU receives another interrupt request while performing the said 1. to 5. processing steps of the current interrupt, the latest interrupt request is sampled immediately after execution of the first instruction of the current interrupt processing routine. Specifying DI as the start instruction disables maskable interrupt nesting. A reset initializes the interrupt mask register <IFF2:0> to "111", disabling all maskable interrupts. Table 3-1 shows the TMP91CW60 interrupt vectors and micro DMA start vectors. The address FFFF00H to FFFFFFH (256 bytes) is assigned for the interrupt vector area. Page 30 2007-12-03 Table 3-1 TMP91CW60 Interrupt Vectors Table(1/2) | Default Priority | Туре | Interrupt Source and Source of Micro DMA Request | Vector Value<br>(V) | Vector Reference Address | Micro DMA<br>Start Vector | |------------------|-----------------|------------------------------------------------------|---------------------|--------------------------|---------------------------| | 1 | | "Reset" or "SWI 0" instruction | 0000H | FFFF00H | - | | 2 | | "SWI 1" instruction | 0004H | FFFF04H | _ | | 3 | | INTUNDEF: Illegal instruction or "SWI 2" instruction | H8000 | FFFF08H | - | | 4 | | "SWI 3" instruction | 000CH | FFFF0CH | - | | 5 | Non- | "SWI 4" instruction | 0010H | FFFF10H | - | | 6 | maskable | "SWI 5" instruction | 0014H | FFFF14H | - | | 7 | | "SWI 6" instruction | 0018H | FFFF18H | - | | 8 | | "SWI 7" instruction | 001CH | FFFF1CH | - | | 9 | | NMI:NMI pin | 0020H | FFFF20H | > - | | 10 | | INTWD: Watchdog timer | 0024H | FFFF24H | _ | | _ | | Micro DMA (MDMA) | $\Diamond$ | 9/1 | _ | | 11 | | INTO: INTO pin | 0028H | FFFF28H | 0AH | | 12 | | INT1: INT1 pin | 002CH | FFFF2CH | 0BH | | 13 | | INT2: INT2 pin | 0030H | FFFF30H | 0CH | | 14 | | INT3: INT3 pin | 0034H | FFFF34H | 0DH | | 15 | | INT4: INT4 pin | 0038H | FFFF38H | 0EH | | 16 | | INT5: INT5 pin | 003CH | FFFF3CH | 0FH | | 17 | | INT6: INT6 pin | 0040H | FFFF40H | 10H | | 18 | | INT7: INT7 pin | 0044H | FFFF44H | 11H | | 19 | | INT8: INT8 pin | 0048H | FFFF48H | 12H | | 20 | | INT9: INT9-pin | 004CH | FFFF4CH | 13H | | 21 | | INT10: NT10 pin | 0050H | FFFF50H | 14H | | 22 | | INTTA0: 8-bit timer 0 | 0054H | FFFF54H | 15H | | 23 | Maskable | INTTA1: 8-bit timer 1 | 0058H | FFFF58H | 16H | | 24 | Waskable | INTTA2: 8-bit timer 2 | 005CH | FFFF5CH | 17H | | 25 | $\wedge \wedge$ | INTTA3: 8-bit timer 3 | 0060H | FFFF60H | 18H | | 26 | 7, | INTTA4: 8-bit timer 4 | 0064H | FFFF64H | 19H | | 27 | | INTTA5: 8-bit timer 5 | 0068H | FFFF68H | 1AH | | 28 | (()) | INTTB00: 16-bit timer 0 (TB0RG0) | 006CH | FFFF6CH | 1BH | | 29 | | INTTB01: 16-bit timer 0 (TB0RG1) | 0070H | FFFF70H | 1CH | | 30 | | INTTB10: 16-bit timer 1 (TB1RG0) | 0074H | FFFF74H | 1DH | | 31 | | INTTB11: 16-bit timer 1 (TB1RG1) | 0078H | FFFF78H | 1EH | | 32 | | INTTB20: 16-bit timer 2 (TB2RG0) | 007CH | FFFF7CH | 1FH | | 33 | | INTTB21: 16-bit timer 2 (TB2RG1) | 0080H | FFFF80H | 20H | | 34 | | INTTB30: 16-bit timer 3 (TB3RG0) | 0084H | FFFF84H | 21H | | 35 | | INTTB31: 16-bit timer 3 (TB3RG1) | 0088H | FFFF88H | 22H | | 36 | | INTTB40: 16-bit timer 4 (TB4RG0) | 008CH | FFFF8CH | 23H | | 37 | | INTTB41: 16-bit timer 4 (TB4RG1) | 0090H | FFFF90H | 24H | Page 31 2007-12-03 Table 3-1 TMP91CW60 Interrupt Vectors Table(2/2) | Default Priority | Туре | Interrupt Source and Source of Micro DMA Request | Vector Value<br>(V) | Vector Reference Address | Micro DMA<br>Start Vector | |------------------|----------|----------------------------------------------------|---------------------|--------------------------|---------------------------| | 38 | | INTTBOF0: 16-bit timer 0 (Over flow) | 0094H | FFFF94H | 25H | | 39 | | INTTBOF1: 16-bit timer 1 (Over flow) | 0098H | FFFF98H | 26H | | 40 | | INTTBOF2: 16-bit timer 2 (Over flow) | 009CH | FFFF9CH | 27H | | 41 | | INTTBOF3: 16-bit timer 3 (Over flow) | 00A0H | FFFFA0H | 28H | | 42 | | INTTBOF4: 16-bit timer 4 (Over flow) | 00A4H | EFFFA4H | 29H | | 43 | | INTRX0:Serial reception (Channel 0) | 00A8H | FFFFA8H | 2AH | | 44 | | INTTX0:Serial transmission (Channel 0) | 00ACH | FFFFACH | 2BH | | 45 | | INTRX1:Serial reception (Channel 1) | 00B0H | FFFFB0H | 2CH | | 46 | | INTTX1:Serial transmission (Channel 1) | 00B4H | FFFFB4H | 2DH | | 47 | | INTRX2:Serial reception (Channel 2) | ○ 00B8H | FFFFB8H | 2EH | | 48 | Maskable | INTTX2:Serial transmission (Channel 2) | 00BCH | FFFFBCH | 2FH | | 49 | | INTSBI0:Serial bus interface interrupt (Channel 0) | 00C0H | FFFFC0H | 30H | | 50 | | INTSBI1:Serial bus interface interrupt (Channel 1) | 00C4H | FEFFC4H | 31H | | 51 | | INTRTC: Interrupt for special timer for CLOCK | 00C8H | FFFFC8H | 32H | | 52 | | INTAD: AD conversion end | 00CCH | FFFFCCH | 33H | | 53 | | INTTC0 Micro DMA end (Channel 0) | 00D0H | FFFFD0H | _ | | 54 | | INTTC1: Micro DMA end (Channel 1) | 00D4H | FFFFD4H | - | | 55 | | INTTC2: Micro DMA end (Channel 2) | 00D8H | FFFFD8H | - | | 56 | | INTTC3: Micro DMA end (Channel 3) | 00DCH | FFFFDCH | - | | | | (Reserved) | 00E0H<br>:<br>00FCH | FFFFE0H<br>:<br>FFFFFCH | -<br>:<br>- | Note: Micro DMA default priority: Micro DMA stands up prior to other maskable interrupt. TOSHIBA TMP91CW60 # 3.2 Micro DMA Processing In addition to general-purpose interrupt processing, the TMP91CW60 supports a micro DMA function. Interrupt requests set by micro DMA perform micro DMA processing at the highest priority level (Level 6) among maskable interrupts, regardless of the priority level of the particular interrupt source. The micro DMA has 4 channels and is possible continuous transmission by specifying the described later burst mode. The micro DMA has 4 channels and is possible continuous transmission by specifying the described later burst mode. Because the micro DMA function has been implemented with the cooperative operation of CPU, when CPU goes to a standby mode (STOP, IDLE1 and IDLE2) by HALT instruction, the requirement of micro DMA will be ignored (Pending) and DMA transfer is started after release HALT. ## 3.2.1 Micro DMA Operation When an interrupt request specified by the micro DMA start vector register is generated, the micro DMA triggers a micro DMA request to the CPU at interrupt priority level 6 and starts processing the request in spite of any interrupt source's level. The micro DMA is ignored on <IFF2:0> = "7". The 4 micro DMA channels allow micro DMA processing to be set for up to 4 types of interrupts at any one time. When micro DMA is accepted, the interrupt request flip-flop assigned to that channel is cleared. The data are automatically transferred once (1/2/4 bytes) from the transfer source address to the transfer destination address set in the control register, and the transfer counter is decreased by 1 (-1). If the decreased result is "0", the micro DMA transfer end interrupt (INTTC0 to INTTC3) passes from the CPU to the interrupt controller. In addition, the micro DMA start vector register DMAnV is cleared to 0, the next micro DMA is disabled and micro DMA processing completes. If the decreased result is other than "0", the micro DMA processing completes if it does not specify the described later burst mode. In this case, the micro DMA transfer end interrupt (INTTC0 to INTTC3) aren't generated. If an interrupt request is triggered for the interrupt source in use during the interval between the clearing of the micro DMA start vector and the next setting, general-purpose interrupt processing executes at the interrupt level set. Therefore, if only using the interrupt for starting the micro DMA (Not using the interrupts as a general-purpose interrupt: Level 1 to 6), first set the interrupts level to 0 (Interrupt requests disabled). If using micro DMA and general-purpose interrupts together, first set the level of the interrupt used to start micro DMA processing lower than all the other interrupt levels. (Note) In this case, the cause of general interrupt is limited to the edge interrupt. The priority of the micro DMA transfer end interrupt (INTTC0 to INTTC3) is defined by the interrupt level and the default priority as the same as the other maskable interrupt. If a micro DMA request is set for more than one channel at the same time, the priority is not based on the interrupt priority level but on the channel number. The smaller channel number has the higher priority (Channel 0 (High) > Channel 3 (Low)). While the register for setting the transfer source/transfer destination addresses is a 32-bit control register, this register can only effectively output 24-bit addresses. Accordingly, micro DMA can access 16 Mbytes (The upper eight bits of the 32 bits are not valid). Note: If the priority level of micro DMA is set higher than that of other interrupts, CPU operates as follows. In case INTxxx interrupt is generated first and then INTyyy interrupt is generated between checking "Interrupt specified by micro DMA start vector" (in the Figure 3-1) and reading interrupt vector with setting below, the vector shifts to that of INTyyy at the time. This is because the priority level of INTyyy is higher than that of INTxxx. In the interrupt routine, CPU reads the vector of INTyyy because checking of micro DMA has been finished. And INTyyy is generated regardless of transfer counter of micro DMA. INTxxx: level 1 without micro DMA INTyyy: level 6 with micro DMA Page 33 2007-12-03 Three micro DMA transfer modes are supported: 1-byte transfer, 2-byte (One-word) transfer, and 4-byte transfer. After a transfer in any mode, the transfer source/destination addresses are increased, decreased, or remain unchanged. This simplifies the transfer of data from I/O to memory, from memory to I/O, and from I/O to I/O. For details of the transfer modes, see" 3.2.4 Detailed Description of the Transfer Mode Register ". As the transfer counter is a 16-bit counter, micro DMA processing can be set for up to 65536 times per interrupt source. (The micro DMA processing count is maximized when the transfer counter initial value is set to 0000H.) Micro DMA processing can be started by the 42 interrupts shown in the micro DMA start vectors of Table 3-1 and by the micro DMA soft start, making a total of 43 interrupts. Figure 3-2 shows the word transfer micro DMA cycle in transfer destination address INC mode (except for counter mode, the same as for other modes). (The conditions for this cycle are based on an external 16-bit bus, 0 waits, transfer source/transfer destination addresses both even-numberd values). Figure 3-2 Timing for Micro DMA Cycle States 1 to 3: Instruction fetch cycle (Gets next address code). If 3 bytes and more instruction codes are inserted in the instruction queue buffer, this cycle becomes a dummy cycle. States 4 to 5: Micro DMA read cycle State 6: Dummy cycle (The address bus remains unchanged from state 5.) States 7 to 8: Micro DMA write cycle Note 1: If the source address area is an 8-bit bus, it is increased by two states. If the source address area is a 16-bit bus and the address starts from an odd number, it is increased by two states. Note 2: If the destination address area is an 8-bit bus, it is increased by two states. If the destination address area is a 16-bit bus and the address starts from an odd number, it is increased by two states. Page 34 2007-12-03 #### 3.2.2 Soft Start Function In addition to starting the micro DMA function by interrupts, TMP91CW60 includes a micro DMA software start function that starts micro DMA on the generation of the write cycle to the DMAR register. Writing "1" to each bit of DMAR register causes micro DMA once (If write "0" to each bit, micro DMA doesn't operate) At the end of transfer, the corresponding bit of the DMAR register is automatically cleared to "0" Only one-channel can be set once for micro DMA. (Do not write "1" to plural bits.) When writing again "1" to the DMAR register, check whether the bit is "0" before writing "1". If read "1", micro DMA transfer isn't started yet. When a burst is specified by DMAB register, data is continuously transferred until the value in the micro DMA transfer counter is "0" after start up of the micro DMA. If execute soft start during micro DMA transfer by interrupt source, micro DMA transfer counter doesn't change. Don't use Read-modify-write instruction to avoid writing to other bits by mistake. | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 ( | (2) | 1 | 0 | |--------|----------------------------|------------|---|-----|-------|-----|-------|-------|--------|-------| | | DMA<br>Request<br>Register | equest RMW | ı | - | (-\) | > - | DMAR3 | DMAR2 | DMAR1 | DMAR0 | | DMAD | | | ı | - ( | 7(-/> | 1 | R/W | | | | | DMAR | | | - | -4( | | + | 0 | 0 | 0 | 0 | | | | | | | | | | 1 AMD | equest | | ### 3.2.3 Transfer Control Registers The transfer source address and the transfer destination address are set in the following registers in CPU. Data setting for these registers is done by an "LDC cr, r" instruction. Page 35 2007-12-03 # 3.2.4 Detailed Description of the Transfer Mode Register | (1 | OMAN | /10 to | DMA | M3) | | | |----|---------|--------|---------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------| | | ) (<br> | ) ( | ) | ĺ | Mode Note: The upper three bit of data programmed to these regist | ers must always be 0. | | | | | <del> </del> | <u> </u> | ZZ: 0 = Byte transfer, 1 = Word transfer, 2 = 4-byte transfer, 3 = Reserved | Execution time | | 0 | 0 | 0 | Z | z z | Transfer destination address INC mode · · · · · · · · I/O to memory (DMADn+) ← (DMASn) | 8 states (800 ns)<br>@ byte/word transfer | | | Ü | | | | DMACn ← DMACn – 1 if DMACn = 0 then INTTC is generated | 12 states (1200 ns)<br>@ 4-byte/word transfer | | 0 | 0 | 1 | Z | Z | Transfer destination address DEC mode · · · · · · · · I/O to memory (DMADn-) ← (DMASn) | 8 states (800 ns)<br>@ byte/word transfer | | | U | | ۷ | | DMACn ← DMACn – 1 if DMACn = 0 then INTTC is generated | 12 states (1200 ns)<br>@ 4-byte/word transfer | | | | z z | Transfer source address INT mode · · · · · · · · · · memory to I/O (DMADn) ← (DMASn+) | 8 states (800 ns)<br>@ byte/word transfer | | | | 0 | 1 | 0 | ۷ | Z | DMACn ← DMACn − 1 if DMACn = 0 then INTTC is generated | 12 states (1200 ns)<br>@ 4-byte/word transfer | | | 1 | 1 | 7 | 7 | Transfer source address DEC mode · · · · · · · · memory to 1/O (DMADn) ← (DMASn-) | 8 states (800 ns)<br>@ byte/word transfer | | 0 | 1 | | Z | Z | DMACn ← DMACn − 1 if DMACn = 0 then INTTC is generated | 12 states (1200 ns)<br>@ 4-byte/word transfer | | | 0 | 0 | Z | Z | Address fixed mode · · · · · · · · · · · · · · · · · · · | 8 states (800 ns)<br>@ byte/word transfer | | 1 | 0 | 0 | ۷ | | DMACn ← DMACn − 1 if DMACn = 0 then INTTC is generated | 12 states (1200 ns)<br>@ 4-byte/word transfer | | 1 | 0 | 1 | 0 | 0 | Counter mode for counting number of times interrupt is generated DMASn ← DMASn + 1 | 5 states | | Ľ | U | ı | U | U | DMACn ← DMACn △ 1 if DMACn = 0 then INTTC is generated | (500 ns) | Note 1: "n" is the corresponding micro DMA channels 0 to 3. DMADn+/DMASn+: Post-increment (Increment register value after transfer) DMADn-/DMASn-: Post-decrement (Decrement register value after transfer) The I/Os in the table mean fixed address and the memory means increment (INC) or decrement (DEC) addresses. Note 2: Execution time is under the condition of: 16-bit bus width (Both transfer and destination address area)/0 waits/ $fc = 20 \text{ MHz/selected high-frequency mode (fc <math>\times$ 1) Note 3: Do not use an undefined code for the transfer mode register except for the defined codes listed in the above table. Page 36 2007-12-03 TOSHIBA TMP91CW60 ### 3.3 Interrupt Controller Operation The block diagram in Figure 3-3 shows the interrupt circuits. The left-hand side of the diagram shows the interrupt controller circuit. The right-hand side shows the CPU interrupt request signal circuit and the halt release circuit. For interrupt controller there is an interrupt request flag (Consisting of a flip-flop), an interrupt priority setting register and a micro DMA start vector register. The interrupt request flag latches interrupt requests from the peripherals. The flag is cleared to 0 in the following cases: - · When reset occurs - When the CPU reads the channel vector after accepted its interrupt - When executing an instruction that clears the interrupt (Write DMA start vector to INTCLR register) - When the CPU receives a micro DMA request (when micro DMA is set) - When the micro DMA burst transfer is terminated An interrupt priority can be set independently for each interrupt source by writing the priority to the interrupt priority setting register (e.g., INTE0AD or INTE56). 6 interrupt priorities levels (1 to 6) are provided. Setting an interrupt source's priority level to 0 (or 7) disables interrupt requests from that source. The priority of non-maskable interrupts (NMI pin interrupts and watchdog timer interrupts) is fixed at 7. If interrupt request with the same level are generated at the same time, the default priority is used to determine which interrupt request is accepted first. The 3rd and 7th bits of the interrupt priority setting register indicate the state of the interrupt request flag and thus whether an interrupt request for a given channel has occurred. The interrupt controller sends the interrupt request and its vector address to the CPU. The CPU compares the priority value <IFF2:0> in the status register by the interrupt request signal with the priority value set; if the latter is higher, the interrupt is accepted. Then the CPU sets a value higher than the priority value by 1 (+1) in the CPU SR<IFF2:0>. Interrupt request 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:0>. The interrupt controller also has registers (4 channels) used to store the micro DMA start vector. Writing the start vector of the interrupt source for the micro DMA processing beforehand (see Table 3-1), enables the corresponding interrupt to be processed by micro DMA processing. The values must be set in the micro DMA parameter register (e.g., DMAS and DMAD) prior to the micro DMA processing. Page 37 2007-12-03 Figure 3-3 Block Diagram of Interrupt Controller Page 38 2007-12-03 # 3.3.1 Interrupt Level Setting Registers # Interrupt Level Setting Registers | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------------------|---------|---------|----------|---------|--------|----------------|--------|--------|--------| | | | | | IN | TAD | | INTO | | | | | INTE0AD | INTO & | | IADC | IADM2 | IADM1 | IADM0 | IOC | 10M2 | IOM1 | IOMO | | | INTAD<br>enable | 90H | R | | R/W | | R | | R/W | | | | | | 0 | 0 | 0 | 0 | 0(( | 0 | 0 | 0 | | | | | | 11 | NT2 | | | | IT1 | | | INTE12 | INT1 &<br>INT2 | 91H | I2C | I2M2 | I2M1 | I2M0 | I1C | I1M2 | I1M1 | I1M0 | | INTEIZ | enable | 9111 | R | | R/W | | R | | R/W | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 11 | NT4 | | , | At C | IT3 | | | INTE34 | INT3 & | 024 | I4C | I4M2 | I4M1 | 14M0 | I3C | I3M2 | 13M1 | I3M0 | | INTES4 | INT4<br>enable | 92H | R | | R/W | | R | )} | R/W | | | | | | 0 | 0 | 0 | 9 | 0 | | ŷ | 0 | | | INT5 &<br>INT6<br>enable | 93H | | 11 | 1T6 | | (( | , IN | IT5 | | | INTE56 | | | I6C | I6M2 | I6M1 | 16M0 | I5C | 15M2 | I5M1 | I5M0 | | INTESO | | | R R/W | | | | (R//< | | R/W | | | | | | 0 | 0,( | 9 | 0 | | 0 | 0 | 0 | | | | | INT8 | | | | INT7 | | | | | INTE78 | INT7 &<br>INT8 | 94H | I8C | (I8M2 | I8M1 | 18M0 | 17C | I7M2 | I7M1 | I7M0 | | INTE | enable | 94H | R | | R/W | | √ R | | R/W | | | | | | 0(( | <b>0</b> | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | T10 | | INT9 | | | | | INTE910 | INT9 &<br>INT10 | 95H | (110C \ | I10M2 | I10M1 | 110M0 | I9C | I9M2 | I9M1 | I9M0 | | | enable | 95H | R | | R/W | \ | R | | R/W | | | | | | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | INTETA01 | | 1 | | INTTA1 | (TMRA1) | | INTTA0 (TMRA0) | | | | | | INTTA0 & INTTA1 enable | TA1 96H | ITA1C | ITA1M2 | ITA1M1 | ITA1M0 | ITA0C | ITA0M2 | ITA0M1 | ITA0M0 | | | | | R | | R/W | | R | | R/W | | | | <> | | 0 | <b>O</b> | 0 | 0 | 0 | 0 | 0 | 0 | | IxxxC | | |------------------------|--| | Interrupt request flag | | | lxxM2 | lxxM1 | IxxM0 | Function (Write) | |-------|-------|-------|------------------------------------| | 0 | 0 | 0 | Disables interrupt requests | | 0 | 0 | 1 | Sets interrupt priority level to 1 | | 0 | 1 | 0 | Sets interrupt priority level to 2 | | 0 | 1 | 1 | Sets interrupt priority level to 3 | | 1 | 0 | 0 | Sets interrupt priority level to 4 | | 1 | 0 | 1 | Sets interrupt priority level to 5 | | 1 | 1 | 0 | Sets interrupt priority level to 6 | | 1 | 1 | 1 | Disables interrupt requests | Page 39 2007-12-03 # Interrupt Level Setting Registers | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|------------------------------|----------|--------|------------|--------------|---------------|----------------|--------------------------|---------------|---------| | | | | | INTTA3 | (TMRA3) | | INTTA2 (TMRA2) | | | | | INITETACO | INTTA2 & | 0711 | ITA3C | ITA3M2 | ITA3M1 | ITA3M0 | ITA2C < | ITA2M2 | ITA2M1 | ITA2M0 | | INTETA23 | INTTA3<br>enable | 97H | R | | R/W | | R | | R/W | | | | | | 0 | 0 | 0 | 0 | 0 | ( 0 ) | 0 | 0 | | | | | | INTTA5 | (TMRA5) | | | INTTA4 | (TMRA4) | | | INITETA 45 | INTTA4 & | 0011 | ITA5C | ITA5M2 | ITA5M1 | ITA5M0 < | ITA4C | ITA4M2 | ITA4M1 | ITA4M0 | | INTETA45 | INTTA5<br>enable | 98H | R | | R/W | | R | | R/W | | | | | | 0 | 0 | 0 | 0 | ((0)) | 0 | 0 | 0 | | | | | | INTTB01 | (TMRB0) | | | INTTB00 | (TMRB0) | | | | Interrupt | | ITB01C | ITB01M2 | ITB01M1 | ITB01M0 | ITB00C | ITB00M2 | ITB00M1 | ITB00M0 | | INTETB0 | enable<br>TMRB0 | 99H | R | | R/W | | > R | 2 | R/W | | | | | | 0 | 0 | 0 | (//0 ) | 0 🔷 | (0) | O O | 0 | | | | 9AH | | INTTB11 | (TMRB1) | | | INTTB10 | (TMRB1) | | | INITETO 4 | Interrupt<br>enable<br>TMRB1 | | ITB11C | ITB11M2 | ITB11M1 | ITB11M0 | ITB10C | ITB10M2 | ITB10M1 | ITB10M0 | | INTETB1 | | | R | | R/W | $\rightarrow$ | R C | $\langle \gamma \rangle$ | R/W | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Interrupt<br>enable<br>TMRB2 | 9ВН | | INTTB21 | (TMRB2) | | | ) INTTB20 | (TMRB2) | | | | | | ITB21C | ITB21M2 | ITB21M1 | ITB21M0 | ITB20C | ITB20M2 | ITB20M1 | ITB20M0 | | INTETB2 | | | R | | > R/W | | R | | R/W | | | | | | 0 | (0)) | 0 | 0 | <b>//</b> 0 | 0 | 0 | 0 | | | | | | INTTB31 | (TMRB3) | \ | INTTB30(TMRB3) | | | | | INITETRO | Interrupt | 2011 | ITB31C | ITB31M2 | ITB31M1 | ITB31M0 | ITB30C | ITB30M2 | ITB30M1 | ITB30M0 | | INTETB3 | enable<br>TMRB3 | 9CH | R | | R/W | | R | | R/W | | | | | | (//o)) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | , | // ) ]_ | | INTTB41 | (TMRB4) | | | INTTB40 | (TMRB4) | | | INITETD ( | Interrupt | 07/1 | ITB41C | ITB41M2 | ITB41M1 | ITB41M0 | ITB40C | ITB40M2 | ITB40M1 | ITB40M0 | | INTETB4 | enable<br>TMRB4 | 9DH | R < | | R/W | | R | | R/W | | | | ^ ^ | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | \ \ \ \ | ,II | NTTBOF1(TM | RB1 Over flo | w) | 11 | NTTBOF0(TM | RB0 Over flow | v) | | INTETROCC | Interrupt<br>enable | )<br> | ITF1C | ITF1M2 | ITF1M1 | ITF1M0 | ITF0C | ITF0M2 | ITF0M1 | ITF0M0 | | INTETB01V | TMRB0/1 | 9EH | R | | R/W | | R | | R/W | | | | (Over flow) | $\wedge$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ſ | IxxxC | |---|------------------------| | L | | | I | Interrupt request flag | | lxxM2 | lxxM1 | IxxM0 | Function (Write) | |-------|-------|-------|------------------------------------| | 0 | 0 | 0 | Disables interrupt requests | | 0 | 0 | 1 | Sets interrupt priority level to 1 | | 0 | 1 | 0 | Sets interrupt priority level to 2 | | 0 | 1 | 1 | Sets interrupt priority level to 3 | | 1 | 0 | 0 | Sets interrupt priority level to 4 | | 1 | 0 | 1 | Sets interrupt priority level to 5 | | 1 | 1 | 0 | Sets interrupt priority level to 6 | | 1 | 1 | 1 | Disables interrupt requests | Page 40 2007-12-03 ### Interrupt Level Setting Registers | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|------------------------|----------------|--------|------------|--------------|-----------|---------------------------|--------------------------|----------------|---------|--| | | | | 11 | NTTBOF3(TM | RB3 Over flo | w) | INTTBOF2(TMRB2 Over flow) | | | | | | INTETB23V | Interrupt<br>enable | 9FH | ITF3C | ITF3M2 | ITF3M1 | ITF3M0 | ITF2C 〈 | ITF2M2 | ITF2M1 | ITF2M0 | | | INTETB23V | TMRB2/3<br>(Over flow) | | R | | R/W | | R | | R/W | | | | | (Over now) | | 0 | 0 | 0 | 0 | 0 | (0) | 0 | 0 | | | | Intorrunt | | | INT | RTC | | | NTTBOF4(TM | IRB4 Over flow | w) | | | INTETB4VRTC | Interrupt<br>enable | A0H | IRTCC | IRTCM2 | IRTCM1 | IRTCM0 | ITF4C/ | ITF4M2 | ITF4M1 | ITF4M0 | | | INTERDANCIO | TMRB4/<br>INTRTC | Aori | R | | R/W | | R | | R/W | | | | | IIVIICIO | | 0 | 0 | 0 | 0 | (0) | 0 | 0 | 0 | | | | | | | INT | TX0 | | | INT | RX0 | | | | INTES0 | INTRX0 & INTTX0 | A1H | ITX0C | ITX0M2 | ITX0M1 | ITXOMO | IRX0C | IRX0M2 | IRX0M1 | IRX0M0 | | | INTESU | enable | АІП | R | | R/W | | R | R | R/W | | | | | | | 0 | 0 | 0 | (//0 )) | 0 🚫 | (0) | 0 | 0 | | | | INTRX1 & INTTX1 enable | &<br>A2H | | INT | TX1 | | | TIME | RX1// | | | | INTES1 | | | ITX1C | ITX1M2 | ITX1M1 | ITX1M0 | IRX1C | IRX1M2 | IRX1M1 | IRX1M0 | | | INTEST | | | R | | R/W | $\supset$ | R | $\langle \gamma \rangle$ | R/W | | | | | | | 0 | 0 ( | 0 | 0 | 0 | $\mathcal{O}_0$ | 0 | 0 | | | | INTRX2 & INTTX2 enable | A3H | | INT | TX2 | | | ) INT | RX2 | | | | INTES2 | | | ITX2C | ITX2M2 | ITX2M1 | ITX2M0 | IRX2C | IRX2M2 | IRX2M1 | IRX2M0 | | | INTEGE | | | R | | R/W | | R | | R/W | | | | | | | 0 | ( 0 ) | 0 | 0 | <b>//</b> 0 | 0 | 0 | 0 | | | | | | | INT | SBI1 | <u> </u> | INTSBI0 | | | | | | INTESBI01 | INTSBI0 &<br>INTSBI1 | A4H | ISBI1C | ISBI1M2 | ISBI1M1 | ISBI1M0 | ISBI0C | ISBI0M2 | ISBI0M1 | ISBI0M0 | | | INTEGRIOT | enable | /(411 | R | | R/W | | R | | R/W | | | | | | | (v/o)) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | / | (/) | | INT | TC1// | | INTTC0 | | | | | | INTETC01 | INTTC0 & INTTC1 | A5H | ITC1C | ITC1M2 | ITC1M1 | ITC1M0 | ITC0C | ITC0M2 | ITC0M1 | ITC0M0 | | | INTETCOT | enable | | R 〈 | | R/W | | R | | R/W | | | | | $\wedge$ | , | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | 7/ | $\backslash D$ | | INT | тсз | | | INTTC2 | | | | | INTETC23 | INTTC2 & INTTC3 | A6H | ITC3C | ITC3M2 | ITC3M1 | ITC3M0 | ITC2C | ITC2M2 | ITC2M1 | ITC2M0 | | | | enable | , 1011 | R | | R/W | | R | | R/W | | | | | | $\wedge$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 1 | IxxxC | |---|------------------------| | ı | | | | Interrupt request flag | | lxxM2 | lxxM1 | IxxM0 | Function (Write) | |-------|-------|-------|------------------------------------| | 0 | 0 | 0 | Disables interrupt requests | | 0 | 0 | 1 | Sets interrupt priority level to 1 | | 0 | 1 | 0 | Sets interrupt priority level to 2 | | 0 | 1 | 1 | Sets interrupt priority level to 3 | | 1 | 0 | 0 | Sets interrupt priority level to 4 | | 1 | 0 | 1 | Sets interrupt priority level to 5 | | 1 | 1 | 0 | Sets interrupt priority level to 6 | | 1 | 1 | 1 | Disables interrupt requests | Page 41 2007-12-03 ### 3.3.2 External Interrupt Control ### External Interrupt Control Register (IIMC) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------------------------|--------------------------------------------|----------------------|---|---|-----|---|-----------------------------------------|-------------------------------------|-----------------------------------------------------------------| | | | | - | - | - | - | - | 10EDGE | IOLE | NMIREE | | | | | | | | V | N | | > | | | | Interrupt | 8CH | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | IIMC | input<br>mode<br>control | RMW instruc-<br>tions are pro-<br>hibited. | Always<br>write "0". | ŀ | ı | - ( | | INTO<br>EDGE<br>0: Rising<br>1: Falling | INT0<br>mode<br>0: Edge<br>1: Level | 1:Oper-<br>ates even<br>on rising/<br>falling<br>edge of<br>NMI | #### INT0 setting | | | | 0 | | |--------------------|---------------|-------------------|---------------------------|-----------| | P7FC <p75f></p75f> | <iole></iole> | <ioedge></ioedge> | INTO | | | 1 | 0 | 0 | Rising edge interruption | <b>\Q</b> | | 1 | 0 | 1 | Falling edge interruption | | | 1 | 1 | 0 | "H" level INT | | | 1 | 1 | 1 < | "L" level INT | | #### NMI rising edge enable | 0 | INT request generation at falling edge | |---|-----------------------------------------------| | 1 | INT request generation at rising/falling edge | # 3.3.3 Interrupt Request Flag Clear Register The interrupt request flag is cleared by writing the appropriate micro DMA start vector, as given in Table 3-1, to the register INTCLR. For example, to clear the interrupt flag INT0, perform the following register operation after execution of the DI instruction. INTCLR ← 0AH: Clears interrupt request flag INT0. ### Interrupt Request Flag Clear Register (INTCLR) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|------------------|----------------------|----------|------|-------|-------|----------|----------|-------|-------| | ^ | | 88H | - < | - | CLRV5 | CLRV4 | CLRV3 | CLRV2 | CLRV1 | CLRV0 | | Interrupt | | ) RMW \ | 7 | | W | | | | | | | INTCLR | Clear<br>Control | instructions | <u> </u> | )) - | 0 | 0 | 0 | 0 | 0 | 0 | | | | are prohib-<br>ited. | | | | | Interrup | t vector | | | Page 42 2007-12-03 ### 3.3.4 Micro DMA Start Vector Registers This register assigns micro DMA processing to which interrupt source. The interrupt source with a micro DMA start vector that matches the vector set in this register is assigned as the micro DMA start source. When the micro DMA transfer counter value reaches 0, the micro DMA transfer end interrupt corresponding to the channel is sent to the interrupt controller, the micro DMA start vector register is cleared, and the micro DMA start source for the channel is cleared. Therefore, to continue micro DMA processing, set the micro DMA start vector register again during the processing of the micro DMA transfer end interrupt. If the same vector is set in the micro DMA start vector registers of more than one channel, the channel with the lowest number has a higher priority. Accordingly, if the same vector is set in the micro DMA start vector registers of two channels, the interrupt generated in the channel with the lower number is executed until micro DMA transfer is complete. If the micro DMA start vector for this channel is not set again, the next micro DMA is started for the channel with the higher number. (Micro DMA chaining) #### Micro DMA Start Vector Registers (DMAnV) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 (( | 2 | 1 | 0 | | |-----------------------|-----------------------|----------|-------|--------|--------|-------------------|------------|------------|--------|--------|--| | | | | - | - | DMA0V5 | DMA0V4 | DMA0V3 | DMA0V2 | DMA0V1 | DMA0V0 | | | DMA0V | DMA0 | 0011 | - | | | | ((//R | ŵ | | | | | DMA0V Start<br>Vector | 80H | - | -4( | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | DMA0 st | art vector | | | | | | DMA1 DMA1V Start | | - | | DMA1V5 | DMA1V4 | DMA1V3 | DMA1V2 | DMA1V1 | DMA1V0 | | | | | 81H | - | | | R/W | | | | | | | | DIVIATV | DMA1V Start<br>Vector | 81H | - (( | 5 | 0 ~ | 0 | 0 | 0 | 0 | 0 | | | | | | | )) | | | DMA1 st | art vector | | | | | | | | ((/// | _ | DMA2V5 | DMA2V4 | DMA2V3 | DMA2V2 | DMA2V1 | DMA2V0 | | | DMA2V | DMA2<br>Start | | ) | _ < | R/W | | | | | | | | DIVIAZV | Vector | 82H | | -// | | 0 | 0 | 0 | 0 | 0 | | | | | | | | 1 | DMA2 start vector | | | | | | | | ^ | $\wedge$ | - | 7/ | DMA3V5 | DMA3V4 | DMA3V3 | DMA3V2 | DMA3V1 | DMA3V0 | | | DMA3V | DMA3 | 83H | - | _ | R/W | | | | | | | | DIVIASV | DMA3V Start Vector | | - < | _ | 0 | 0 | 0 | 0 | 0 | 0 | | | < | | | | | | | DMA3 st | art vector | | | | Page 43 2007-12-03 # 3.3.5 Micro DMA Burst Specification Specifying the micro DMA burst continues the micro DMA transfer until the transfer counter register reaches 0 after micro DMA start. Setting a bit which corresponds to the micro DMA channel of the DMAB registers mentioned below to "1" specifies a burst. If other interrupts (maskable/nonmaskable is not concerned) are generated during burst transfer, interrupt is executed after completed burst transfer. ### Micro DMA Burst Request Registers (DMAR) | Symbol | Name | Address | 7 | 6 | 5 | 4 | (3) | 2 | 1 | 0 | |-----------------|----------------------|----------------------|---|---|----------------|-------|-------|-------------|--------------|-------| | DMA<br>Software | 89H | - | - | - | - ( | DMAR3 | DMAR2 | DMAR1 | DMAR0 | | | | RMW | - | - | - | -4/ | | Ŕ | w > | | | | DMAR | DMAR Request instruc | instructions | - | - | - | | | 0 | 0 | 0 | | | Register | are prohib-<br>ited. | | | | | < | 1: DMA soft | ware request | | | | | Burst 8AH | - | - | (( | //- | DMAB3 | DMAB2 | DMAB1 | DMAB0 | | DMAD | DMA | | - | - | <del>(</del> ) | - | (( | R | /W | | | DMAB | Register | | - | - | | _ | 0 | | 0 | 0 | | | | | | | | / | ((// | 1: DMA bu | urst request | | Page 44 2007-12-03 **TMP91CW60** #### 3.3.6 Attention Point The instruction execution unit and the bus interface unit of this CPU operate independently. Therefore, immediately before an interrupt is generated, if the CPU fetches an instruction that clears the corresponding interrupt request flag, the CPU may execute the instruction that clears the interrupt request flag (Note) between accepting and reading the interrupt vector. In this case, the CPU reads the default vector 0008H and reads the interrupt vector address FFFF08H. To avoid the above problem, place instructions that clear interrupt request flags after a DI instruction. And in the case of setting an interrupt enable again by EI instruction after the execution of clearing instruction, execute EI instruction after clearing and more than 1-instructions (ex. "NOP" \* 1 times). If executed EI instruction without waiting NOP instruction after execution of clearing instruction, interrupt will be enable before request flag is cleared. In the case of changing the value of the interrupt mask register <IFF2:0> by execution of POP SR instruction, disable an interrupt by DI instruction before execution of POP SR instruction. In addition, take care as the following 2 circuits are exceptional and demand special attention. | | In level mode INT0 is not an edge-triggered interrupt. Hence, in level mode the interrupt request flip-flop for INT0 does not function. The peripheral interrupt request passes through the S input of the flip-flop and becomes the Q output. If the interrupt input mode is changed from edge mode to level mode, the interrupt request flag is cleared automatically. | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | INT0 level mode | If the CPU enters the interrupt response sequence as a result of INT0 going from 0 to 1, INT0 must then be held at 1 until the interrupt response sequence has been completed. If INT0 is set to level mode so as to release a halt state, INT0 must be held at 1 from the time INT0 changes from 0 to 1 until the halt state is released. (Hence, it is necessary to ensure that input noise is not interpreted as a 0, causing INT0 to revert to 0 before the halt state has been released.) When the mode changes from level mode to edge mode, interrupt request flags which were set in level mode will not be cleared. Interrupt request flags must be cleared using the following sequence. DI LD (IIMC), 00H ; Switches interrupt input mode from level mode to edge mode. LD (INTCLR), 0AH ; Clears interrupt request flag. NOP : Wait El instruction | | | EL | | INTRXn | The interrupt request flip-flop can only be cleared by reset or by reading the serial channel receive buffer. It cannot be cleared by writing INTCLR register. | Note: The following instructions or pin input state changes are equivalent to instructions that clear the interrupt request flag. INTO: Instructions which switch to level mode after an interrupt request has been generated in edge mode. The pin input change from high to low after interrupt request has been generated in level mode. (H ightarrow L) INTRXn: Instruction which reads the receive buffer. Page 45 2007-12-03 **TMP91CW60** # 4. Port Function The TMP91CW60 features 83 bit settings which relate to the various I/O ports. As well as general-purpose I/O port functionality, the port pins also have I/O functions which relate to the built-in CPU and internal I/Os. Table 4-1 lists the functions of each port pin. Table 4-1 lists the functions of each port pin. Table 4-2 lists I/O registers and their specifications. Table 4-1 Port Functions (R: PU = with programmable pull-up resistor) (1/2) | Port Names | Pin Names | Number of<br>Pins | Direction | R | Direction<br>Setting Unit | Pin Names for Built-in Functions | |------------|------------|-------------------|--------------|---------------------|---------------------------|----------------------------------| | Port0 | P00 to P07 | 8 | I/O | - | Bit | AD0 to AD7 | | Port1 | P10 to P17 | 8 | I/O | = | Bit | AD8 to AD15/A8 to A15 | | Port2 | P20~P27 | 8 | I/O | - | Bit | A16 to A23/A0 to A7 | | | P30 | 1 | I/O | - (( | Bit | TB3IN0, INT3, SDA0 | | Dout | P31 | 1 | I/O | | Bit | TB3IN1, INT4, SCL0 | | Port3 | P32 | 1 | I/O | 7 | Bit | WAIT, TB3OUT0 | | | P33 | 1 | I/O | d(-)> | Bit | TB30UT1 | | | P40 | 1 | 1/0 | ZZ | Bit | CSO, SCOUT | | | P41 | 1 | 1/0 | ₽U | Bit | CS1, TXD2 | | Port4 | P42 | 1 | 1/0 | PU / | Bit | CS2 RXD2 | | | P43 | 1 | 1/0 | PU | Bit | CS3, SCLK2, CTS2 | | | P44 | 1 | (1/0) | PU | Bit | ALE | | | P50 | 1 ( | 1/0 | - < | Bit | AN0 | | | P51 | 1 | <i>)</i> //o | <i>₹</i> | Bit | AN1 | | | P52 | (1)/ | I/O | (=J)/ | Bit | AN2 | | D 15 | P53 | 1 | )<br>I/O | $\bigcap_{\Lambda}$ | Bit | AN3 | | Port5 | P54 | 17 | 1/Q | (-) | Bit | AN4 | | | P55 | 1 | 1/0 | _ | Bit | AN5 | | | P56 | 1 | VO. | | Bit | AN6 | | | P57 | 1 | 1/0 | - | Bit | AN7 | | | P60 | 1 ^ | 1/0 | - | Bit | AN8 | | < (( | P61 | 1 | 1/0 | - | Bit | AN9 | | | P62 | > ( | 1/0 | = | Bit | AN10 | | | P63 | 1 | // //0 | _ | Bit | AN11 | | Port6 | P64 | 1 | I/O | = | Bit | AN12 | | | P65 | 1 | I/O | - | Bit | AN13 | | | P66 | 1 | I/O | = | Bit | AN14 | | | P67 | 1 | I/O | = | Bit | AN15 | Page 46 2007-12-03 Table 4-1 Port Functions (R: PU = with programmable pull-up resistor) (2/2) | Port Names | Pin Names | Number of<br>Pins | Direction | R | Direction<br>Setting Unit | Pin Names for Built-in Functions | |------------|-----------|-------------------|-----------|------------------------------|---------------------------|----------------------------------| | | P70 | 1 | I/O | - | Bit | TAOIN | | | P71 | 1 | I/O | - | Bit | TA1QUT | | | P72 | 1 | I/O | - | Bit | TA3OUT_ | | Port7 | P73 | 1 | I/O | - | Bit | TA4IN | | | P74 | 1 | I/O | - | Bit | TA5OUT | | | P75 | 1 | I/O | - | Bit | INTO | | | P80 | 1 | I/O | - | Bit | TB0IN0, INT5 | | | P81 | 1 | I/O | _ | Bit | TB0IN1, INT6 | | | P82 | 1 | I/O | - | Bit | TB0OUT0 | | Port8 | P83 | 1 | I/O | - | Bit | TB0OUT1 | | 1 Oito | P84 | 1 | I/O | - (( | Bit | TB1IN0, INT7 | | | P85 | 1 | I/O | | Bit | TB1IN1, INT8 | | | P86 | 1 | I/O | 4 | Bit | TB1OUT0 | | | P87 | 1 | I/O | 4(-/> | Bit | TB10UT1 | | | P90 | 1 | 1/0 | | Bit | TXD0 | | | P91 | 1 | 1/0 | <u></u> | Bit | RXD0 | | | P92 | 1 | 1/0 | ( | Bit | SCLK0, CTS0 | | Port9 | P93 | 1 | (70) | _ | Bit | TXD1 | | | P94 | 1 | 1/0 | - | Bit | RXD1 | | | P95 | 1 (( | I/O | - | Bit | SCLK1, CTS1 | | | P96 | | )/O | | Bit | XT1 | | | P97 | (1//) | I/O | | Bit | XT2 | | | PA0 | | I/O | $\left( \frac{1}{2} \right)$ | Bit | TB2IN0, INT1 | | PortA | PA1 | 1 | 1/0 | | Bit | TB2IN1, INT2 | | | PA2 | 1 | 1/0 | | Bit | TB2OUT0 | | | PA3 | 1 | 1/0 | - | Bit | TB2OUT1 | | | PB0 | 1 | / 1/0 | - | Bit | TB4IN0, INT9, SDA1 | | PortB | PB1 | 1 < | 1/0 | - | Bit | TB4IN1, INT10, SCL1 | | | PB2 | > 1 | 1/0 | - | Bit | TB4OUT0 | | | PB3 | | )) | - | Bit | TB4OUT1 | | | PZ0 | 1 | Output | - | Bit | RD | | PortZ | PZ1 | 1 | Output | _ | Bit | WR | | | PZ2 | 1 | I/O | PU | Bit | HWR | | | PZ3 | 1 | I/O | PU | Bit | R/W | Page 47 2007-12-03 Table 4-2 I/O Port Setting List(1/4) | 5.1 | D: N | 0 % | | I/O Re | gister Setting | Values | | |------------------|-----------------|-----------------------------------------|------------|--------|----------------|--------|------| | Ports | Pin Names | Specifications | Pn | PnCR | PnFC | PnFC2 | ODE | | | | Input port | × | 0 | | | | | Port0 | P00 to P07 | Output port | × | 1 | None | None | None | | | | AD0 to AD7 bus <sup>#1</sup> | × | × | | | | | | | Input port | × | 0 | 0 | ) | | | Port1 P10 to P17 | Output port | × | _ 1 (( | 7/0 | None | None | | | | AD8 to AD15 bus | × | 0 | | None | none | | | | | A8 to A15 output | × | (1 | 1 | | | | | | Input port | × | | 0 | | | | D- +0 | P20 to P27 | Output port | ×4( | 1 | 0 | None | None | | Port2 | P20 to P27 | A0 to A7 output | X | 0 | 1 | | None | | | | A16 to A23 output | (\x/\) | ) 1 < | | | | | | | Input port | × | 0 | 6 | | _ | | | P30 to P31 | Output port (CMOS output) | × | 1 ( | 0 | 0 | 0 | | | | Output port (open drain output) | × | 1 | | 0 | 1 | | | P32 to P33 | Input port | × | (0// | 0 | None | None | | | F32 10 F33 | Output port | X | | 0 | None | None | | | | TB3IN0 Input, INT3 Input | \(\times\) | 0 | 1 | 0 | - | | Port3 | P30 | SDA0 input/output (CMOS output) | × | 1/ | 0 | 1 | 0 | | Ports | | SDA0 input/output (open drain output)#2 | _ × | 1 | 0 | 1 | 1 | | | | TB3IN1 Input, INT4 Input | × | 0 | 1 | 0 | - | | P31 | P31 | SCL0 input/output (CMOS output) | X | 1 | 0 | 1 | 0 | | | | SCL0 input/output (open drain output)#2 | × | 1 | 0 | 1 | 1 | | | P32 | WAIT output | ) × | 0 | 1 | | None | | | F32 | TB3OUT0 output | × | 1 | 1 | None | | | | P33 | TB3OUT1 output | × | 1 | 1 | | | Page 48 2007-12-03 Table 4-2 I/O Port Setting List(2/4) | | 5: 11 | 0 11 1 | | I/O Re | egister Setting | Values | | | | |-------|------------|-----------------------------------|-----------|--------|-----------------|--------|------|--|--| | Ports | Pin Names | Specifications | Pn | PnCR | PnFC | PnFC2 | ODE | | | | | | Input port (without pull up) | 0 | 0 | 0 | 0 | | | | | | P40, P43 | Input port (with pull up) | 1 | 0 | 0 | 0 | None | | | | | | Output port | × | 1 | 0 | 0 | | | | | | | Input port (without pull up) | 0 | 0 | | 7 | | | | | | P42, P44 | Input port (with pull up) | 1 | 0 (( | 7/9 | None | None | | | | | | Output port | × | | 0 | | | | | | | | Input port (without pull up) | 0 | 0 | 0 | 0 | _ | | | | | B | Input port (with pull up) | 1 | 0 | 0 | 0 | _ | | | | | P41 | Output port (CMOS output) | ×4( | 1 | 0 | 0 | 0 | | | | | | Output port (open drain output) | X | 1 | 0 /2 | 0 | 1 | | | | | | CS0 output | ( ( / / / | ) 1 < | 1( | 0 | | | | | Port4 | P40 | SCOUT output | × | 1 | 0 | 7(1) | None | | | | | | CS1 output (CMOS output) | × | 1 / | 7 | 0 | 0 | | | | | | CS1 output (open drain output) | × | 1 | | 0 | 1 | | | | | P41 | TXD2 output (CMOS output) | × | (17) | 0 | 1 | 0 | | | | | | TXD2 output (open drain output)#2 | X | | 0 | 1 | 1 | | | | | P42 | CS2 output | <× | 1 | 1 | | | | | | | | RXD2 Input | × | /0/ | 0 | None | None | | | | | | CS3 output | ^ × | 1 | 1 | 0 | | | | | | B.co | SCLK2 Input | × | 0 | 0 | 0 | | | | | | P43 | SCLK2 output | X | 1 | 0 | 1 | None | | | | | | CTS2 Input | × | 0 | 0 | 0 | | | | | | P44 | ALE output | ) × | 1 | 1 | None | None | | | | | | Input port | × | 0 | 1 | | | | | | Port5 | P50 to P57 | Output port | × | 1 | 0 | None | None | | | | | <\? | AN0 to AN7 Input #3 | × | 0 | 0 | | | | | | | | Input port | × | 0 | 1 | | | | | | Port6 | P60 to P67 | Output port | × | 1 | 0 | None | None | | | | | | AN8 to AN15 Input #3 | × | 0 | 0 | | | | | | | 2 | Input port | × | 0 | 0 | | | | | | | P70 to P75 | Output port | × | 1 | 0 | | | | | | | P70 | TAOIN Input | × | 0 | None | | | | | | _ | P71 | TA1OUT output | × | 1 | 1 | | | | | | Port7 | P72 | TA3OUT output | × | 1 | 1 | None | None | | | | | P73 | TA4IN Input | × | 0 | None | | | | | | | P74 | TA5OUT output | × | 1 | 1 | | | | | | | P75 | INT0 Input | × | 0 | 1 | | | | | Page 49 2007-12-03 Table 4-2 I/O Port Setting List(3/4) | | 5: 11 | 0 11 1 | | I/O Re | gister Setting | Values | | |-------|-------------|-----------------------------------|----------------------------|-----------|----------------|-----------|------| | Ports | Pin Names | Specifications | Pn | PnCR | PnFC | PnFC2 | ODE | | | P80 to P87 | Input port | × | 0 | 0 | | | | | P80 10 P87 | Output port | × | 1 | 0 | | | | | P80 | TB0IN0, INT5 Input | × | 0 | 1 | | | | | P81 | TB0IN1, INT6 Input | × | 0 | 7 | ) | | | D40 | P82 | TB0OUT0 output | × | _ 1 (( | 7/4 | None | None | | Port8 | P83 | TB0OUT1 output | × | 7 | | None | None | | | P84 | TB1IN0, INT7 Input | × | (0) | <b>)</b> 1 | | | | | P85 | TB1IN1, INT8 Input | × | | 1 | | | | | P86 | TB1OUT0 output | × | 1 | 1 | $\sqrt{}$ | > | | | P87 | TB1OUT1 output | X | <u></u> 1 | 1 /2 | | | | | P91 to P92, | Input port | (\ <del>\</del> /\) | ) 0 < | > 0( | | Non- | | | P94 to P95 | Output port | × | 1 | 0 | 70) | None | | | | Input port | × | 0 ( | 0 | <b>)</b> | _ | | | P90, P93 | Output port (CMOS output) | × | 1 | | | 0 | | | | Output port (open drain output) | × | (1// | 0 | | 1 | | | DOO | TXD0 output (CMOS output) | output (CMOS output) x 1 1 | | | 0 | | | | P90 | TXD0 output (open drain output)#2 | <× | 1 | 1 | | 1 | | | P91 | RXD0 Input | × | /0/ | None | | None | | | | SCLK0 Input | ^ × | 0 | 0 | | None | | D40 | P92 | SCLK0 output | × | 1 | 1 | None | | | Port9 | | CTS0 Input | X | 0 | 0 | None | | | | P93 | TXD1 output (CMOS output) | * | 1 | 1 | | 0 | | | F93 | TXD1 output (open drain output)#2 | ) × | 1 | 1 | | 1 | | | P94 | RXD1 Input | × | 0 | None | | None | | | | SCLK1 Input | × | 0 | 0 | | | | | P95 | SCLK1 output | × | 1 | 1 | | None | | | | CTS1 Input | × | 0 | 0 | | | | ^ | | Input port | × | 0 | 1 | | | | | P96 to P97 | Output port | × | 1 | 1 | | None | | | 2 | XT1 to XT2 #4 | × | 0 | 0 | | | | | PA0 to PA3 | Input port | × | 0 | 0 | | | | | PAU 10 PA3 | Output port | × | 1 | 0 | | | | D. 14 | PA0 | TB2IN0 Input, INT1 Input | × | 0 | 1 | No | | | PortA | PA1 | TB2IN1 Input, INT2 Input | × | 0 | 1 | None | None | | | PA2 | TB2OUT0 | × | 1 | 1 | | | | | PA3 | TB2OUT1 | × | 1 | 1 | | | Page 50 2007-12-03 Table 4-2 I/O Port Setting List(4/4) | | | | | I/O Re | egister Setting | Values | | |-------|------------|-------------------------------------------|---------|--------|-----------------|--------|------| | Ports | Pin Names | Specifications | Pn | PnCR | PnFC | PnFC2 | ODE | | | | Input port | × | 0 | 0 | 0 | = | | | PB0 to PB1 | Output port (CMOS output) | × | 1 | 0 | 0 | 0 | | | | Output port (open drain output) | × | 1 | 0 | 0 | 1 | | | PB2 to PB3 | Input port | × | 0 | 0 | None | None | | | FB2 10 FB3 | Output port | x 1 7/0 | | 7/9 | None | None | | | | TB4IN0 Input, INT9 Input | × | 0 | | 0 | _ | | PortB | PB0 | SDA1 input/output (CMOS output) | × | (1) | 0 | 1 | 0 | | | | SDA1 input/output (open drain output)#2 | × | | 0 | 1 | 1 | | | | TB4IN1 Input, INT10 Input | ×4( | 0 | 1 | 0 | - | | | PB1 | SCL1 input/output (CMOS output) | X | 1 | 0 /2 | | 0 | | | | SCL1 input/output (open drain output)#2 | (\x/\) | ) 1 < | ) o(C | | 1 | | | PB2 | TB4OUT0 output | × | 1 | | None | None | | | PB3 | TB4OUT1 output | × | 1 / | 7 | None | None | | | | Output port | × | | | | | | | PZ0 | RD output only when accessing an external | 1 | None | 1 | | | | | | Always RD output | 9 | | / 1 | | | | | PZ1 | Output port | <× | None | 0 | | | | D- +7 | FZI | WR output only when accessing an external | × | None | 1 | None | None | | PortZ | | Input port (without pull up) | 0 | 0 | 0 | None | None | | | PZ2 to PZ3 | Input port (with pull up) | 1/1 | 1 0 0 | | | | | | | Output port | (X) | x 1 0 | | | | | | PZ2 | HWR output | × | 1 | 1 | _ | | | | PZ3 | R/W output | × | 0 | 1 | | | <sup>#1</sup> Note: x:Don't care 2007-12-03 Page 51 There is not port setting for changing AD0 to AD7. When accessing external area, it changes automatically. If using P30/P31/P41/P90/P93/PB0/PB1 as open-drain output in SDA0/SCL0/TXD2/TXD0/TXD1/SDA1/SCL1 output, #2 please set ODE. If using P50 to P57,P60 to P67 as an analog input, please set ADCCR1<SAIN3:0>. If using P96 to P97 as XT1-XT2, please set SYSCR0. TMP91CW60 # 4.1 Port 0 (P00 to P07) Port 0 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P0CR. Reset operation initializes all bits of the control register P0CR to "0" and sets port 0 to input port. In addition to functioning as a general-purpose I/O port, port 0 can also function as address data bus (AD0 to AD7). When accessing external area, port 0 functions as address data bus (AD0 to AD7) automatically, and P0CR is cleared to "0". Figure 4-1 Port 0 #### Port 0 Register P0 (0000H) | | | // | / 7 / h | | | | | |-------------|----------|--------------|-------------------|-------------------|----------------|-----|-----| | | // 7 ) 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit symbol | P07 P06 | P05 | P04 | P03 | P02 | P01 | P00 | | Read/Write | | | R | /W | | | | | After reset | | Data from ex | ternal port (Outp | ut latch register | is undefined.) | | | Port 0 Control Register (Read-modify-write instructions are prohibited.) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---------------------------------------------------------------------------------------------------------------|------|------|------|------|------|------|------|------| | | Bit symbol | P07C | P06C | P05C | P04C | P03C | P02C | P01C | P00C | | P0CR<br>(0002H) | Read/Write | 27 | | | W | | | | | | . , | After reset | 0 | 9 | 0 | 0 | 0 | 0 | 0 | 0 | | | Function 0: Input 1: Output (When access to external, become AD7 to AD0 and this register is cleared to "0".) | | | | | | | | | | access | P0xC | P07<br>function | P06<br>function | P05<br>function | P04<br>function | P03<br>function | P02<br>function | P01<br>function | P00<br>function | |----------|-------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | internal | 0 | input port | internal | 1 | output port | external | cleared to<br>"0" | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | AD1 | AD0 | Note: <P0xC> is bit X of each register P0CR. Page 52 2007-12-03 **TMP91CW60** # 4.2 Port 1 (P10 to P17) Port 1 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P1CR and function register P1FC. Reset operation initializes all bits of output latch P1, the control register P1CR and function register P1FC to "0" and sets port 1 to input port. In addition to functioning as a general-purpose I/O port, port 1 can also function as address data bus (AD8 to AD15) and address bus (A8 to A15). Page 53 2007-12-03 ### Port 1 Register P1 (0001H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|-----|--------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--| | Bit symbol | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | | | | Read/Write | | RW | | | | | | | | | | After reset | | Data from external port (Output latch register is cleared to "0".) | | | | | | | | | ### Port 1 Control Register (Read-modify-write instructions are prohibited.) P1CR (0004H) | | 7 | 6 | 5 | 4 | 3 | $()^2 \wedge$ | 1 | 0 | |-------------|------|------|------|-----------------------------------------------------------------------------------------------|---------------|---------------|------|------| | Bit symbol | P17C | P16C | P15C | P14C | P13C | P12C | P11C | P10C | | Read/Write | | | | 1 | N C | | | | | After reset | 0 | 0 | 0 | 0 | 0 | ) P 0 | 0 | 0 | | Function | | | | < <refer colu<="" td="" to=""><td>umn of P1FC&gt;&gt;</td><td></td><td></td><td></td></refer> | umn of P1FC>> | | | | ### Port 1 Function Register (Read-modify-write instructions are prohibited.) P1FC (0005H) | | 7 | 6 | 5 | 4 | 3 | 2 | (//1)) | 0 | |-------------|------|------|---------------|------------------|-----------------|----------------------------------------|--------|------| | Bit symbol | P17F | P16F | P15F | P14F | P13F | P12F | P11F | P10F | | Read/Write | | | | ( V | V | | ~ | | | After reset | 0 | 0 | 0 | 0 | 0 | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 0 | 0 | | Function | | P1 | FC/P1CR = 00: | Input, 01: Outpu | ut, 10: AD15 to | AD8, 11: A15 to | A8 | | | P1xF | P1xC | P17<br>function | P16<br>function | P15<br>function | P14<br>function | P13<br>function | P12<br>function | P11<br>function | P10<br>function | |------|------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | 0 | 0 | input port | 0 | 1 | output port | 1 | 0 | AD15 | AD14 | AD13 | AD12 | AD11 | AD10 | AD9 | AD8 | | 1 | 1 | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | Note: <P1XF>/<P1XC> is bit X of each register P1FC/P1CR. **TMP91CW60** # 4.3 Port 2 (P20 to P27) Port 2 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P2CR and function register P2FC. Reset operation initializes all bits of output latch P2 to "1", and the control register P2CR and function register P2FC to "0", and sets port 2 to input port. In addition to functioning as a general-purpose I/O port, port 2 can also function as address bus (A0 to A5) and address bus (A16 to A23). Page 55 2007-12-03 ### Port 2 Register P2 (0006H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|-----|----------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--|--| | Bit symbol | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | | | | | Read/Write | | R/W | | | | | | | | | | | After reset | | Data from external port (Output latch register is set to "1".) | | | | | | | | | | ### Port 2 Control Register (Read-modify-write instructions are prohibited.) P2CR (0008H) | | 7 | 6 | 5 | 4 | 3 | (7/2) | 1 | 0 | | | | |-------------|------|------|------|-----------------------------------------------------------------------------------------------|---------------|-------|------|------|--|--|--| | Bit symbol | P27C | P26C | P25C | P24C | P23C | P22C | P21C | P20C | | | | | Read/Write | | W | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | ) > 0 | 0 | 0 | | | | | Function | | | | < <refer colu<="" th="" to=""><th>ımn of P2FC&gt;&gt;</th><th></th><th></th><th></th></refer> | ımn of P2FC>> | | | | | | | ### Port 2 Function Register (Read-modify-write instructions are prohibited.) P2FC (0009H) | | 7 | 6 | 5 | 4 | 3 | 2 | (/1)) | 0 | |-------------|------|------|---------------|-----------------------------------------|------------------|-----------------|-------|------| | Bit symbol | P27F | P26F | P25F | P24F | P23F | P22F | P21F | P20F | | Read/Write | | | | ( \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | V | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | Function | | F | P2FC/P2CR = 0 | 0: Input, 01: Out | put, 10: A7 to A | 0, 11: A23 to A | 16 | | | P2xF | P2xC | P27<br>function | P26<br>function | P25<br>function | P24<br>function | P23<br>function | P22<br>function | P21<br>function | P20<br>function | |------|------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | 0 | 0 | input port | 0 | 1 | output port | 1 | 0 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 | | 1 | 1 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | Note: <P2XF>/<P2XC> is bit X of each register P2FC/P2CR. When setting to address bus A23 to A16, set P2FC after setting P2CR. If P2CR is set after setting P2FC, A7 to A0 are outputted between setting P2FC and setting P2CR when P2CR is "0". Page 56 2007-12-03 TOSHIBA TMP91CW60 ### 4.4 Port3 (P30 to P33) Port 3 is an 4-bit general-purpose I/O port. Reset operation initializes to input port. All bits of output latch register P3 are set to "1". There are the following functions in addition to an I/O port. This function enable each function by writing "1" to applicable bit of port 3 function register P3FC. - •The input function of wait control (WAIT) - •The input function of external interrupt (INT3, INT4) - •The input function of 16-bit timer 3 (TB3IN0, TB3IN1) - •The output function of 16-bit timer 3 (TB3OUT0, TB3OUT1) - •The I/O function of serial bus interface 0 (SDA0, SCL0) Reset operation initializes, P3CR,P3FC and P3FC2 to "0", all bits are set to input port. And Port 30 and 31 have a programmable open-drain function which can be controlled by the ODE register. Figure 4-4 Port 30 and 31 Page 57 2007-12-03 Figure 4-5 Port 32 and 33 Page 58 2007-12-03 ### Port 3 Register P3 (000CH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|---|---|---|---|----------------------------------------------------------------|-------|--------|-----|--| | Bit symbol | _ | - | - | - | P33 | P32 | P31 | P30 | | | Read/Write | _ | - | - | - | R/W | | | | | | After reset | - | - | - | - | Data from external port (Output latch register is set to "1".) | | | | | | Function | | | - | | | outpu | t mode | | | ### Port 3 Control Register (Read-modify-write instructions are prohibited.) P3CR (000EH) | | 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | |-------------|---|---|---|---|-----------|----------|------| | Bit symbol | - | - | ı | ı | P33C P32C | P31C | P30C | | Read/Write | _ | _ | _ | - | | W | | | After reset | _ | _ | _ | - | 0 0 | 0 | 0 | | Function | | | - | | 0:Input | 1:Output | > | ### Port 3 Function Register (Read-modify-write instructions are prohibited.) P3FC (000FH) | | 7 | 6 | 5 | 4 | 3 | 2 | ) 1 | 0 | |-------------|---|---|-----|----------|------|--------|------|------| | Bit symbol | ı | - | - < | ((-)) | P33F | P32F | P31F | P30F | | Read/Write | ı | | -( | | ( | 77,01 | N | | | After reset | - | - | | <u> </u> | 0 | / ) )0 | 0 | 0 | # Port 3 Function Register 2 (Read-modify-write instructions are prohibited.) P3FC2 (000DH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|------|-----|------|---|---|-------|-------| | Bit symbol | ı | (-( | - | -// | ı | ı | P31F2 | P30F2 | | Read/Write | I | | ) - | 17/ | _ | ı | V | V | | After reset | - | (//- | = | (=1/ | = | = | 0 | 0 | | | | | | | _ / | | |-------|------|------|-----------------|-----------------|-----------------|-----------------| | P3xF2 | P3xF | РЗхС | P33<br>function | P32<br>function | P31<br>function | P30<br>function | | 0 | 0 | 0 | input port | input port | input port | input port | | 0 | 0 | 7- | output port | output port | output port | output port | | 0 | 1 | | reserved | WAIT | TB3IN1/INT4 | TB3IN0/INT3 | | 0 | | 1 | TB3OUT1 | TB3OUT0 | reserved | reserved | | 1 | 0 | 0 | reserved | reserved | reserved | reserved | | 1 | 0 | 1(( | reserved | reserved | SCL0 | SDA0 | | 1 | | 0 | reserved | reserved | reserved | reserved | | 1 | 1 | 1 | reserved | reserved | reserved | reserved | Note 1: <P3xF2>/<P3xF>/<P3xC> is bit X of each register P3FC2/P3FC/P3CR. Note 2: Wen P32/WAIT pin is used as a WAIT pin, set P3CR<P32C> to "0" and Chip Select/WAIT control register <BnW2:0> to "010". Page 59 2007-12-03 TOSHIBA TMP91CW60 # 4.5 Port 4 (P40 to P44) Port 4 is an 5-bit general-purpose I/O port. Reset operation initializes to input port, and connects a pull-up resistor. All bits of output latch register P4 are set to "1". There are the following functions in addition to an I/O port. This function enable each function by writing "1" to applicable bit of port 4 function register P4FC. - •The output function of a chip select signal ( $\overline{CS0}$ to $\overline{CS3}$ ) - •The I/O function of the serial channel 2 (RXD2, TXD2, SCLK2/CTS2) - •The output function of an Address latch enable signal (ALE) - •The output function of a system clock signal (SCOUT) Reset operation initializes, P4CR,P4FC and P4FC2 to "0", all bits are set to input port. And Port 41 have a programmable open-drain function which can be controlled by the ODE register. Figure 4-6 Port 40 Page 60 2007-12-03 Page 61 2007-12-03 Page 62 2007-12-03 Page 63 2007-12-03 Page 64 2007-12-03 #### Port 4 Register P4 (0010H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|---|---|---|------------------------------------------------------------------------------------------------|-----|-----------------------------------|-----|-----|--| | Bit symbol | - | - | - | P44 | P43 | P42 | P41 | P40 | | | Read/Write | _ | - | - | R/W | | | | | | | After reset | - | ı | - | | | ta from external atch register is | • | | | | Function | | | | (Output latch register): Pull-up resistor OFF (Output latch register): Pull-up resistor ON | | | | | | #### Port 4 Control Register (Read-modify-write instructions are prohibited.) P4CR (0012H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|------|------|-----------------|------|------| | Bit symbol | - | - | - | P44C | P43C | P42C | P41C | P40C | | Read/Write | - | - | - | | | W | | | | After reset | - | - | - | 0 | 0 | 0 | 0 | 0 | | Function | | | | (0 | 7/\ | : Input 1: Outp | put | | #### Port 4 Function Register (Read-modify-write instructions are prohibited.) P4FC (0013H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|----|------|------|------|------|------| | Bit symbol | - | ı | -( | P44F | P43F | P42F | P41F | P40F | | Read/Write | | ı | | | | ₩ . | | | | After reset | - | - | (7 | 0 // | 0 | 0 | 0 | 0 | ### Port 4 Function Register 2 (Read-modify-write instructions are prohibited.) P4FC2 (0011H) | | 7 | 6 | )) 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----------|------------|----------|-------|---------|---|-------|-------| | Bit symbol | - | $\bigcirc$ | _ | | → P43F2 | _ | P41F2 | P40F2 | | Read/Write | | ( | - / | | W | _ | \ | N | | After reset | // - ) ) | | <u> </u> | // <> | 0 | _ | 0 | 0 | | P4xF2 | P4xF | P4xC | P44<br>function | P43<br>function | P42<br>function | P41<br>function | P40<br>function | |-------|---------------|------|-----------------|----------------------------|----------------------|-----------------|-----------------| | 0 | 0 | 0 | input port | input port<br>(SCLK2/CTS2) | input port<br>(RXD2) | input port | input port | | 0 | 0 | 1 | output port | output port | output port | output port | output port | | 0 | )1 | 0( | reserved | reserved | reserved | reserved | reserved | | 0 | $\overline{}$ | 1 | ALE output | CS3 | CS2 | CS1 | CS0 | | 1 | 0 | 0 | input port | reserved | input port<br>(RXD2) | reserved | reserved | | 1 | 0 | 1 | output port | SCLK2 | output port | TXD2 | SCOUT | | 1 | 1 | 0 | reserved | reserved | reserved | reserved | reserved | | 1 | 1 | 1 | ALE output | reserved | CS2 | reserved | reserved | Note 1: <P4xF2>/<P4xF>/<P4xC> is bit X of each register P4FC2/P4FC/P4CR. - Note 2: When port 4 is used as input mode, P4 register controls internal pull-up resistor. Read-modify-write instruction is prohibited in input mode or I/O mode. Setting the internal pull-up resistor may be depended on the states of the input pin. - Note 3: When outputting chip select signal ( $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ ), set bit of control register (P4CR) to "1" after setting bit of function register (P4FC) to "1". If P4FC is set after setting P4CR, value of P4 register is outputted between setting P4CR and setting P4FC. - Note 4: When setting TXD2 pin to open-drain output, write "1" to bit2 of ODE register. P42/RXD2 pin does not have a register which changes Port/Function. For example, when it is also used as an input port, the input signal is inputted to SIO as serial receiving data. Page 65 2007-12-03 # 4.6 Port 5 (P50 to P57) Port 5 is an 8-bit general-purpose I/O port. By the reset action, it becomes Hi-Z and becomes analog input permission. All bits of output latch register P5 are set to "1". There are the following functions in addition to an I/O port. Page 66 2007-12-03 ### Port 5 Register P5 (0014H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|-----|----------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--| | Bit symbol | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | | | | Read/Write | | R/W | | | | | | | | | | After reset | | Data from external port (Output latch register is set to "1".) | | | | | | | | | #### Port 5 Control Register (Read-modify-write instructions are prohibited.) P5CR (0016H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|------|------|------|----------|-----------|------|-------|------|--|--| | Bit symbol | P57C | P56C | P55C | P54C | P53C | P52C | P51C | P50C | | | | Read/Write | | W | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | (0) | 0 | 0 | 0 | | | | Function | | | | 0: Input | 1: Output | | 3(( \ | | | | ### Port 5 Function Register (Read-modify-write instructions are prohibited.) P5FC (0017H) | | 7 | 6 | 5 | 4 | 3 | (2) | 1 | 0 | |-------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------| | Bit symbol | P57F | P56F | P55F | P54F | P53F | P52F | P51F | P50F | | Read/Write | | | | | v ( | 7/^ | | | | After reset | 0 | 0 | 0 | > 0 | 0 | <u>)</u> 0 | 0 | 0 | | Function | P57 input<br>0:disable<br>1:enable | P56 input<br>0:disable<br>1:enable | P55 input<br>0:disable<br>1:enable | P54 input<br>0:disable<br>1:enable | P53 input<br>0:disable<br>1:enable | P52 input<br>0:disable<br>1:enable | P51 input<br>0:disable<br>1:enable | P50 input<br>0:disable<br>1:enable | | P5xF | P5xC | P57<br>function | P56<br>function | P55<br>function | P54<br>function | P53<br>function | P52<br>function | P51<br>function | P50<br>function | |------|------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | 0 | 0 | input disable | 0 | 1 | output port | 1 | 0 / | input enable | 1 | 1 | output port Note 1: <P5xF>/<P5xC> is bit X of each register P5FC/P5CR. Note 2: The input channel selection of AD converter are set by AD converter mode register ADCCR1. Page 67 2007-12-03 # 4.7 Port 6 (P60 to P67) Port 6 is an 8-bit general-purpose I/O port. By the reset action, it becomes Hi-Z and becomes analog input permission. All bits of output latch register P6 are set to "1". There are the following functions in addition to an I/O port. Page 68 2007-12-03 ### Port 6 Register P6 (0018H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|----------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|--|--| | Bit symbol | P67 | P66 | P65 | P64 | P63 | P62 | P61 | P60 | | | | Read/Write | R/W | | | | | | | | | | | After reset | Data from external port (Output latch register is set to "1".) | | | | | | | | | | #### Port 6 Control Register (Read-modify-write instructions are prohibited.) P6CR (001AH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|--------------------|------|------|------|------|------|------|------|--| | Bit symbol | P67C | P66C | P65C | P64C | P63C | P62C | P61C | P60C | | | Read/Write | W | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | (0) | 0 | 0 | 0 | | | Function | 0: Input 1: Output | | | | | | | | | ### Port 6 Function Register (Read-modify-write instructions are prohibited.) P6FC (001BH) | | 7 | 6 | 5 | 4 | 3 | (2) | 1 | 0 | |-------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------| | Bit symbol | P67F | P66F | P65F | P64F | P63F | P62F | P61F | P60F | | Read/Write | | | | | N (C | 7/^ | | | | After reset | 0 | 0 | 0 | > 0 | 0 | <u>)</u> 0 | 0 | 0 | | Function | P67 input<br>0:disable<br>1:enable | P66 input<br>0:disable<br>1:enable | P65 input<br>0:disable<br>1:enable | P64 input<br>0:disable<br>1:enable | P63 input<br>0:disable<br>1:enable | P62 input<br>0:disable<br>1:enable | P61 input<br>0:disable<br>1:enable | P60 input<br>0:disable<br>1:enable | | P6xF | P6xC | P67<br>function | P66<br>function | P65<br>function | P64<br>function | P63<br>function | P62<br>function | P61<br>function | P60<br>function | |------|------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | 0 | 0 | input disable | 0 | 1 | output port | 1 | 0 / | input enable | 1 | 1 | output port Note 1: <P6xF>/<P6xC> is bit X of each register P6FC/P6CR. Note 2: The input channel selection of AD converter are set by AD converter mode register ADCCR1. Page 69 2007-12-03 TOSHIBA TMP91CW60 # 4.8 Port 7 (P70 to P75) Port 7 is an 6-bit general-purpose I/O port. Reset operation initializes to input port. All bits of output latch register P7 are set to "1". There are the following functions in addition to an I/O port. This function enable each function by writing "1" to applicable bit of port 7 function register P7FC. - •The I/O function of 8-bit timer 01 (TA0IN,TA1OUT) - •The output function of 8-bit timer 23 (TA3OUT) - •The I/O function of 8-bit timer 45 (TA4IN,TA5OUT) - •The input function of external interrupt (INT0) Reset operation initializes, P7CR and P7FC to "0", all bits are set to input port, Figure 4-13 Port 70 to 74 Page 70 2007-12-03 Page 71 2007-12-03 #### Port 7 Register P7 (001CH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|---|---|-----|----------------------------------------------------------------|-----|-----|-----|-----|--|--| | Bit symbol | - | - | P75 | P74 | P73 | P72 | P71 | P70 | | | | Read/Write | _ | - | | R/W | | | | | | | | After reset | - | - | | Data from external port (Output latch register is set to "1".) | | | | | | | #### Port 7 Control Register (Read-modify-write instructions are prohibited.) P7CR (001EH) | | 7 | 6 | 5 | 4 | 3 | //2 | 1 | 0 | | | |-------------|---|---|------|--------------------|------|------|------|------|--|--| | Bit symbol | _ | 1 | P75C | P74C | P73C | P72C | P71C | P70C | | | | Read/Write | - | 1 | | (W) | | | | | | | | After reset | - | 1 | 0 | 0 | 0 | )) o | 0 | 0 | | | | Function | | | | 0: Input 1: Output | | | | | | | #### Port 7 Function Register (Read-modify-write instructions are prohibited.) P7FC (001FH) | | 7 | 6 | 5 | 4 | 3 | 2 | 40/ | 0 | |-------------|---|---|--------------------|----------------------|-----|----------------------|----------------------|---| | Bit symbol | _ | 1 | P75F | P74F | > _ | P72F | P71F | _ | | Read/Write | - | 1 | $\Diamond$ | W \ | - | | W | - | | After reset | - | 1 | 0 | 0 | - ( | | 0 | _ | | Function | | | 0: port<br>1: JNT0 | 0: port<br>1: TA5OUT | | 0: port<br>1: TA3OUT | 0: port<br>1: TA1OUT | | #### P75 INT0 setting | <p75f></p75f> | <iole></iole> | <ioedge></ioedge> | INTO | |---------------|---------------|-------------------|-------------------------| | 1 | 0 | | Rising edge detect INT | | 1 | 0 ( | <u></u> | falling edge detect INT | | 1 | 1 | )0 | H level INT | | 1 | | 1 | L level-INT | | P7xF | P7xC | P75<br>function | P74<br>function | P73<br>function | P72<br>function | P71<br>function | P70<br>function | |---------------------|------------|-----------------|-----------------|-----------------------|-----------------|-----------------|-----------------------| | 0 | <b>○</b> ○ | input port | input port | input port<br>(TA4IN) | input port | input port | input port<br>(TA0IN) | | 0 | 4/ | output port | output port | output port | output port | output port | output port | | 1 | 0 | INT0 | reserved | reserved | reserved | reserved | reserved | | $\langle 1 \rangle$ | (1) | reserved | TA5OUT | reserved | TA3OUT | TA1OUT | reserved | Note 1: <P7xF>/<P7xC> is bit X of each register P7FC/P7CR. Note 2: P70/TA0IN, P73/TA4IN pin dose not have a register changing PORT/FUNCTION. For example, when it is used as an input port, the input signal is inputted to 8bit Timer. Page 72 2007-12-03 # 4.9 Port 8 (P80 to P87) Port 8 is an 8-bit general-purpose I/O port. Reset operation initializes to input port. All bits of output latch register P8 are set to "1". There are the following functions in addition to an I/O port. This function enable each function by writing "1" to applicable bit of port 8 function register P8FC. - •The I/O function of 16-bit timer 0 (TB0IN0,TB0IN1,TB0OUT0,TB0OUT1) - •The I/O function of 16-bit timer 1 (TB1IN0,TB1IN1,TB1OUT0,TB1OUT1) - •The input function of external interrupt (INT5 to INT8) Reset operation initializes, P8CR and P8FC to "0", all bits are set to input port. Figure 4-15 Port 8 Page 73 2007-12-03 ## Port 8 Register P8 (0020H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|-----|----------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--| | Bit symbol | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | | | Read/Write | | R/W | | | | | | | | | | After reset | | Data from external port (Output latch register is set to "1".) | | | | | | | | | ## Port 8 Control Register (Read-modify-write instructions are prohibited.) P8CR (0022H) | | 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | | | | |-------------|------|--------------------|------|------|-----------|------|------|--|--|--| | Bit symbol | P87C | P86C | P85C | P84C | P83C P82C | P81C | P80C | | | | | Read/Write | | w | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | | | | | Function | | 0: Input 1: Output | | | | | | | | | # Port 8 Function Register (Read-modify-write instructions are prohibited.) P8FC (0023H) | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | |-------------|-----------------------|-----------------------|-------------------------------|-------------------------------|-----------------------|-----------------------|-------------------------------|-------------------------------| | Bit symbol | P87F | P86F | P85F | P84F | P83F | P82F | P81F | P80F | | Read/Write | | | | | N | | | | | After reset | 0 | 0 | 0 | 0 | 0 (( | / 0 | 0 | 0 | | Function | 0: port<br>1: TB1OUT1 | 0: port<br>1: TB1OUT0 | 0: port<br>1: TB1IN1,<br>INT8 | 0: port<br>1: TB1IN0,<br>INT7 | 0: port<br>1: TB0OUT1 | 0: port<br>1: TB0OUT0 | 0: port<br>1: TB0IN1,<br>INT6 | 0: port<br>1: TB0IN0,<br>INT5 | | | | | | | | * | | | | |------|------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | P8xF | P8xC | P87<br>function | P86<br>function | P85<br>function | P84<br>function | P83<br>function | P82<br>function | P81<br>function | P80<br>function | | 0 | 0 | input port | 0 | 1 | output port | 1 | 0 < | reserved | reserved | TB1IN1/<br>INT8 | TB1IN0/<br>INT7 | reserved | reserved | TB0IN1/<br>INT6 | TB0IN0/<br>INT5 | | 1 | 1 | TB10UT1 | TB1OUT0 | reserved | reserved | TB0OUT1 | TB0OUT0 | reserved | reserved | Note: <P8xF>/<P8xC> is bit X of each register P8FC/P8CR. Page 74 2007-12-03 TOSHIBA TMP91CW60 ## 4.10 Port 9 (P90 to P97) #### • Port 90 to 95 Port 90 to 95 are a 6-bit general-purpose I/O port. Reset operation initializes to input port. All bits of output latch register are set to "1". In addition to functioning as a I/O port, port 90 to 95 can also function as I/O of SIO0, SIO1. This function enable each function by writing "1" to applicable bit of port 9 function register P9FC. Reset operation initializes P9CR and P9FC to "0", all bits are set to input port, #### • Port 96 to 97 Port 96 to 97 are a 2-bit general-purpose I/O port. In case of output port, this is open drain output. Reset operation initializes output latch register and control register to "1", and it is set to "High-Z" (High impedance). In addition to functioning as a I/O port, port 96 to 97 can also function as low-frequency oscillator connection pin (XT1 and XT2) during using low speed clock function. Therefore, dual clock function can use by setting of system clock control registers SYSCR0 and SYSCR1. ## 4.10.1 Port 90 and 93 (TXD0 and TXD1) In addition to functioning as a I/O port, Port 90 and 93 can also function as TXD output pin of serial channel. And Port 90 and 93 have a programmable open-drain function which can be controlled by the ODE register. Page 75 2007-12-03 # 4.10.2 Port91(RXD0), 94 (RXD1) Page 76 2007-12-03 # 4.10.3 Port 92(CTS0/SCLK0), 95 (CTS1/SCLK1) In addition to functioning as a I/O port, port 92 and 95 can also function as $\overline{\text{CTS}}$ input pin or SCLK I/O pin of serial channel. Figure 4-18 Port 92 and 95 Page 77 2007-12-03 # 4.10.4 Port 96 (XT1), 97 (XT2) In addition to functioning as a I/O port, port 96 and 97 can also function as low frequency oscillator connection pins. Figure 4-19 Port 96 and 97 Page 78 2007-12-03 #### Port 9 Register P9 (0024H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|-----|----------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--| | Bit symbol | P97 | P96 | P95 | P94 | P93 | P92 | P91 | P90 | | | | Read/Write | | RW | | | | | | | | | | After reset | | Data from external port (Output latch register is set to "1".) | | | | | | | | | #### Port 9 Control Register (Read-modify-write instructions are prohibited.) P9CR (0026H) | | 7 | 6 | 5 | 4 | 3 | $()^2 \wedge$ | 1 | 0 | | | |-------------|------|--------------------|------|------|------|---------------|------|------|--|--| | Bit symbol | P97C | P96C | P95C | P94C | P93C | P92C | P91C | P90C | | | | Read/Write | | W | | | | | | | | | | After reset | 1 | 1 | 0 | 0 | 0 | ) > 0 | 0 | 0 | | | | Function | | 0: Input 1: Output | | | | | | | | | ## Port 9 Function Register (Read-modify-write instructions are prohibited.) P9FC (0027H) | | 7 | 6 | 5 | 4 | 3 | 2 | (2/1)) | 0 | |-------------|---------------------------------|---------------------------------|-------------------------------|-------|--------------------------------|-------------------------------|--------|--------------------------------| | Bit Symbol | P97F | P96F | P95F | 7(-// | P93F | P92F | | P90F | | Read/Write | | W | _ | ( - | \ | N( | _ | W | | After reset | 0 | 0 | 0 | - | 0 | | - | 0 | | Function | Port<br>0: disable<br>1: enable | Port<br>0: disable<br>1: enable | 0: port<br>1: SCLK1<br>output | | 0: port<br>1: TXD1 out-<br>put | 0: port<br>1: SCLK0<br>output | | 0: port<br>1: TXD0 out-<br>put | | P9xF | P9xC | P97<br>function | P96<br>function | P95<br>function | P94<br>function | P93<br>function | P92<br>function | P91<br>function | P90<br>function | |------|------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | 0 | 0 | XT2 | XT1 | input port | input port | input port | input port | input port | input port | | 0 | 1 | reserved | reserved | output port | output port | output port | output port | output port | output port | | 1 | 0 | input port | input port | reserved | reserved | reserved | reserved | reserved | reserved | | 1 | 1 | output port | output port | SCLK1 | reserved | TXD1 | SCLK0 | reserved | TXD0 | Note 1: <P9xF>/<P9xC> is bit X of each register P9FC/P9CR. Note 2: When setting TXD pin to open-drain output, write "1" to bit3 of ODE register (for TXD0 pin), or bit4 (for TXD1 pin). P91/RXD0 and P94/RXD1 pin does not have a register which changes Port/Function. For example, when it is also used as an input port, the input signal is inputted to SIO as serial receiving data. Note 3: Low frequency oscillation circuit To connect a low frequency resonator to port 96 and 97, it is necessary to set a following procedure to reduce the consumption power supply. (Case of resonator connection) P9CR<P96C, P97C> = "11", P9<P96:97> = "00" (Case of external clock input) P9CR<P96C, P97C> = "11", P9<P96:97> = "10" Page 79 2007-12-03 # 4.11 Port A (PA0 to PA3) Port A is an 4-bit general-purpose I/O port. Reset operation initializes to input port. All bits of output latch register PA are set to "1". There are the following functions in addition to an I/O port. This function enable each function by writing "1" to applicable bit of port A function register PAFC. - •The I/O function of 16-bit timer 2 (TB2IN0,TB2IN1,TB2OUT0,TB2OUT1) - •The input function of external interrupt (INT1, INT2) Reset operation initializes, PACR and PAFC to "0", all bits are set to input port. Reset Direction control (on bit basis) PACR write Function control (on bit basis) PAFC write PA0 (TB2IN0/INT1) PA1 (TB2IN1/INT2) Output latch PA write SB PA read TB2IN0, INT1◀ TB2IN1, INT2 Internal data Reset Direction control (on bit basis) PACR write Function control (on bit basis) PAFC write PA2 (TB2OUT0) PA3 (TB2OUT1) Output latch A S PA write Timer F/F OUT TB02UT0: TMRB2 TB02UT1: TMRB2 Selecto Figure 4-20 Port A PA read Page 80 2007-12-03 ## Port A Register PA (0028H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|---|--------------|------------------|-------------------|-------------------| | Bit symbol | - | - | - | - | PA3 | PA2 | PA1 | PA0 | | Read/Write | - | - | - | - | | R | W | | | After reset | - | Ì | Ī | Ì | Data from ex | ternal port (Out | out latch registe | r is set to "1".) | ## Port A Control Register (Read-modify-write instructions are prohibited.) PACR (002AH) | | 7 | 6 | 5 | 4 | 3 2 1 0 | | |-------------|---|---|---|---|---------------------|---| | Bit symbol | - | - | _ | - | PA3C PA2C PA1C PA0C | ; | | Read/Write | - | _ | 1 | ı | W | | | After reset | - | _ | - | - | 0 0 0 | | | Function | - | - | - | - | 0: Input 1: Output | | ### Port A Function Register (Read-modify-write instructions are prohibited.) PAFC (002BH) | | 7 | 6 | 5 | 4 | 3 | 2 | (//1)) | 0 | |-------------|---|---|-----|-------|-----------------------|----------------------|-------------------------------|-------------------------------| | Bit symbol | - | - | - | 7(-// | PA3F | PA2F | PA1F | PA0F | | Read/Write | _ | - | - / | (-) | | | N | | | After reset | _ | - | - ( | - | 0 | | 0 | 0 | | Function | - | - | | \\\\\ | 0: port<br>1: TB2OUT1 | 0:port<br>1: TB2OUT0 | 0: port<br>1: TB2IN1,<br>INT2 | 0: port<br>1: TB2IN0,<br>INT1 | | PAxC | PAxF | PA3<br>function | PA2<br>function | PA1<br>function | PA0<br>function | |------|------|-----------------|-----------------|-----------------|-----------------| | 0 | 0 | input port | input port | ) input port | input port | | 0 | 1 | output port | output port | output port | output port | | 1 | 0 | reserved | reserved | TB2IN1/ INT2 | TB2IN0/INT1 | | 1 | 1 | TB2OUT1 | TB2OUT0 | reserved | reserved | Note: <PAxF>/<PAxC> is bit X of each register PAFC/PACR. **TMP91CW60** # 4.12 Port B (PB0 to PB3) Port B is an 4-bit general-purpose I/O port. Reset operation initializes to input port. All bits of output latch register PB are set to "1". There are the following functions in addition to an I/O port. This function enable each function by writing "1" to applicable bit of port B function register PBFC. - •The I/O function of 16-bit timer 4 (TB4IN0,TB4IN1,TB4OUT0,TB4OUT1) - •The input function of external interrupt (INT9, INT10) - •The I/O function of serial bus interface 1 (SDA1, SCL1) Reset operation initializes, PBCR and PBFC to "0", all bits are set to input port Figure 4-21 Port B0 and B1 Page 82 2007-12-03 Page 83 2007-12-03 #### Port B Register PB (002CH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|---|--------------|------------------|-------------------|-------------------| | Bit symbol | - | - | - | - | PB3 | PB2 | PB1 | PB0 | | Read/Write | - | - | - | - | | R | W | | | After reset | - | Ì | Ī | Ì | Data from ex | ternal port (Out | out latch registe | r is set to "1".) | ## Port B Control Register (Read-modify-write instructions are prohibited.) PBCR (002EH) | | 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | |-------------|---|---|---|---|-----------|-----------|------| | Bit symbol | - | - | - | - | PB3C PB2C | PB1C | PB0C | | Read/Write | - | - | - | - | | N | | | After reset | - | - | - | - | 0 0 | 0 | 0 | | Function | - | - | - | - | 0: Input | 1: Output | | # Port B Function Register (Read-modify-write instructions are prohibited.) PBFC (002FH) | | 7 | 6 | 5 | 4 | 3 | 2 | \(\/1)) | 0 | |-------------|---|---|-----|----------|------|------|---------|------| | Bit symbol | - | - | - | 7(-// | PB3F | PB2F | PB2F | PB0F | | Read/Write | - | - | | (-/- | | | N | | | After reset | - | - | - ( | <u> </u> | 0 | | 0 | 0 | #### Port B Function Register 2 (Read-modify-write instructions are prohibited.) PBFC2 (002DH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|-----|-------|------|---|---|-------|-------| | Bit symbol | - | - \ | | _ | | - | PB1F2 | PB0F2 | | Read/Write | - | | ) | - | 1 | - | ١ | ٧ | | After reset | _ | (-( | ) ) – | ~ // | _ | _ | 0 | 0 | | PBxC | PBxF | PBxF2 | PB3<br>function | PB2 function | PB1<br>function | PB0<br>function | |------|------------------------------|-------|-----------------|--------------|-----------------|-----------------| | 0 | 0 | 0 | input port | input port | input port | input port | | 1 | 0 | 0 | output port | output port | output port | output port | | 0 | $\langle 1 \rangle$ | 0 | reserved | reserved | TB4IN1/INT10 | TB4IN0/INT9 | | 1 | 7 | 19 | TB4OUT1 | TB4OUT0 | reserved | reserved | | 0 | 9 | (( | reserved | reserved | reserved | reserved | | _1 | ( 0 ) | 1 | reserved | reserved | SCL1 | SDA1 | | 0 | $\left( \frac{1}{2} \right)$ | 1 | reserved | reserved | reserved | reserved | | | 1 | 1(( | reserved | reserved | reserved | reserved | Note: <PBxF>/<PBxC> is bit X of each register PBFC/PBCR. Page 84 2007-12-03 TMP91CW60 # 4.13 Port Z (PZ0 to PZ3) TOSHIBA Port Z is a 4-bit general-purpose I/O port (however PZ0 and PZ1 are only output port). Each bit can be set individually for input or output using the control register PZCR and function register PZFC. Reset operation initializes all bits of output latch PZ to "1", and the control register PZCR and function register PZFC to "0". And PZ0 and PZ1 output "High", and sets PZ2 and PZ3 to input port with pull-up resister. In addition to functioning as a general-purpose I/O port, port Z can also function as the output for the CPU's control/status signal. If PZ0 is defined as $\overline{RD}$ signal output mode ( $\langle PZ0F \rangle =$ "1") and the output latch register $\langle PZ0 \rangle$ is cleared to "0", $\overline{RD}$ strobe of PZ0 is outputted (for pseudo static RAM) even when accessing internal address. If <PZ0 > remains "1", RD strobe signal is output only when external address area is accessed. Figure 4-23 Port Z0 and Z1 Page 85 2007-12-03 Figure 4-24 Port Z2 and Z3 Page 86 2007-12-03 #### Port Z Register PZ (007DH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|---|----------------------------|--------------------------------------------------------------|--------|--------| | Bit symbol | - | - | _ | - | PZ3 | PZ2 | PZ1 | PZ0 | | Read/Write | - | - | - | - | R/W | | | | | After reset | 1 | 1 | 1 | ı | (Output latch | external port<br>register is set<br>'1".) | 1 | 1 | | Function | | | - | | Pull-up re<br>1 (Output la | tch register):<br>sistor OFF<br>tch register):<br>esistor ON | output | t mode | ## Port Z Control Register (Read-modify-write instructions are prohibited.) PZCR (007EH) | | 7 | 6 | 5 | 4 3 2 1 0 | |-------------|---|---|---|-------------------------------------------| | Bit symbol | _ | - | - | - PZ3C PZ2C | | Read/Write | - | - | - | - ( ) \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | After reset | - | 1 | ı | - 0 0 - | | Function | | | - | 0:Input 1:Output | #### Port Z Function Register (Read-modify-write instructions are prohibited.) PZFC (007FH) | | 7 | 6 | 5 | 4 | 3 | | 1 | 0 | |-------------|---|-----|--------|--------|-------------------|-------------------|------------------|------------------| | Bit symbol | - | ı | 4/ | > - // | PZ3F | PZ2F | PZ1F | PZ0F | | Read/Write | - | - / | | - | | \ | N | | | After reset | _ | - ( | ( )-) | - | 0 | 0 | 0 | 0 | | Function | - | | )<br>( | - | 0: port<br>1:R/ W | 0: port<br>1: HWR | 0: port<br>1: WR | 0: port<br>1: RD | | | | | $I/I/\Lambda$ | | | | |-----------|-------|-----|-----------------|-----------------|---------------------------------------------|----------------------------------------------| | PZxF | PZxC | PZx | PZ3<br>function | PZ2<br>function | PZ1 function | PZ0<br>function | | 0 | 0 < | 0/- | input port | input port | Output "0". | Output "0". | | 0 | 0 | 1 | input port | input port | Output "1". | Output "1". | | 0 | 1 | 0 | output port | output port | Output "0". | Output "0". | | 0 | <1/>/ | 1 | output port | output port | Output "1". | Output "1". | | 1 | 0 | | R/W | reserved | WR is output only during external accesses. | Always output RD.(Correspond to pseudo SRAM) | | <b>\1</b> | | 1 | R/W | reserved | WR is output only during external accesses. | RD is output only during external accesses. | | 1 | ) 1 | 0 | reserved | HWR | WR is output only during external accesses. | Always output RD.(Correspond to pseudo SRAM) | | 1 | 1 | 1 | reserved | HWR | WR is output only during external accesses. | RD is output only during external accesses. | Note 1: <PZxF>/<PZxC> is bit X of each register PZFC/PZCR. Note 2: When port Z is used as input mode, PZ register controls internal pull-up resistor. Read-modify-write instruction is prohibited in input mode or I/O mode. Setting the internal pull-up resistor may be depended on the states of the input pin. Page 87 2007-12-03 # 4.14 Open-drain Control P30,P31,P41,P90,P93,PB0,PB1 can perform selection of an open-drain output per bit. Reset operation initializes all bits of the control register ODE to "0" and sets to CMOS output. #### Open-drain Control Register ODE (003FH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|-------|-------|-------|-----------------------------------|-----------|-------|-------| | Bit symbol | _ | ODEB1 | ODEB0 | ODE93 | ODE90 | ODE41 | ODE31 | ODE30 | | Read/Write | _ | | | | R/W | | | | | After reset | - | 0 | 0 | 0 | 0 | ( ( 0 ) ) | 0 | 0 | | Function | | | | | 0: CMOS outpu<br>:Open drain outp | | | | Page 88 2007-12-03 TMP91CW60 # 5. Chip Select/Wait Controller On the TMP91CW60, four user specifiable address areas (CS0 to CS3) can be set. The data bus width and the number of waits can be set independently for each address area (CS0 to CS3 and others). The pins $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ (which can also function as port pins P40 to P43) are the respective output pins for the areas CS0 to CS3. When the CPU specifies an address in one of these areas, the corresponding $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ pin outputs the chip select signal for the specified address area (in ROM or SRAM). However, in order for the chip select signal to be output, the port 6 function register P4FC,P4FC2 must be set. The areas CS0 to CS3 are defined by the values in the memory start address registers MSAR0 to MSAR3 and the memory address mask registers MAMR0 to MAMR3. The chip select/wait control registers B0CS to B3CS and BEXCS should be used to specify the master enable/disable status the data bus width and the number of waits for each address area. The input pin controlling these states is the bus wait request pin (WAIT) # 5.1 Specifying an Address Area The CS0 to CS3 address areas are specified using the start address registers (MSAR0 to MSAR3) and memory address mask registers (MAMR0 to MAMR3). At each bus cycle, a compare operation is performed to determine if the address on the specified a location in the CS0 to CS3 area. If the result of the comparison is a match, this indicates an access to the corresponding CS area. In this case, the $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ pin outputs the chip select signal and the bus cycle operates in accordance with the settings in chip select/wait control registers B0CS to B3CS. (See" 5.2 Chip Select/Wait Control Registers ".) # 5.1.1 Memory start address registers The memory start address registers MSAR0 to MSAR3 set the start addresses for the CS0 to CS3 areas. Set the upper 8 bits (A23 to A16) of the start address in <S23:16>. The lower 16 bits of the start address (A15 to A0) are permanently set to 0. Accordingly, the start address can only be set in 64-Kbyte increments, starting from 000000H. Figure 5-1 shows the relationship between the start address and the start address register value. #### Memory Start Address Registers (for areas CS0 to CS3) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|-------------|-----|-----------|----------|----------------|-----------------|----------|-----|-----| | MSAR0 | Bit symbol | S23 | S22 | S21 | S20 | S19 | S18 | S17 | S16 | | (00C8H) | Read/Write | | $\bigcap$ | | R | /W | | | | | MSAR1 | After reset | 1 < | 1 1 | 1 | 1 | 1 | 1 | 1 | 1 | | (00CAH) | | > ( | | | | | | | | | MSAR2 | ( | | )) | Dete | rmine A23 to A | A16 of start ad | dress | | | | (00CCH) | _Function | | | (Set sta | rt addresses f | or areas CS0 | to CS3.) | | | | MSAR3<br>(00CEH) | | | | | | | | | | Page 89 2007-12-03 Figure 5-1 Relationship between Start Address and Start Address Register Value ## 5.1.2 Memory address mask registers Memory address mask registers MAMR0 to MAMR3 are used to set the size of the CS0 to CS3 areas by specifying a mask for each bit of the start address set in memory start address registers MAMR0 to MAMR3. The compare operation used to determine if an address is in the CS0 to CS3 areas is only performed for bus address bits corresponding to bits set to "0" in these registers. Also, the address bits that can be masked by MAMR0 to MAMR3 differ between CS0 to CS3 areas. Accordingly, the size that can be each area is different. #### Memory Address Mask Register (for CS0 area) MAMR0 (00C9H) | | 7 | 6 | 5 | 4 | /3/ | 2 | 1 | 0 | |-------------|-----|-----|---------------|------------|-----------------|-------------|-----------|----| | Bit symbol | V20 | V19 | V18 | V17 | V16 | V15 | V14 to V9 | V8 | | Read/Write | ( | | | R | /W | | | | | After reset | 1 | | 1 | 14 | 1 | 1 | 1 | 1 | | Function | (0) | | Set size of 0 | CS0 area 0 | : Used for addr | ess compare | | · | Note: Range of possible settings for CS0 area size: 256 bytes to 2 Mbytes. #### Memory Address Mask Register (CS1) MAMR1 (00CBH) | $\wedge \wedge$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|-----|---------------|-------------|---------------|-------------|-----------|----| | Bit symbol | V21 | V20 | V19 | V18 | V17 | V16 | V15 to V9 | V8 | | Read/Write | | R/W | | | | | | | | After reset | 1 | //\ | 1 | 1 | 1 | 1 | 1 | 1 | | Function | \ (C | | Set size of 0 | CS1 area 0: | Used for addr | ess compare | | | Note: Range of possible settings for CS1 area size: 256 bytes to 4 Mbytes. #### Memory Address Mask Register (CS2, CS3) MAMR2 (00CDH) MAMR3 (00CFH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|-----|-----|---------------|------------|-----------------|-------------|-----|-----|--| | Bit symbol | V22 | V21 | V20 | V19 | V18 | V17 | V16 | V15 | | | Read/Write | | R/W | | | | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | Function | | | Set size of ( | CS1 area 0 | : Used for addr | ess compare | | | | Note: Range of possible settings for CS2 and CS3 area sizes: 32 Kbytes to 8 Mbytes. Page 90 2007-12-03 #### 5.1.3 Setting memory start addresses and address areas Figure 5-2 shows an example of specifying a 64-Kbyte address area starting from 010000H using the CS0 areas. Set "01H" in memory start address register MSAR0<S23:16> (Corresponding to the upper 8 bits of the start address). Next, calculate the difference between the start address and the anticipated end address (01FFFFH). Bits 20 to 8 of the result correspond to the mask value to be set for the CS0 area. Setting this value in memory address mask register MAMR0<V20:8> sets the area size. This example sets "07H" in MAMR0 to specify a 64-Kbyte area. Figure 5-2 Example Showing How to Set the CS0 Area After a reset, MSAR0 to MSAR3 and MAMR0 to MAMR3 are set to "FFH". B0CS<B0E>, B1CS<B1E> and B3CS<B3E> are reset to "0". This disables the CS0, CS1 and CS3 areas. However, as B2CS<B2M> to "0" and B2CS<B2E> to "1", CS2 is enabled "002000 to FDFFFF" in TMP91CW60. Also, the bus width and number of waits specified in BEXCS are used for accessing addresses outside the specified CS0 to CS3 area. Page 91 2007-12-03 ### 5.1.4 Address area size specification Table 5-1 shows the relationship between CS area and area size. " $\Delta$ " indicates areas that cannot be set by memory start address register and address mask register combinations. When setting an area size using a combination indicated by " $\Delta$ ", set the start address mask register in the desired steps starting from 000000H. If the CS2 area is set to 16 Mbytes or if two or more areas overlap, the smaller CS area number has the higher priority. #### 5.1.4.1 To set the area size for CS0 to 128 Kbytes: Example: Valid start addresses 000000H \$\sqrt{(128 \text{ Kbytes})}\$ 020000H \$\sqrt{(128 \text{ Kbytes})}\$ 040000H \$\sqrt{(128 \text{ Kbytes})}\$ 060000H : Example: Invalid start addresses 000000H ↓ (64 Kbytes) 010000H ↓ (128 Kbytes) 030000H ↓ (128 Kbytes) 050000H This is not an integer multiple of the desired area size setting. Hence, none of these addresses can be set as the start address. Any of these addresses may be set as the start address Table 5-1 Valid Area Sizes for Each CS Area | | \ (I | | | | | | Size (Bytes | ) | | | | | |------|------|-------------|-----|------|------|-------|-------------|-------|-----|-----|-----|-----| | | | 256 | 512 | 32 K | 64 K | 128 K | 256 K | 512 K | 1 M | 2 M | 4 M | 8 M | | | CS0 | $\supset$ 0 | 0 | | / o | Δ | Δ | Δ | Δ | Δ | | | | area | CS1 | О | O | | О | Δ | Δ | Δ | Δ | Δ | Δ | | | CS | CS2 | | | О | О | Δ | Δ | Δ | Δ | Δ | Δ | Δ | | | CS3 | · | · | О | О | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Note: "\Delta" indicates areas that cannot be set by memory start address register and address mask register combinations. Page 92 2007-12-03 # 5.2 Chip Select/Wait Control Registers The master enable/disable, chip select output waveform, data bus width and number of wait states for each address area (CS0 to CS3 and others) are set in their respective chip select/wait control registers, B0CS to B3CS and BEXCS. #### Chip Select/Wait Control Registers | | | 7 | 6 | 5 | 4 | 3 | ( 2 ) | 1 | 0 | |----------------------------------|------------------------------|-------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------| | | Bit symbol | B0E | - | B0OM1 | B0OM0 | B0BUS | B0W2 | B0W1 | B0W0 | | D000 | Read/Write | W | - | | | | w) > | | | | B0CS<br>(00C0H) | After reset | 0 | - | 0 | 0 | Q | ) o | 0 | 0 | | RMW instructions are prohibited. | Function | 0: Disable<br>1: Enable | | Chip select output waveform selection 00: For ROM/SRAM 01: Don't care 10: Don't care 11: Don't care | | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | Number of waits 000: 2 WAIT 001: 1 WAIT 010: 1 WAIT+N 011: 0 WAIT 111: 8 WAIT | | | | | Bit symbol | B1E | - | B1OM1 | B1OM0 | > B1BUS | B1W2 | B1W1 | B1W0 | | B1CS | Read/Write | W | - | < | 1( // | ١ | v(C) | | | | (00C1H) | After reset | 0 | - | 0 | 0 | 0 | | 0 | 0 | | RMW instructions are prohibited. | | 0: Disable<br>1: Enable | ( | Chip select output waveform<br>selection<br>00: For ROM/SRAM<br>01: Don't care<br>10: Don't care<br>11: Don't care | | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | Number of waits -000: 2 WAIT 100: Reserved 001: 1 WAIT 101: 3 WAIT 010: 1 WAIT+N 110: 4 WAIT 011: 0 WAIT 111: 8 WAIT | | | | | Bit symbol | B2E | B2M | B2OM1 | B2OM0 | B2BUS | B2W2 | B2W1 | B2W0 | | B2CS | Read/Write | W | (( | | | W | | | | | (00C2H) | After reset | 1 | 0 | <i>//</i> 0 | 0 | 0 | 0 | 0 | 0 | | RMW instructions are prohibited. | Function | 0: Disable<br>1: Enable | CS2 area<br>selection<br>0: 16-Mbyte<br>area<br>1: CS area | selection<br>00: For ROM/S | 00: For ROM/SRAM<br>01: Don't care<br>10: Don't care | | Number of waits 000: 2 WAIT | | AIT<br>AIT | | | Bit symbol | B3E | · - | B3OM1 | B3OM0 | B3BUS | B3W2 | B3W1 | B3W0 | | B3CS | Read/Write | > w | - | | | ١ | V | | | | (00C3H) | After reset < | 9 | - ^ | 0 | 0 | 0 | 0 | 0 | 0 | | RMW instructions are prohibited. | RMW instructions are prohib- | | | Chip select ou<br>selection<br>00: For ROM/S<br>01: Don't care<br>10: Don't care<br>11: Don't care | | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | Number of wai<br>000: 2 WAIT<br>001: 1 WAIT<br>010: 1 WAIT+N<br>011: 0 WAIT | 100: Res | AIT<br>AIT | #### Master enable bit | BnE | 0 | Disable | |----------------|---|---------| | (n = 0 to 3) | 1 | Enable | #### Chip select output waveform selection | | 00 | for ROM/SRAM | |----------------|----|--------------| | BnOM1:0 | 01 | | | (n = 0 to 3) | 10 | Don't care | | | 11 | | #### CS2 area selection | R2M | 0 | 16-Mbyte area | |-------|---|------------------------| | DZIVI | 1 | Specified address area | #### Data bus width selection | BnBUS | 0 | 16-bit data bus | |----------------|---|-----------------| | (n = 0 to EX) | 1 | 8-bit data bus | Page 93 2007-12-03 BEXCS (00C7H) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|---|---|---|---|----------------------------------------------|-----------------------------------------------------------------------------|----------------------|------------| | Bit sym | bol | - | - | - | - | BEXBUS | BEXW2 | BEXW1 | BEXW0 | | Read/W | /rite | - | - | - | - | | \ \ \ | N | | | After re | set | - | ı | ı | - | 0 | 0 | 0 | 0 | | Functio | n | | | | | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | Number of wai<br>000: 2 WAIT<br>001: 1 WAIT<br>010: 1 WAIT+1<br>011: 0 WAIT | 100: Res<br>101: 3 W | AIT<br>AIT | Number of address area waits | BnW2:0<br>(n = 0 to EX) | See" 5.2.3 Wait control " | |-------------------------|---------------------------| |-------------------------|---------------------------| #### 5.2.1 Master enable bits Bit7 (<B0E>, <B1E>, <B2E> or <B3E>) of a chip select/wait control register is the master bit which is used to enable or disable settings for the corresponding address area. Writing "1" to this bit enables the settings. Reset disables (Sets to "0") <B0E>, <B1E> and <B3E>, and enabled (Sets to "1") <B2E>. This enables area CS2 only. ### 5.2.2 Data bus width selection Bit3 (<B0BUS>, <B1BUS>, <B2BUS>, <B3BUS> or <BEXBUS>) of a chip select/wait control register specifies the width of the data bus. This bit should be set to "0" when memory is to be accessed using a 16-bit data bus and to "1" when an 8-bit data bus is to be used. This process of changing the data bus width according to the address being accessed is known as "Dynamic bus sizing". For details of this bus operation see Table 5-2. Page 94 2007-12-03 Table 5-2 Dynamic Bus Sizing | Operand Data | Operand Start | Memory Data | CPU Address | CPU | Data | |--------------|-------------------------|-------------|------------------------------|---------------------------------|---------------------------------------------------| | Bus Width | Address | Bus Width | CFO Address | D15 to D8 | D7 to D0 | | | 2n + 0 | 8 bits | 2n + 0 | xxxxx | b7 to b0 | | 8 bits | (Even number) | 16 bits | 2n + 0 | xxxxx | b7 to b0 | | 8 DIIS | 2n + 1 | 8 bits | 2n + 1 | xxxxx | b7 to b0 | | | (Odd number) | 16 bits | 2n + 1 | 67 to 60 | xxxxx | | | 2n + 0 | 8 bits | 2n + 0<br>2n + 1 | XXXXX | b7 to b0<br>b15 to b8 | | | (Even number) | 16 bits | 2n + 0 | b15 to b8 | b7 to b0 | | 16 bits | 16 bits 2n + 1 | 8 bits | 2n + 1<br>2n + 2 | xxxxx | b7 to b0<br>b15 to b8 | | | (Odd number) | 16 bits | 2n + 1<br>2n + 2 | b7 to b0 | xxxxx<br>b15 to b8 | | | 2n + 0<br>(Even number) | 8 bits | 2n+0<br>2n+1<br>2n+2<br>2n+3 | XXXXX<br>XXXXX<br>XXXXX | b7 to b0<br>b15 to b8<br>b23 to b16<br>b31 to b24 | | | | 16 bits | 2n + 0<br>2n + 2 | b15 to b8<br>b31 to b24 | b7 to b0<br>b23 to b16 | | 32 bits | 2n + 1<br>(Odd number) | 8 bits | 2n+1<br>2n+2<br>2n+3<br>2n+4 | XXXXX<br>XXXXX<br>XXXXX | b7 to b0<br>b15 to b8<br>b23 to b16<br>b31 to b24 | | | | 16 bits | 2n + 1<br>2n + 2<br>2n + 4 | b7 to b0<br>b23 to b16<br>xxxxx | xxxxx<br>b15 to b8<br>b31 to b24 | Note: "xxxxx" indicates that the input data from these bits are ignored during a read. During a write, indicates that the bus for these bits goes too high impedance; also, that the write strobe signal for the bus remains inactive. ## 5.2.3 Wait control Bits 0 to 2 (<B0W0:2>, <B1W0:2>, <B2W0:2>, <B3W0:2>, <BEXW0:2>) of a chip select/wait control register specify the number of waits that are to be inserted when the corresponding memory area is accessed. The following types of wait operation can be specified using these bits. Bit settings other than those listed in the table should not be made. A reset sets these bit to "000" (2 waits). Table 5-3 Wait Operation Settings | | | J 1 | |-------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <bxw2:0></bxw2:0> | Number of Waits | Wait Operation | | 000 | 2 waits | Inserts a wait of 2 states, irrespective of the WAIT pin state. | | 001 | 1 wait | Inserts a wait of 1 state, irrespective of the WAIT pin state. | | 010 | (1 + N) waits | Samples the state of the WAIT pin after inserting a wait of one state. If the WAIT pin is low, the waits continue and the bus cycle is extended until the pin goes high. | | 011 | 0 waits | Ends the bus cycle without a wait, regardless of the WAIT pin state. | | 100 | Reserved | Invalid setting | | 101 | 3 waits | Inserts a wait of 3 state, irrespective of the WAIT pin state. | | 110 | 4 waits | Inserts a wait of 4 state, irrespective of the WAIT pin state. | | 111 | 8 waits | Inserts a wait of 8 state, irrespective of the WAIT pin state. | Page 95 2007-12-03 **TMP91CW60** #### 5.2.4 Bus width and wait control for an area other than CS0 to CS3 The chip select/wait control register BEXCS controls the bus width and number of waits when memory locations which are not in one of the four user-specified address areas (CS0 to CS3) are accessed. The BEXCS register settings are always enabled for areas other than CS0 to CS3. ## 5.2.5 Selecting 16-Mbyte area/specified address area Setting B2CS<B2M> (Bit6 of the chip select/wait control register for CS2) to "0" designates the 16-Mbyte area "002000 to FDFFFF" as the CS2 area. Setting B2CS<B2M> to "1" designates the address area specified by the start address register MSAR2 and the address mask register MAMR2 as CS2 (e.g., if B2CS<B2M> = 1, CS2 is specified in the same manner as CS0, CS1 and CS3 are). A reset clears this bit to "0", specifying CS2 as a 16-Mbyte address area ## 5.2.6 Procedure for setting chip select/wait control When using the chip select/wait control function, set the registers in the following order: - 1. Set the memory start address registers MSAR0 to MSAR3. Set the start addresses for CS0 to CS3. - 2. Set the memory address mask registers MAMR0 to MAMR3. Set the sizes of CS0 to CS3. - 3. Set the chip select/wait control registers B0CS to B3CS. Set the chip select output waveform, data bus width, number of waits and master enable/disable status for $\overline{CS0}$ to $\overline{CS3}$ . The CS0 to CS3 pins can also function as pins P40 to P43. To output a chip select signal using one of these pins, set the corresponding bit in the port 6 function register P4FC/P4FC2 to "1". If a CS0 to CS3 address is specified which is actually an internal I/O and RAM area address, the CPU accesses the internal address area and no chip select signal is output on any of the CS0 to CS3 pins. Example :In this example CS0 is set to the 64-Kbyte area 010000H to 01FFFFH. The bus width is set to 16 bits and the number of waits is set to 0. LD (MSAR0), 01H ; Start address: 010000H LD (MAMR0), 07H ; Address area: 64 Kbytes LD (B0CS), 83H ; ROM/SRAM, 16-bit data bus, 0 waits, CS0 area settings enabled Page 96 2007-12-03 # 5.3 Connecting External Memory Figure 5-3 shows an example of how to connect external memory to TMP91CW60. In this example the ROM is connected using a 16-bit bus. The RAM and I/O are connected using an 8-bit bus. Figure 5-3 Example of External Memory Connection (ROM uses 16-bit bus, RAM and I/O use 8-bit bus. A reset clears all bits of the port 4 control register P4CR and the port 4 function register P4FC/P4FC2 to "0" and disables output of the CS signal. To output the CS signal, the appropriate bit must be set to "1". Page 97 2007-12-03 TOSHIBA TMP91CW60 # 6. 8-Bit Timers (TMRA) The TMP91CW60 features 6 channels (TMRA0 to TMRA5) built-in 8-bit timers. These timers are paired into 3 modules: TMRA01, TMRA23 and TMRA45. Each module consists of 2 channels and can operate in any of the following 4 operating modes. - 8-bit interval timer mode - 16-bit interval timer mode - 8-bit programmable square wave pulse generation output mode (PPG Variable duty cycle with variable period) - 8-bit pulse width modulation output mode (PWM Variable duty cycle with constant period) Figure 6-1 to Figure 6-3 show block diagrams for TMRA01, TMRA23 and TMRA45. Each channel consists of an 8-bit up counter, an 8-bit comparator and an 8-bit timer register. In addition, a timer flip-flop and a prescaler are provided for each pair of channels. The operation mode and timer flip-flops are controlled by 5-byte registers SFRs (Special function registers). Each of the three modules (TMRA01, TMRA23 and TMRA45) can be operated independently. All modules operate in the same manner; hence only the operation of TMRA01 is explained here. Table 6-1 Registers and Pins for Each Module | Specification | Module | TMRA01 | TMRA23 | TMRA45 | |---------------|----------------------------------|----------------------------------------|----------------------------------------|----------------------------------------| | External pin | Input pin for external clock | TA0IN<br>(Shared with P70) | None | TA4IN<br>(Shared with P73) | | External pin | Output pin for timer flip-flop | TA1OUT<br>(Shared with P71) | TA3OUT<br>(Shared with P72) | TA5OUT<br>(Shared with P74) | | SFR (Address) | Timer run register | TA01RUN<br>(0100H) | TA23RUN<br>(0108H) | TA45RUN<br>(0110H) | | | Timer register | TAOREG<br>(0102H)<br>TA1REG<br>(0103H) | TA2REG<br>(010AH)<br>TA3REG<br>(010BH) | TA4REG<br>(0112H)<br>TA5REG<br>(0113H) | | | Timer mode register | TA01MOD<br>(0104H) | TA23MOD<br>(010CH) | TA45MOD<br>(0114H) | | | Timer flip-flop control register | TA1FFCR<br>(0105H) | TA3FFCR<br>(010DH) | TA5FFCR<br>(0115H) | Page 98 2007-12-03 # 6.1 Block Diagrams Figure 6-1 TMRA01 Block Diagram Page 99 2007-12-03 Page 100 2007-12-03 Page 101 2007-12-03 TOSHIBA TMP91CW60 ## 6.2 Operation of Each Circuit #### 6.2.1 Prescalers A 9-bit prescaler generates the input clock to TMRA01. The " $\phi$ T0" as the input clock to prescaler is a clock divided by 4 which is selected using the prescaler clock selection register SYSCR0<PRCK1>. The prescaler's operation can be controlled using TA01RUN<TA01PRUN> in the timer control register. Setting <TA01PRUN> to "1" starts the count; setting <TA01PRUN> to "0" clears the prescaler to "0" and stops operation. Table 6-2 shows the various prescaler output clock resolutions. Table 6-2 Prescaler Output Clock Resolution @ fc = 20 MHz, fs = 32.768 kHz | System Clock | Gear Value | Prescaler Clock | Prescaler Clock Prescaler Output Clock Resolut | | | | |-------------------------------------|----------------------------|-------------------------------------|------------------------------------------------|------------------------------|--------------------------------|---------------------------------| | Selection<br>SYSCR1 <sysck></sysck> | SYSCR1 <gear2:0></gear2:0> | Selection<br>SYSCR0 <prck1></prck1> | φT1<br>(1/2) | φT4<br>(1/8) | φT16<br>(1/32) | φT256<br>(1/512) | | 1 (fs) | xxx | | 2 <sup>3</sup> /fs (244 μs) | 2 <sup>5</sup> /fs (977 μs) | 2 <sup>7</sup> /fs (3.9 ms) | 2 <sup>11</sup> /fs (62.5 ms) | | | 000 (fc) | | 2 <sup>3</sup> /fc (0.4 μs) | 2 <sup>5</sup> /fc (1.6 μs) | 2 <sup>7</sup> /fc(6.4 μs) | 2 <sup>11</sup> /fc (102.4 μs) | | | 001 (fc/2) | 0 (1/1)<br>f <sub>EPH</sub> | 2 <sup>4</sup> /fc (0.8 μs) | 2 <sup>6</sup> /fc (3.2 μs) | 2 <sup>8</sup> /fc (12.8 μs) | 2 <sup>12</sup> /fc (204.8 μs) | | | 010 (fc/4) | | 2 <sup>5</sup> /fc (1.6 μs) | 2 <sup>7</sup> /fc (6.4 μs) | 2 <sup>9</sup> /fc (25.6 μs) | 2 <sup>13</sup> /fc (409.6 μs) | | 0 (fc) | 011 (fc/8) | | 2 <sup>6</sup> /fc (3.2 μs) | 2 <sup>8</sup> /fc (12.8 μs) | 2 <sup>10</sup> /fc (51.2 μs) | 2 <sup>14</sup> /fc (819.2 μs) | | | 100 (fc/16) | | 2 <sup>7</sup> /fc (6.4 μs) | 2 <sup>9</sup> /fc (25.6 μs) | 2 <sup>11</sup> /fc (102.4 μs) | 2 <sup>15</sup> /fc (1638.4 μs) | | | XXX | 1 (1/16)<br>fc/16 CLOCK | 2 <sup>7</sup> /fc (6.4 μs) | 2 <sup>9</sup> /fc (25.6 μs) | 2 <sup>11</sup> /fc (102.4 μs) | 2 <sup>15</sup> /fc (1638.4 μs) | Note: xxx: Don't care # 6.2.2 Up counters (UC0 and UC1) These are 8-bit binary counters which count up the input clock pulses for the clock specified by TA01MOD. The input clock for UC0 is selectable and can be either the external clock input via the TA0IN pin or one of the three internal clocks $\phi$ T1, $\phi$ T4, or $\phi$ T16. The clock setting is specified by the value set in TA01MQD<TA01CLK1:0>. The input clock for UC1 depends on the operation mode. In 16-bit timer mode, the overflow output from UC0 is used as the input clock. In any mode other than 16-bit timer mode, the input clock is selectable and can either be one of the internal clocks $\phi$ T1, $\phi$ T16 or $\phi$ T256, or the comparator output (The match detection signal) from TMRA0. For each interval timer the timer operation control register bits TA01RUN<TA0RUN> and TA01RUN<TA1RUN> can be used to stop and clear the up counters and to control their count. A reset clears both up counters, stopping the timers. Page 102 2007-12-03 ## 6.2.3 Timer registers (TA0REG and TA1REG) These are 8-bit registers which can be used to set a time interval. When the value set in the timer register TA0REG or TA1REG matches the value in the corresponding up counter, the comparator match detect signal goes active. If the value set in the timer register is 00H, the signal goes active when the up counter overflows. The TAOREG are double buffer structure, each of which makes a pair with register buffer. The setting of the bit TA01RUN<TA0RDE> determines whether TA0REG's double buffer structure is enabled or disabled. It is disabled if <TA0RDE> = "0" and enabled if <TA0RDE> = "1". When the double buffer is enabled, data is transferred from the register buffer to the timer register when a 2<sup>n</sup> overflow occurs in PWM mode, or at the start of the PPG cycle in PPG mode. Hence the double buffer cannot be used in timer mode. A reset initializes <TA0RDE> to "0", disabling the double buffer. To use the double buffer, write data to the timer register, set <TA0RDE> to "1", and write the following data to the register buffer. Figure 6-4 shows the configuration of TA0REG. Figure 6-4 Configuration of TA0REG Note: The same memory address is allocated to the timer register TA0REG and the register buffer 0. When <TA0RDE> = 0, the same value is written to the register buffer 0 and the timer register TA0REG; when <TA0RDE> = 1, only the register buffer 0 is written to. Page 103 2007-12-03 'OSHIBA TMP91CW60 ## 6.2.4 Comparator (CP0 and CP1) The comparator compares the value in an up counter with the value set in a timer register. If they match, the up counter is cleared to 0 and an interrupt signal (INTTA0 or INTTA1) is generated. If timer flip-flop inversion is enabled, the timer flip-flop is inverted at the same time. Note: If a value smaller than the up-counter value is written to the timer register while the timer is counting up, this will cause the timer to overflow and an interrupt cannot be generated at the expected time. (The value in the timer register can be changed without any problem if the new value is larger than the up-counter value.) In 16-bit interval timer mode, be sure to write to both TAOREG and TA1REG in this order (16 bits in total), The compare circuit will not function if only the lower 8 bits are set. ## 6.2.5 Timer flip-flop (TA1FF) The timer flip-flop (TA1FF) is a flip-flop inverted by the match detects signal (8-bit comparator output) of each interval timer. Whether inversion is enabled or disabled is determined by the setting of the bit TA1FFCR<TA1FFIE> in the timer flip-flop control register. A reset clears the value of TA1FF1 to "0". Writing "01" or "10" to TA1FFCR<TA1FFC1:0> sets TA1FF to 0 or 1. Writing "00" to these bits inverts the value of TA1FF (This is known as software inversion). The TA1FF signal is output via the TA1OUT pin (Concurrent with P71). When this pin is used as the timer output, the timer flip-flop should be set beforehand using the port 7 function registers P7CR, P7FC. The condition for TA1FF inversion varies with mode as shown below 8-bit interval timer mode UC0 matches TA0REG or UC1 matches TA1REG (Select either one of the two) 16-bit interval timer mode : UC0 matches TA0REG or UC1 matches TA1REG 8 bit PWM mode : UC0 matches TA0REG or a 2n overflow occurs 8 bit PPG mode : UC0 matches TA0REG or UC0 matches TA1REG Note: If an inversion by the match-detect signal and a setting change via the TMRA1 flip-flop control register occur simultaneously, the resultant operation varies depending on the situation, as shown below. - If an inversion by the match-detect signal and an inversion via the register occur simultaneously, the flip-flop will be inverted only once. - If an inversion by the match-detect signal and an attempt to set the flip-flop to 1 via the register occur simultaneously, the timer flip-flop will be set to 1. - If an inversion by the match-detect signal and an attempt to clear the flip-flop to 0 via the register occur simultaneously the flip-flop will be cleared to 1. Be sure to stop the timer before changing the flip-flop insertion setting. If the setting is changed while the timer is counting, proper operation cannot be obtained. Page 104 2007-12-03 ## 6.3 SFR #### TMRA01 Run Register TA01RUN (0100H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------------------------|---|---|---|------------------|---------------------------------|---------------------|---------------------| | Bit symbol | TA0RDE | - | - | - | I2TA01 | TA01PRUN | TA1RUN | TA0RUN | | Read/Write | R/W | - | - | - | | R | W | | | After Reset | 0 | - | - | - | 0 | | <i>)</i> 0 | 0 | | Function | Double<br>buffer | | | | IDLE2<br>0: Stop | TMRA01<br>prescaler | Up counter<br>(UC1) | Up counter<br>(UC0) | | Function | 0: Disable<br>1: Enable | | | | 1: Operate | 0: Stop and cl<br>1: Run (count | | | Count operation | TA01PRUN | 0 | Stop and clear | | |-----------------|---|----------------|--| | TA1RUN / TA0RUN | 1 | Run (Count up) | | TA0REG double buffer control | TAORDE ( | 0 | Disable | |----------|---|---------| | TAURDE | | Enable | Note: The values of bits 4 to 6 of TA01RUN are "1" when read. ## TMRA23 Run Register TA23RUN (0108H) | | 7 | 6 | 5 | 4 | 3 | 7 / 2 | 1 | 0 | |-------------|-------------------------|-----|----|---------------|-----------------------|---------------------------------|---------------------|---------------------| | Bit symbol | TA2RDE | - | | <b>&gt;</b> - | I2TA23 | TA23PRUN | TA3RUN | TA2RUN | | Read/Write | R/W | - | 47 | > - // | | R | /W | | | After Reset | 0 | - / | | - | 0 )) | 0 | 0 | 0 | | Function | Double<br>buffer | | | ^ | IDLE2 | TMRA23<br>prescaler | Up counter<br>(UC3) | Up counter<br>(UC2) | | Function | 0: Disable<br>1: Enable | | | | 0: Stop<br>1: Operate | 0: Stop and cl<br>1: Run (count | | | Count operation | | \ ' \ / / / | | |-----------------|-------------|----------------| | TA23PRUN | 0 | Stop and clear | | TA3RUN / TA2RUN | <b>─</b> 1 | Run (Count up) | TA2REG double buffer control | TA2RDE | 0 | Disable | |--------|---|---------| | | 1 | Enable | Note: The values of bits 4 to 6 of TA23RUN are "1" when read. #### TMRA45 Run Register TA45RUN (0110H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------------------------|------|-----|---|------------------|----------------------------------|---------------------|---------------------| | Bit symbol | TA4RDE | | > - | - | I2TA45 | TA45PRUN | TA5RUN | TA4RUN | | Read/Write | R/W | >(-) | - | - | | R | W | | | After Reset | 0 | )- | - | _ | 0 | 0 | 0 | 0 | | Function | Double<br>buffer | | | | IDLE2<br>0: Stop | TMRA45<br>prescaler | Up counter<br>(UC5) | Up counter<br>(UC4) | | 1 Unction | 0: Disable<br>1: Enable | | | | 1: Operate | 0: Stop and clo<br>1: Run (count | | | Count operation | TA45PRUN<br>TA5RUN / TA4RUN | 0 | Stop and clear | |-----------------------------|---|----------------| | | 1 | Run (Count up) | TA4REG double buffer control | TA4RDE | 0 | Disable | |--------|---|---------| | | 1 | Enable | Note: The values of bits 4 to 6 of TA45RUN are "1" when read. Page 105 2007-12-03 ## TMRA01 Mode Register TA01MOD (0104H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------------------------------------------------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------|-------|----------------------------------------------------------------------------|---------|-----------------------------------------------------------------------------|---------| | Bit symbol | TA01M1 | TA01M0 | PWM01 | PWM00 | TA1CLK1 | TA1CLK0 | TA0CLK1 | TA0CLK0 | | Read/Write | | | | R | /W | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Function | Operation mo<br>00: 8-bit timer<br>01: 16-bit time<br>10: 8-bit PPG<br>11: 8-bit PWM | mode<br>er mode<br>mode | PWM cycle<br>00: Reserved<br>01: 2 <sup>6</sup><br>10: 2 <sup>7</sup><br>11: 2 <sup>8</sup> | | Input clock for<br>00: TA0TRG<br>01: \phiT1<br>10: \phiT16<br>11: \phiT256 | TMRA1 | Input clock for<br>00: TAOIN pin<br>01: \phiT1<br>10: \phiT4<br>11: \phiT16 | | ## TMRA0 input clock selection | | 00 | TAOIN | | |-------------------------|----|-------|---| | <ta0clk1:0></ta0clk1:0> | 01 | φT1 | | | CIAOOLICI.02 | 10 | φТ4 | > | | | 11 | φT16 | | ## TMRA1 input clock selection | | _ | TA01MOD <ta01m1:0> ≠ 01</ta01m1:0> | TA01MOD <ta01m1:0> = 01</ta01m1:0> | |-------------------------|----|------------------------------------|------------------------------------------------| | | 00 | Comparator output from TMRA0 | | | <ta1clk1:0></ta1clk1:0> | 01 | φT1) | Overflow output from TMRA0 (16-bit timer mode) | | | 10 | φT16 | (10-bit timer mode) | | , | 11 | фТ256 | | ## PWM cycle selection | | 00 | Reserved | |-----------------------|-------|----------------------------------| | -DWM04:00: | )) 01 | 2 <sup>6</sup> × Clock source | | <pwm01:00></pwm01:00> | 10 | $2^7 \times \text{Clock source}$ | | | 11 | 2 <sup>8</sup> × Clock source | # TMRA01 operation mode selection | | | 1 1 1 | | |----|-----------------------|-------|-----------------------------------------| | | /// | 00 | 8-bit timers 2ch | | | <ta01m1:0></ta01m1:0> | 01 | 16-bit timer | | | CIAOTIVIT.0> | 10 | 8-bit PPG | | 11 | \ \ \ | 11 | 8-bit PWM (TMRA0) + 8-bit timer (TMRA1) | Page 106 2007-12-03 ## TMRA23 Mode Register TA23MOD (010CH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------------------------------------------------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------|-------|----------------------------------------------------------|---------|----------------------------------------------------------------------------|---------| | Bit symbol | TA23M1 | TA23M0 | PWM21 | PWM20 | TA3CLK1 | TA3CLK0 | TA2CLK1 | TA2CLK0 | | Read/Write | | | | R | /W | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Function | Operation mo<br>00: 8-bit timer<br>01: 16-bit time<br>10: 8-bit PPG<br>11: 8-bit PWM | mode<br>er mode<br>mode | PWM cycle<br>00: Reserved<br>01: 2 <sup>6</sup><br>10: 2 <sup>7</sup><br>11: 2 <sup>8</sup> | | Input clock for 00: TA2TRG 01: \$T1 10: \$T16 11: \$T256 | TMRA3 | Input clock for<br>00: Reserved<br>01: \phiT1<br>10: \phiT4<br>11: \phiT16 | TMRA2 | ### TMRA2 input clock selection | | 00 | Reserved | |-------------------------|----|----------| | <ta2clk1:0></ta2clk1:0> | 01 | фТ1 | | CIAZOLNI.03 | 10 | φТ4 | | | 11 | фТ16 | # TMRA3 input clock selection | | | ' \ \ / / / / | | |-------------------------|----|------------------------------------|------------------------------------------------| | | | TA23MOD <ta23m1:0> ≠ 01</ta23m1:0> | TA23MOD <ta23m1:0> = 01</ta23m1:0> | | | 00 | Comparator output from TMRA2 | | | <ta3clk1:0></ta3clk1:0> | 01 | <b>φ</b> T1 | Overflow output from TMRA2 (16-bit timer mode) | | | 10 | φT16 | (10 bit timer mode) | | | 11 | φT256 | | ## PWM cycle selection | | 00 | Reserved | |-----------------------|-------|-------------------------------| | DWM24,20, | 01 | 2 <sup>6</sup> × Clock source | | <pwm21:20></pwm21:20> | 10 | 2 <sup>7</sup> × Clock source | | | // 11 | 2 <sup>8</sup> × Clock source | ### TMRA23 operation mode selection | | 111111111111111111111111111111111111111 | polation in our delication | |-----------------------|-----------------------------------------|-----------------------------------------| | | 00 (( | 8-bit timers 2ch | | <ta23m1:0></ta23m1:0> | 01 | 16-bit timer | | V CIAZSWI1.0> | 10 | 8-bit PPG | | | 11 | 8-bit PWM (TMRA2) + 8-bit timer (TMRA3) | Page 107 2007-12-03 ## TMRA45 Mode Register TA45MOD (0114H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------------------------------------------------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------|-------|-------------------------------------------------------------------|---------|-----------------------------------------------------------------------------|---------| | Bit symbol | TA45M1 | TA45M0 | PWM41 | PWM40 | TA5CLK1 | TA5CLK0 | TA4CLK1 | TA4CLK0 | | Read/Write | | | | R | W | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Function | Operation mo<br>00: 8-bit timer<br>01: 16-bit time<br>10: 8-bit PPG<br>11: 8-bit PWM | mode<br>er mode<br>mode | PWM cycle<br>00: Reserved<br>01: 2 <sup>6</sup><br>10: 2 <sup>7</sup><br>11: 2 <sup>8</sup> | | Input clock for<br>00: TA4TRG<br>01: φT1<br>10: φT16<br>11: φT256 | TMRA5 | Input clock for<br>00: TA4IN pin<br>01: \phiT1<br>10: \phiT4<br>11: \phiT16 | | ### TMRA4 input clock selection | | 00 | TA4IN | | |-------------------------|----|-------|----| | <ta4clk1:0></ta4clk1:0> | 01 | фТ1 | | | CIA4CEN1.05 | 10 | φТ4 | // | | | 11 | φT16 | / | ## TMRA5 input clock selection | | | TA45MOD <ta45m1:0> ≠ 01</ta45m1:0> | TA45MOD <ta45m1:0> = 01</ta45m1:0> | |-------------------------------------|----|------------------------------------|------------------------------------------------| | <ta5clk1:0> 00 01 10 11</ta5clk1:0> | 00 | Comparator output from TMRA4 | | | | 01 | <b>φ</b> T1 | Overflow output from TMRA4 (16-bit timer mode) | | | 10 | φT16 | (10-bit times mode) | | | 11 | <b>♦</b> T256 | $\bigcirc)$ | ## PWM cycle selection | | 00 | Reserved | |-----------------------|-------|-------------------------------| | -DIMMA4140 | 01 | 2 <sup>6</sup> × Clock source | | <pwm41:40></pwm41:40> | 10 | 2 <sup>7</sup> × Clock source | | | // 11 | 2 <sup>8</sup> × Clock source | ### TMRA45 operation mode selection | | Time at the openion to the control of | | | | | |-----------------------|---------------------------------------|------------------------------------------|--|--|--| | | 00 (( | 8-bit timers 2ch | | | | | <ta45m1:0></ta45m1:0> | 01 | 16-bit timer | | | | | V 41A45IW11.02 | 10 | 8-bit PPG | | | | | | 11 | -8-bit PWM (TMRA4) + 8-bit timer (TMRA5) | | | | Page 108 2007-12-03 TMRA1 Flip-Flop Control Register TA1FFCR (0105H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|---|--------------------------------------------------------------------|---------|--------------------------------------------------------------|-----------------------------------------------------| | Bit symbol | - | _ | - | - | TA1FFC1 | TA1FFC0 | TA1FFIE | TA1FFIS | | Read/Write | - | - | - | - | R | /W | R | W | | After reset | - | - | - | - | 1 | _1 | 0 | 0 | | Function | | | | | 00: Invert TA1<br>01: Set TA1FF<br>10: Clear TA1<br>11: Don't care | FF | TA1FF<br>control for<br>inversion<br>0: Disable<br>1: Enable | TA1FF<br>inversion<br>select<br>0: TMRA0<br>1:TMRA1 | Inverse signal for timer flip-flop 1 (TA1FF) (Don't care except in 8-bit timer mode) | TA1FFIS | 0 | Inversion by TMRA0 | |---------|---|--------------------| | IAITIO | 1 | Inversion by TMRA1 | Inversion of TA1FF | | | . (1) | |---------|---|----------| | TA1FFIE | 0 | Disabled | | | 1 | Enabled | #### Control of TA1FF | | 00 | Inverts the value of TA1FF (Software inversion) | |-------------------------|------|-------------------------------------------------| | <ta1ffc1:0></ta1ffc1:0> | 01 < | Sets TA1FF to "1" | | <iaiffci:u></iaiffci:u> | 10 | Clears TA1FF to "0" | | | 11 | Don't care | Note: The values of bits 4 to 7 of TA1FFCR are "1" when read. ## TMRA3 Flip-Flop Control Register TA3FFCR (010DH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|-----|------|----------------------------------------|--------------------------------------------------------------------|--------------------|--------------------------------------------------|-----------------------------------------------------| | Bit symbol | _ | F | )) - | ( <u>-</u> ) | TA3FFC1 | TA3FFC0 | TA3FFIE | TA3FFIS | | Read/Write | - | 77 | - | C-1/ | R | /W | R | W | | After reset | - | (-) | - ( | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 1 | 1 | 0 | 0 | | Function | | | | | 00: Invert TA3<br>01: Set TA3FF<br>10: Clear TA3<br>11: Don't care | <del>-</del><br>FF | TA3FF control for inversion 0: Disable 1: Enable | TA3FF<br>inversion<br>select<br>0: TMRA2<br>1:TMRA3 | Inverse signal for timer flip-flop 3 (TA3FF) (Don't care except in 8-bit timer mode) | TA3FFIS | 0 | Inversion by TMRA2 | |---------|---|--------------------| | 1731110 | 1 | Inversion by TMRA3 | ### Inversion of TA3FF | TABELLE | 0 | Disabled | |----------|---|----------| | TASKI IL | 1 | Enabled | ### Control of TA3FF | <ta3ffc1:0></ta3ffc1:0> | 00 | Inverts the value of TA3FF (Software inversion) | | | | |-------------------------|----|-------------------------------------------------|--|--|--| | | 01 | Sets TA3FF to "1" | | | | | | 10 | Clears TA3FF to "0" | | | | | | 11 | Don't care | | | | Note: The values of bits 4 to 7 of TA3FFCR are "1" when read. Page 109 2007-12-03 ## TMRA5 Flip-Flop Control Register TA5FFCR (0115H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|---|--------------------------------------------------------------------|---------|--------------------------------------------------------------|-----------------------------------------------------| | Bit symbol | - | - | - | - | TA5FFC1 | TA5FFC0 | TA5FFIE | TA5FFIS | | Read/Write | - | - | - | - | R | /w < | R | W | | After reset | - | - | - | - | 1 | 1 | 0 | 0 | | Function | | | | | 00: Invert TA5<br>01: Set TA5FF<br>10: Clear TA5<br>11: Don't care | FF/S | TA5FF<br>control for<br>inversion<br>0: Disable<br>1: Enable | TA5FF<br>inversion<br>select<br>0: TMRA4<br>1:TMRA5 | Inverse signal for timer flip-flop 5 (TA5FF) (Don't care except in 8-bit timer mode) | TA5FFIS | 0 | Inversion by TMRA4 | |---------|---|--------------------| | 1701110 | 1 | Inversion by TMRA5 | Inversion of TA5FF | TA5FFIE | 0 | Disabled | 0,0 | |---------|---|----------|-----| | IASITIE | 1 | Enabled | | Control of TA5FF | | 00 Inverts the value of TA5FF (Software inversion) | |-------------------------|----------------------------------------------------| | <ta5ffc1:0></ta5ffc1:0> | 01 Sets TA5FF to "1" | | CIAGIT C1.02 | 10 Clears TA5FF to "0" | | | 11 Don't care | Note: The values of bits 4 to 7 of TA5FFCR are "1" when read. ## Timer Register | | | 7 | 6 | 5 | 4 | | 3 | 2 | 1 | 0 | |-------------------|-------------|---|-------------|------------|-------|----|---|---|---|---| | | Bit symbol | | <b>75</b> ) | | 4, | >- | | | | | | TA0REG<br>(0102H) | Read/Write | | | < ( | (//s) | W | | | | | | (010211) | After Reset | | 7 | | | 0 | | | | | | | Bit symbol | | (- | | | _ | | | | | | TA1REG<br>(0103H) | Read/Write | , | | | | W | | | | | | (5.55.1) | After Reset | | $\wedge$ | $\Diamond$ | | 0 | | | | | | | Bit symbol | | 21 | | | - | | | | | | TA2REG<br>(010AH) | Read/Write | | | , | | W | | | | | | | After Reset | | | | | 0 | | | | | | | Bit symbol | | | | | - | | | | | | TA3REG<br>(010BH) | Read/Write | | | | | W | | | | | | , | After Reset | | * | | | 0 | | | | | | | Bit symbol | | | | | - | | | | | | TA4REG<br>(0112H) | Read/Write | | | | | W | | | | | | , , | After Reset | | | | | 0 | | | | | | | Bit symbol | | | | | - | | | | | | TA5REG<br>(0113H) | Read/Write | | | | | W | | | | | | . , | After Reset | | | | | 0 | | | | | Page 110 2007-12-03 ## 6.4 Operation in Each Mode ### 6.4.1 8-bit timer mode Both TMRA0 and TMRA1 can be used independently as 8-bit interval timers. Set its function or counter data for TMRA0 and TMRA1 after stop these registers. ## 6.4.1.1 Generating interrupts at a fixed interval (Using TMRA1) To generate interrupts at constant intervals using TMRA1 (INTTA1), first stop TMRA1 then set the operation mode, input clock and a cycle to TA01MOD and TA1REG register, respectively. Then, enable the interrupt INTTA1 and start TMRA1 counting. Example: To generate an INTTA1 interrupt every 12 $\mu$ s at fc = 20 MHz, set each register as follows: | * Clock state | System clock | : High frequency (fc) | |---------------|-----------------|-----------------------| | | Prescaler clock | :f <sub>FPH</sub> \ | | | Clock gear | : 1 (fc) | | | | | | MSB | LSB | | | | IVIOD | | | | | | | | (OD ) | $\langle \rangle$ | |----------|-------|---|---|---|----|-----|-----|-----|-------|-----------------------------------------------------------------------------------------------| | | | 7 | 6 | 5 | 4 | 3 | 2 | (1) | 0 | $\Rightarrow$ ( $(//)$ ) | | TA01RUN | | - | Χ | Х | Χ | -< | 14 | 0 | > | Stop TMRA1 and clear it to 0. | | TA01MOD | | 0 | 0 | Х | x | 0 | 1 | X | Х | Select 8-bit timer mode and select $\phi T1$ (0.4 $\mu s$ at fc = 20 MHz) as the input clock. | | TA1REG | | 0 | 0 | 0 | 1 | 1 | (اد | 1 | 0 | Set TA1REG to 12 $\mu$ s ÷ $\phi$ T1 = 30 = 1EH | | INTETA01 | | X | 1 | 0 | 7, | X | - | - | - | Enable INTTA1 and set it to level 5. | | TA01RUN | | _ | X | X | X | )-) | 1 | 1 | - | Start TMRA1 counting. | | | | | | | ~ | _ | | | | | Note: X: Don't care, -: No change Select the input clock using Table 6-2 Note: The input clocks for TMRA0 and TMRA1 are different from as follows. TMRA0: TA0IN input, $\phi$ T1, $\phi$ T4 or $\phi$ T16 TMRA1: Match output of TMRA0, \$\phi\$T1, \$\phi\$T16, \$\phi\$T256 Page 111 2007-12-03 ## 6.4.1.2 Generating a 50% duty ratio square wave pulse The state of the timer flip-flop (TA1FF) is inverted at constant intervals and its status output via the timer output pin (TA1OUT). Example: To output a 2.4 $\mu$ s square wave pulse from the TA1OUT pin at fc = 20 MHz, use the following procedure to make the appropriate register settings. This example uses TMRA1; however, either TMRA0 or TMRA1 may be used. | | * Clock stat | te | | | ; | Syster | n clo | ck | | : High frequency (fc) | |---------|--------------|----|---|----|-----|--------|--------|------|-----------|-----------------------------------------------------------------------------------------------| | | | | | | ı | Presc | aler c | lock | | :(f <sub>FPH</sub> | | | | | | | | Clock | gear | | | : 1 (tc) | | | | | | | | | | | | 4() | | | MSB | | | | | | | | LSB | | | | - | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TA01RUN | - | - | Х | Х | Х | - | - | 0 | $\exists$ | Stop TMRA1 and clear it to 0. | | TA01MOD | ( | 0 | 0 | Х | X | 0 | 1 | ~ | (- | Select 8-bit timer mode and select $\phi T1$ (0.4 $\mu s$ at fc = 20 MHz) as the input clock. | | TA1REG | ( | 0 | 0 | 0 | 0 | 0 | 0( | 1 | 1 | Set the timer register to 2.4 $\mu$ s ÷ $\phi$ T1 ÷ 2 = 03H | | TA1FFCR | ) | X | х | Х | Х | 1 | 0 | 1 | 1 | Clear TA1FF to "0" and set it to invert on the match detects signal from TMRA1. | | P7CR | | X | Х | Х | - | _ | ]_ | 1 | _ | 0.477.4 | | P7FC | | X | Χ | Х | + ( | (- | 1-1 | 1 | _ | Set P71 to function as the TA1OUT pin. | | TA01RUN | - | _ | Χ | Х | -x | - | ٧/ | 1 | - | Start TMRA1 counting. | | | | | | (( | ~ < | | | | | | Note: X: Don't care, -: No change Page 112 2007-12-03 Figure 6-5 Square Wave Output Timing Chart (50% duty) ## 6.4.1.3 Making TMRA1 count up on the match signal from the TMRA0 comparator Select 8-bit timer mode and set the comparator output from TMRA0 to be the input clock to TMRA1. Figure 6-6 TMRA1 Count Up on Signal from TMRA0 Page 113 2007-12-03 ### 6.4.2 16-bit timer mode A 16-bit interval timer is configured by pairing the two 8-bit timers TMRA0 and TMRA1. To make a 16-bit interval timer in which TMRA0 and TMRA1 are cascaded together, set TA01MOD<TA01M1:0> to 01. In 16-bit timer mode, the overflow output from TMRA0 is used as the input clock for TMRA1, regardless of the value set in TA01MOD<TA1CLK1:0>. Table 6-2 shows the cycle of the input clock for TMRA0. LSB 8-bit set to TA0REG and MSB 8-bit is for TA1REG. Please keep setting TA0REG first because setting data for TA0REG inhibit its compare function and setting data for TA1REG permit it. Example: To generate an INTTA1 interrupt every 0.4 [s] at fc = 20 MHz, set the timer registers TA0REG and TA1REG as follows: \* Clock state System clock Prescaler clock Clock gear \* High frequency (fc) : f<sub>FPH</sub> : 1 (fc) If $\phi T16$ ( $2^7$ /fc $\mu$ s at fc = 20 MHz) is used as the input clock for counting, set the following value in the registers: $0.4 \text{ s/}(2^7$ /fc) $\mu$ s = 62500 = F424H (e.g., set TA1REG to F4H and TA0REG to 24H). As a result, INTTA1 interrupt can be generated every 0.4 [s]. The comparator match signal is output from TMRA0 each time the up counter UC0 matches TA0REG, though the up counter UC0 is not cleared and also INTTA0 is not generated. In the case of the TMRA1 comparator, the match detect signal is output on each comparator pulse on which the values in the up counter UC1 and TA1REG match. When the match detect signal is output simultaneously from both the comparators TMRA0 and TMRA1, the up counters UC0 and UC1 are cleared to 0 and the interrupt INTTA1 is generated. Also, if inversion is enabled, the value of the timer flip-flop TA1FF is inverted. Example: When TA1REG = 04H and TA0REG = 80H Figure 6-7 Timer Output by 16-Bit Timer Mode Page 114 2007-12-03 ## 6.4.3 8-bit PPG (Programmable pulse generation) output mode Square wave pulses can be generated at any frequency and duty ratio by TMRA0. The output pulses may be active low or active high. In this mode TMRA1 cannot be used. TMRA0 outputs pulses on the TA1OUT pin. Figure 6-8 8-Bit PPG Output Waveforms In this mode, a programmable square wave is generated by inverting the timer output each time the 8-bit up counter (UC0) matches the value in one of the timer registers TA0REG or TA1REG. The value set in TA0REG must be smaller than the value set in TA1REG. Although the up counter for TMRA1 (UC1) is not used in this mode, TA01RUN<TA1RUN> should be set to "1", so that UC1 is set for counting. Figure 6-9 shows a block diagram representing this mode. Figure 6-9 Block Diagram of 8-Bit PPG Output Mode Page 115 2007-12-03 If the TA0REG double buffer is enabled in this mode, the value of the register buffer will be shifted into TA0REG each time TA1REG matches UC0. Use of the double buffer facilitates the handling of low-duty waves (when duty is varied). Figure 6-10 Operation of Register Buffer 0 Note: The values that can be set in TAxREG range from 01h to 00h (equivalent to 100h). If the maximum value 00h is set, the match-detect signal goes active when the up-counter overfolws. Example: To generate 1/4-duty 50-kHz pulses (at fc = 20 MHz): Calculate the value which should be set in the timer register. To obtain a frequency of 50 kHz, the pulse cycle t should be: $t = 1/50 \text{ kHz} = 20 \mu \text{s}$ $$\phi T1 = 2^3/\text{fc } \mu \text{s (at fc} = 20 \text{ MHz)};$$ $$20 \,\mu\text{s}/(2^3/\text{fc}) \,\mu\text{s} = 50$$ Therefore set TA1REG to 50 (32H), and 50-kHz pulses can be obtained. The duty is to be set to 1/4: $t \times 1/4 = 20 \mu s \times 1/4 = 5 \mu s$ $$5 \,\mu\text{s}/(2^3/\text{fc}) \,\mu\text{s} = 13$$ Therefore, set TA0REG = 13 = 0DH. Page 116 2007-12-03 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------------|------|-------|------|---|---|---|---|---|-------------------------------------------------------------------| | TA01RUN | 0 | Х | Х | Х | _ | - | 0 | 0 | Stop TMRA0 and TMRA01 and clear it to "0".(Double buffer disable) | | TA01MOD | 1 | 0 | Х | Х | Х | Х | 0 | 1 | Set the 8-bit PPG mode, and select φT1 as input clock. | | TA0REG | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | Write 0DH. | | TA1REG | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | Write 32H. | | TA1FFCR | Х | Х | Х | Х | 0 | 1 | 1 | Х | Set TA1FF, enabling both inversion and the double buffer. | | | | | | | | | | | Writing "10" provides negative logic pulse. | | P7CR | Χ | Χ | Χ | - | - | - | 1 | - | Set P71 as the TA1OUT pin. | | P7FC | Х | Х | Х | - | - | - | 1 | - | | | TA01RUN | 1 | Х | Х | Х | - | 1 | 1 | 1 | Start TMRA0 and TMRA01 counting.(Double buffer enable) | | Note: X : Don't Care | -: N | o cha | ange | | | | | | | Page 117 2007-12-03 ### 6.4.4 8-bit PWM output mode This mode is only valid for TMRA0. In this mode, a PWM pulse with the maximum resolution of 8 bits can be output. When TMRA0 is used the PWM pulse is output on the TA1OUT pin. TMRA1 can also be used as an 8-bit timer. The timer output is inverted when the up counter (UC0) matches the value set in the timer register TA0REG or when $2^n$ counter overflow occurs (n = 6, 7 or 8 as specified by TA01MOD<PWM01:00>). The up counter UC0 is cleared when $2^n$ counter overflow occurs. The following conditions must be satisfied before this PWM mode can be used. Value set in TA0REG < Value set for 2<sup>n</sup> counter overflow Value set in TA0REG ≠ 0 TA0REG and UC0 match 2<sup>n</sup> overflow (INTTA0 interrupt) TA1OUT TA1OUT Figure 6-11 8-Bit PWM Waveforms Figure 6-12 shows a block diagram representing this mode. Figure 6-12 Block Diagram of 8-Bit PWM Mode In this mode, the value of the register buffer will be shifted into TA0REG if 2<sup>n</sup> overflow is detected when the TA0REG double buffer is enabled. Page 118 2007-12-03 Use of the double buffer facilitates the handling of low duty ratio waves. Figure 6-13 Operation of Register Buffer 0 Example: To output the following PWM waves on the TA1OUT pin at fc = 20 MHz: To achieve a 51.2 $\mu$ s PWM cycle by setting $\phi$ T1 to $2^3$ /fc $\mu$ s (at fc = 20 MHz): 51.2 $$\mu s/(2^3/fc) \mu s = 128 = 2^n$$ Therefore n should be set to 7. Since the low-level period is 29.6 $\mu$ s when $\phi T1 = 2^3/fc$ $\mu$ s (at fc = 20 MHz), set the following value for TA0REG: 29.6 $$\mu s/(2^3/fc) \mu s = 74 = 4AH$$ Note:X: Don't Care -: No change Page 119 2007-12-03 Table 6-3 PWM Cycle @ fc = 20 MHz, fs = 32.768 kHz | Select Sys- | Gear Value | Select Prescaler<br>Clock<br>SYSCR0<br><prck1></prck1> | PWM cycle | | | | | | | | | | |---------------------|---------------------|--------------------------------------------------------|-----------|----------------|----------|----------|----------------|----------|----------|----------|----------|--| | tem Clock<br>SYSCR1 | SYSCR1 | | | 2 <sup>6</sup> | | | 2 <sup>7</sup> | | 28 | | | | | <sysck></sysck> | <gear2:0></gear2:0> | | φΤ1 | φΤ4 | φT16 | φΤ1 | φΤ4 | φT16 | φT1 | φΤ4 | φT16 | | | 1 (fs) | XXX | | 15.6 ms | 62.5 ms | 250 ms | 31.3 ms | 125 ms | 500 ms | 62.5 ms | 250 ms | 1000 ms | | | | 000 (fc) | | 25.6 μs | 102.4 μs | 409.6 μs | 51.2 μs | 204.8 μs | 819.2 μs | 102.4 μs | 409.6 μs | 1638 μs | | | | 001 (fc/2) | 0 (1/1) | 51.2 μs | 204.8 μs | 819.2 μs | 102.4 μs | 409.6 μs | 1638 μs | 204.8 μs | 819.2 μs | 3277 μs | | | | 010 (fc/4) | f <sub>FPH</sub> | 102.4 μs | 409.6 μs | 1638 μs | 204.8 μs | 810.2 μs | 3277 μs | 409.6 μs | 1638 μs | 6554 μs | | | 0 (fc) | 011 (fc/8) | | 204.8 μs | 819.2 μs | 3277 μs | 409.6 μs | 1638 μs | 6554 μs | 819.2 μs | 3277 μs | 13107 μs | | | | 100 (fc/16) | | 409.6 μs | 1638 μs | 6554 μs | 819.2 μs | 3277 μs | 13107 μs | 1638 μs | 6554 μs | 26214 μs | | | | XXX | 1 (1/16)<br>fc/16 clock | 409.6 μs | 1638 μs | 6554 μs | 819.2 µs | 3277 μs | 13107 μs | 1638 μs | 6554 μs | 26214 μs | | Note: xxx: Don't care ## 6.4.5 Settings for each mode Table 6-4 shows the SFR settings for each mode. Table 6-4 Timer Mode Setting Registers | Register Name | | TAC | 01MOD | | TA1FFCR | |--------------------------|-----------------------|------------------------------------------------------------------|----------------------------------|------------------------------------------------------|---------------------------------------------| | <bit symbol=""></bit> | <ta01m1:0></ta01m1:0> | <pwm01:00></pwm01:00> | <ta1clk1:0></ta1clk1:0> | <ta0clk1:0></ta0clk1:0> | TA1FFIS | | Function | Timer Mode | PWM Cycle | Upper Timer<br>Input Clock | Lower Timer<br>Input Clock | Timer F/F Invert<br>Signal Select | | 8-bit timer × 2 channels | 000 | )<br>- ( | Lower timer match | External clock<br>φT1 φT4, φT16<br>(00, 01, 10, 11) | 0: Lower timer output 1: Upper timer output | | 16-bit timer mode | 01 | \ <u>-</u> (\(\) | <u></u> | External clock<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | - | | 8-bit PPG × 1 channel | 10 | | - | External clock<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | - | | 8-bit PWM × 1 channel | 11 | 2 <sup>6</sup> , 2 <sup>7</sup> , 2 <sup>8</sup><br>(01, 10, 11) | - | External clock | - | | 8-bit timer × 1 channel | 11 | - | φΤ1, φΤ16, φΤ256<br>(01, 10, 11) | _ | Output disabled | Note: -: Don't care Page 120 2007-12-03 # 16-Bit Timer/Event Counters (TMRB) The TMP91CW60 incorporates five multifunctional 16-bit timer/event counters (TMRB0, TMRB1, TMRB2, TMRB3, TMRB4) which have the following operation modes: - 16-bit interval timer mode - 16-bit event counter mode - 16-bit programmable pulse generation (PPG) output mode The capture function enables selection of the following modes: - · Frequency measurement mode - · Pulse width measurement mode - · Time differential measurement Figure 7-1 show block diagrams for TMRB0, TMRB1, TMRB2, TMRB3 and TMRB4. Each timer/event counter channel consists of a 16-bit up-counter, two 16-bit timer registers (one of them with a double-buffer structure), two 16-bit capture registers, two comparators, a capture input controller, two timer flip-flops and a timer flip-flop controller. Each timer/event counter is controlled by an 11-byte SFR (special-function register). Each of the five channels (TMRB0, TMRB1, TMRB2, TMRB3, TMRB4) can be used independently. Each channel features the same operations except for those described in Table 7-1. Hence, only the operation of TMRB0 is explained below. Table 7-1 Registers and Pins for TMRB | Specification | Channel | TMRB0 | TMRB1 | TMRB2 | TMRB3 | TMRB4 | |-----------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------| | External | External clock/capture trigger input pins | TB0IN0 (also used as P80) TB0IN1 (also used as P81) | TB1IN0<br>(also used as P84)<br>TB1IN1<br>(also used as P85) | TB2IN0<br>(also used as PA0)<br>TB2IN1<br>(also used as PA1) | TB3IN0<br>(also used as P30)<br>TB3IN1<br>(also used as P31) | TB4IN0<br>(also used as PB0)<br>TB4IN1<br>(also used as PB1) | | pins Timer flip-flop output pins | TB0OUT0<br>(also used as P82)<br>TB0OUT1<br>(also used as P83) | TB1OUT0<br>(also used as P86)<br>TB1OUT1<br>(also used as P87) | TB2OUT0<br>(also used as PA2)<br>TB2OUT1<br>(also used as PA3) | TB3OUT0<br>(also used as P32)<br>TB3OUT1<br>(also used as P33) | TB4OUT0<br>(also used as PB2)<br>TB4OUT1<br>(also used as PB3) | | | | Timer run register | TB0RUN (0180H) | TB1RUN (0190H) | TB2RUN (01A0H) | TB3RUN (01B0H) | TB4RUN (01C0H) | | | Timer mode register | TB0MOD (0182H) | TB1MOD (0192H) | TB2MOD (01A2H) | TB3MOD (01B2H) | TB4MOD (01C2H) | | | Timer flip-flop control register | TB0FFCR (0183H) | TB1FFCR (0193H) | TB2FFCR (01A3H) | TB3FFCR (01B3H) | TB4FFCR (01C3H) | | | | TB0RG0L (0188H) | TB1RG0L (0198H) | TB2RG0L (01A8H) | TB3RG0L (01B8H) | TB4RG0L (01C8H) | | SFR | | TB0RG0H (0189H) | TB1RG0H (0199H) | TB2RG0H (01A9H) | TB3RG0H (01B9H) | TB4RG0H (01C9H) | | (address) | Timer registers | TB0RG1L (018AH) | TB1RG1L (019AH) | TB2RG1L (01AAH) | TB3RG1L (01BAH) | TB4RG1L (01CAH) | | | | TB0RG1H (018BH) | TB1RG1H (019BH) | TB2RG1H (01ABH) | TB3RG1H (01BBH) | TB4RG1H (01CBH) | | | | TB0CP0L (018CH) | TB1CP0L (019CH) | TB2CP0L (01ACH) | TB3CP0L (01BCH) | TB4CP0L (01CCH) | | | | TB0CP0H (018DH) | TB1CP0H (019DH) | TB2CP0H (01ADH) | TB3CP0H (01BDH) | TB4CP0H (01CDH) | | | Capture registers | TB0CP1L (018EH) | TB1CP1L (019EH) | TB2CP1L (01AEH) | TB3CP1L (01BEH) | TB4CP1L (01CEH) | | | | TB0CP1H (018FH) | TB1CP1H (019FH) | TB2CP1H (01AFH) | TB3CP1H (01BFH) | TB4CP1H (01CFH) | Page 121 2007-12-03 ## 7.1 Block Diagrams Figure 7-1 Block Diagrams of TMRB0 to TMRB4 Page 122 2007-12-03 TOSHIBA TMP91CW60 ## 7.2 Operation of Each Block ### 7.2.1 Prescaler The 5-bit prescaler generates the source clock for TMRB0. The prescaler clock ( $\phi$ T0) is divided clock (divided by 4) from selected clock by the register SYSCR0<PRCK1> of clock gear. This prescaler can be started or stopped using TB0RUN<TB0PRUN>. Counting starts when <TB0PRUN> is set to 1; the prescaler is cleared to 0 and stops operation when <TB0PRUN> is cleared to 0. Table 7-2 show prescaler output clock resolution. Table 7-2 Prescaler Output Clock Resolution @fc = 20 MHz, fs = 32.768 kHz | System Clock | Clock Gear Value | Prescaler Clock | Prescaler Output Clock Resolution | | | | | | |---------------------------|----------------------------|------------------------------|-----------------------------------|------------------------------|--------------------------------|--|--|--| | SelectionSYSC1<<br>SYSCK> | SYSCR1 <gear2:0></gear2:0> | Selection<br><prck1></prck1> | φT1<br>(1/2) | φT4<br>(1/8) | φT16<br>(1/32) | | | | | 1 (fs) | xxx | | 2 <sup>3</sup> /fs (244 μs) | 2 <sup>5</sup> /fs (977 μs) | 2 <sup>7</sup> /fs (3.9 ms) | | | | | | 000 (fc) | | 2 <sup>3</sup> /fc (0.4 μs) | 2 <sup>5</sup> /fc (1.6 μs) | 2 <sup>7</sup> /fc(6.4 μs) | | | | | | 001 (fc/2) | 0 (1/1) | 2 <sup>4</sup> /fc (0.8 μs) | 2 <sup>6</sup> /fc (3.2 μs) | 2 <sup>8</sup> /fc (12.8 μs) | | | | | | 010 (fc/4) | f <sub>FPH</sub> | 2 <sup>5</sup> /fc (1.6 μs) | 2 <sup>7</sup> /fc (6.4 μs) | 2 <sup>9</sup> /fc (25.6 μs) | | | | | 0 (fc) | 011 (fc/8) | | 2 <sup>6</sup> /fc (3.2 μs) | 2 <sup>8</sup> /fc (12.8 μs) | 2 <sup>10</sup> /fc (51.2 μs) | | | | | | 100 (fc/16) | | 2 <sup>7</sup> /fc (6.4 μs) | 2 <sup>9</sup> /fc (25.6 μs) | 2 <sup>11</sup> /fc (102.4 μs) | | | | | | XXX | 1 (1/16)<br>fc/16 clock | 2 <sup>7</sup> /fc (6.4 μs) | 2 <sup>9</sup> /fc (25.6 μs) | 2 <sup>11</sup> /fc (102.4 μs) | | | | #### Note: xxx: Don't care ## 7.2.2 Up counter (UC0) UC0 is a 16-bit binary counter which counts up according to input from the clock specified by TB0MOD<TB0CLK1:0> register. As the input clock, one of the prescaler internal clocks $\phi T1$ , $\phi T4$ and $\phi T16$ or an external clock from TB0IN0 pin can be selected. Counting or stopping and clearing of the counter is controlled by timer operation control register TB0RUN<TB0RUN>. When clearing is enabled, the up counter UC0 will be cleared to 0 each time its value matches the value in the timer register TB0RG1H/L. If clearing is disabled, the counter operates as a free-running counter. Clearing can be enabled or disabled by using TB0MOD<TB0CLE>. A timer overflow interrupt (INTTBOF0) is generated when UC0 overflow occurs. ## 7.2.3 Timer registers (TB0RG0H/L, TB0RG1H/L) These two 16-bit registers are used to set the interval time. When the value in the up counter UC0 matches the value set in this timer register, the comparator match detect signal will go active. Setting data for both upper and lower timer registers is needed. For example, using 2-byte data transfer instruction or using 1-byte data transfer instruction twice for lower 8 bits and upper 8 bits in order. (The compare circuit will not operate if only the lower 8 bits are written. Be sure to write to both timer registers (16 bits) from the lower 8 bits followed by the upper 8 bits.) The TB0RG0H/L timer register has a double-buffer structure, which is paired with register buffer 0. The value set in TB0RUN<TB0RDE> determines whether the double-buffer structure is enabled or disabled: it is disabled when <TB0RDE> = "0", and enabled when <TB0RDE> = "1". Page 123 2007-12-03 When the double buffer is enabled, data is transferred from the register buffer 0 to the timer register when the values in the up counter (UC0) and the timer register TB0RG1H/L match. The double buffer circuit incorporates two flags to indicate whether or not data is written to the lower 8 bits and the upper 8 bits of the register buffer, respectively. Only when both flags are set can data be transferred from the register buffer to the timer register by a match between the up-counter UC0 and the timer register TB0RG1. This data transfer is performed so long as 16-bit data is written in the register buffer regardless of the register buffer to the timer register unexpectedly as explained below. For example, let us assume that an interrupt occurs when only the lower 8 bits (L1) of the register buffer data (H1L1) have been written and the interrupt routine includes writes to all 16 bits in the register buffer and a transfer of the data to the timer register. In this case, if the higher 8 bits (H1) are written after the interrupt routine is completed, only the flag for the higher 8 bits will be set, the flag for the lower 8 bits having been cleared in the interrupt routine. Therefore, even if a match occurs between UC0 and TB0RG1, no data transfer will be performed. Then, in an attempt to set the next set of data (H2L2) in the register buffer, when the lower 8 bits (L2) are written, this will cause the flag for the lower 8 bits to be set as well as the flag for the higher 8 bits which has been set by writing the previous data (H1). If a match between UC0 and TB0RG1 occurs before the higher 8 bits (H2) are written, this will cause unexpected data (H1L2) to be sent to the timer register instead of the intended data (H2L2). To avoid such transfer timing problems due to interrupts, the DI instruction (disable interrupts) and the EI (enable interrupts) can be executed before and after setting data in the register buffer, respectively. After a reset, TB0RG0H/L and TB0RG1H/L are undefined. If the 16-bit timer is to be used after a reset, data should be written to it beforehand. On a reset <TB0RDE> is initialized to "0", disabling the double buffer. To use the double buffer, write data to the timer register, set <TB0RDE> to "1", then write data to the register buffer 10 as shown below. TB0RG0H/L and the register buffer 0 both have the same memory addresses (0188H and 0189H) allocated to them. If <TB0RDE> = "0", the value is written to both the timer register and the register buffer 0. If <TB0RDE> = "1", the value is written to the register buffer 0 only. The addresses of the timer registers are as follows: Note: The timer registers are write-only registers and thus cannot be read. Page 124 2007-12-03 ## 7.2.4 Capture registers (TB0CP0H/L, TB0CP1H/L) These 16-bit registers are used to latch the values in the up counter (UC0). Data in the capture registers should be read all 16 bits. For example, using a 2-byte data load instruction or two 1-byte data load instructions. The least significant byte is read first, followed by the most significant byte. (during capture is read, capture operation is prohibited. In that case, the lower 8 bits should be read first, followed by the 8 bits.) The addresses of the capture registers are as follows; Note: The capture registers are read-only registers and thus cannot be written to. ## 7.2.5 Capture Input Control and External Interrupt Control 1). This circuit controls the timing to latch the value of up-counter UC0 into TB0CP0H/L and TB0CP1H/L, and generates external interrupt. The latch timing of capture register and selection of edge for external interrupt is controlled by TB0MOD<TB0CPM1:0>. The value in the up-counter (UC0) can be loaded into a capture register by software. Whenever 0 is written to TB0MOD<TB0CP0I>, the current value in the up counter (UC0) is loaded into capture register TB0CP0H/L. It is necessary to keep the prescaler in RUN mode (e.g., TB0RUN<TB0PRUN> must be held at a value of Page 125 2007-12-03 ### 7.2.6 Comparators (CP00, CP01) CP10 and CP11 are 16-bit comparators which compare the value in the up counter UC0 with the value set in TB0RG0H/L or TB0RG1H/L respectively, in order to detect a match. If a match is detected, the comparator generates an interrupt (INTTB00 or INTTB01 respectively). ### 7.2.7 Timer flip-flops (TB0FF0, TB0FF1) These flip-flops are inverted by the match detect signals from the comparators and the latch signals to the capture registers. Inversion can be enabled and disabled for each element using TB0FFCR<TB0C0T1, TB0E1T1, TB0E0T1>. After a reset the value of TB0FF0 is undefined. If "00" is written to TB0FFCR <TB0FF0C1:0> or <TB0FF1C1:0>, TB0FF0 will be inverted. If "01" is written to the capture registers, the value of TB0FF0 will be set to "1". If "10" is written to the capture registers, the value of TB0FF0 will be set to "0". Note: If an inversion by the match-detect signal and a setting change via the TB0FFCR register occurs simultaneously, the resultant operation varies depending on the situation, as shown below. - If an inversion by the match-detect signal and an inversion via the register occur simultaneously, the flip-flop will be inverted only once. - If an inversion by the match-detect signal and an attempt to set the flip-flop to 1 via the register occur simultaneously, the flip-flop will be set to 1. - If an inversion by the match-detect signal and an attempt to clear the flip-flop to 0 via the register occur simultaneously, the flip-flop will be cleared to 0. If an inversion by match-detect signal and inversion disable setting occur simultaneously, two case (it is inverted and it is not inverted) are occurred. Therefore, if changing inversion control (inversion enable/disable), stop timer operation beforehand. The values of TB0FF0 and TB0FF1 can be output via the timer output pins TB0OUT0 (which is shared with P82 and TB0OUT1 (which is shared with P83). Timer output should be specified using the port P function register. Page 126 2007-12-03 ## 7.3 SFR | TMRB R | un Register | |--------|-------------| |--------|-------------| | | <u> </u> | | | | | | | | | |----------------------|------------|-------------------------|--------------|------------|--------|-----------------------|---------------------------------|------|--------| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bi | it symbol | TB0RDE | - | - | - | I2TB0 | TB0PRUN | )) - | TB0RUI | | R | ead/Write | R/W | R/W | - | - | R/W | R/W | - | R/W | | At | fter reset | 0 | 0 | | | 0 | (V(0)) | - | 0 | | Fu | unction | Double<br>Buffer | Always write | Not i | n use | IDLE2<br>0: Stop | TMRB0<br>prescaler | | UC0 | | | | 0: Disable<br>1: Enable | 0. | | | 1: Operate | 0: Stop and Cl<br>1: Run (count | | | | Bi | it symbol | TB1RDE | - | - | - | I2TB1 | TB1PRUN | 91- | TB1RU | | R | ead/Write | R/W | R/W | - | - ( | R/W | R/W | | R/W | | At | fter reset | 0 | 0 | | | 0 | > o (( | | 0 | | Fi | unction | Double<br>Buffer | Always write | Not i | nuse | IDLE2 | TMRB1<br>prescaler | | UC1 | | | u | 0: Disable<br>1: Enable | 0. | < | | 1: Operate | 0: Stop and Cl<br>1: Run (count | | | | Bi | it symbol | TB2RDE | _ | | | I2TB2 | TB2PRUN | _ | TB2RU | | R | ead/Write | R/W | R/W | = | \\ \- | R/W\ | R/W | - | R/W | | At | fter reset | 0 | 0 | 4() | > / | Q | 0 | _ | 0 | | | | Double<br>Buffer | Always write | | | IDLE2 | TMRB2<br>prescaler | | UC2 | | | unction | 0: Disable<br>1: Enable | 0. | Noti | n use | 0: Stop<br>1: Operate | 0: Stop and Cl<br>1: Run (count | | | | Bi | it symbol | TB3RDE | (-( | ) ) – | \ | I2TB3 | TB3PRUN | - | TB3RU | | R | ead/Write | R/W | R/W | ) - | 1 | R/W | R/W | - | R/W | | At | fter reset | 0 | (//0\ | | 11 | 0 | 0 | - | 0 | | E | unction | Double<br>Buffer | Always write | Noti | nuse | IDLE2<br>0: Stop | TMRB3<br>prescaler | | UC3 | | | unction | 0: Disable<br>1: Enable | 0. | | il use | 1: Operate | 0: Stop and Cl<br>1: Run (count | | | | Bi | it symbol | TB4RDE | _ | \ <u>-</u> | | I2TB4 | TB4PRUN | - | TB4RL | | R | ead/Write | R/W | R/W | | _ | R/W | R/W | - | R/W | | Af | fter reset | <b>O</b> | 0 /> | | | 0 | 0 | - | 0 | | Fi | unction | Double<br>Buffer | Always write | Not i | n use | IDLE2<br>0: Stop | TMRB4<br>prescaler | | UC4 | | 0: Disable 1: Enable | | | | | | 1: Operate | 0: Stop and Cl<br>1: Run (count | | | I2TB0, I2TB1, I2TB2, I2TB3, I2TB4: Operation of IDLE2 mode TB0PRUN, TB1PRUN, TB2PRUN, TB3PRUN, TB4PRUN: Operation of prescaler TB0RUN, TB1RUN, TB2RUN, TB3RUN, TB4RUN: Operation of TMRB Operation Stop and Clear 1 Count Note: Bits 1, 4 and 5 of TB0RUN/TB1RUN/TB2RUN/TB3RUN/TB4RUN are "1" when read. Page 127 2007-12-03 TMRB Mode Register (Read-modify-write instructions are prohibited.) (1/2) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------|---------| | | Bit symbol | TB0CT1 | TB0ET1 | TB0CP0I | TB0CPM1 | TB0CPM0 | TB0CLE | TB0CLK1 | TB0CLK0 | | TB0MOD<br>(0182H) | Read/Write | R | /W | W* | | | R/W | | | | (010211) | After reset | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | Function | TB0FF1 inversions of the control | ible | Software capture control 0: Software capture 1: Undefined | 01: TB0IN0↑ TE INT5 occurs 10: TB0IN0↑ TE INT5 occurs 11: TA1OUT↑ T | s at rising edge<br>B0IN0↓<br>s at falling edge | Up counter<br>control<br>0: Clear<br>disable<br>1: Clear<br>enable | TMRB0 input<br>00: TB0IN0 pi<br>01: фT1<br>10: фT4<br>11: фT16 | | | TB1MOD | Bit symbol | TB1CT1 | TB1ET1 | TB1CP0I | TB1CPM1 | TB1CPM0 | TB1CLE | TB1CLK1 | TB1CLK0 | | (0192H) | Read/Write | R | /W | W* | | | R/W | | | | | After reset | 0 | 0 | 1 | 0 ( | / 0 | 0 | 0> | 0 | | | Function | TB1FF1 inversions on Trigger disactions on Trigger enaignment of the T | ible | Software capture control 0: Software capture | 01: TB1IN0↑ TE<br>INT7 occurs<br>10: TB1IN0↑ TE | s at rising edge<br>B1IN0↓ | Up counter control 0: Clear disable 1: Clear | TMRB1 input<br>00: TB1IN0 pi<br>01: \phiT1<br>10: \phiT4 | | | | Dit overhol | loaded into | with<br>TB1RG1H/L | 1: Undefined | 11: TA1OUT↑ T<br>INT7 occurs | s at rising edge | enable | 11: φT16 | TROCLEO | | TB2MOD | Bit symbol | TB2CT1 | TB2ET1 | TB2CP0I | TB2CPM1 | TB2CPM0 | TB2CLE | TB2CLK1 | TB2CLK0 | | (01A2H) | Read/Write | | W | ( W*) | . 1 | | R/W | | | | | After reset | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | | UC2 is Joaded into | | able | Software<br>capture<br>control<br>0: Software<br>capture<br>1: Undefined | 01: TB2IN01 TI INT1 occurs 10: TB2IN01 TI INT1 occurs 11: TA1OUT1 TI INT1 occurs | s at rising edge<br>B2IN0↓<br>s at falling edge | Up counter<br>control<br>0: Clear<br>disable<br>1: Clear<br>enable | TMRB2 input<br>00: TB2IN0 pi<br>01: фT1<br>10: фT4<br>11: фT16 | | | TB3MOD | Bit symbol | TB3CT1 | TB3ET1 | TB3CP0I | ─∕TB3CPM1 | TB3CPM0 | TB3CLE | TB3CLK1 | TB3CLK0 | | (01B2H) | Read/Write | | /W | W* | | | R/W | | | | | After reset | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | Function | TB3FF1 inversions Trigger disable Trigger enauge Invert when UC3 is loaded into TB3CP1H/L | able | Software<br>capture<br>control<br>0: Software<br>capture<br>1: Undefined | 01: TB3IN0↑ TE INT3 occurs 10: TB3IN0↑ TE INT3 occurs 11: TA3OUT↑ T | s at rising edge<br>B3IN0↓<br>s at falling edge | Up counter<br>control<br>0: Clear<br>disable<br>1: Clear<br>enable | TMRB3 input<br>00: TB3IN0 pi<br>01: \phiT1<br>10: \phiT4<br>11: \phiT16 | | Page 128 2007-12-03 TMRB Mode Register (Read-modify-write instructions are prohibited.) (2/2) TB4MOD (01C2H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---------------------------------------------------|----------------------------------------------------|------------------------------------------|--------------------------------------------|-------------------------------------------------|---------------------------------|-------------------------------------------------|---------| | Bit symbol | TB4CT1 | TB4ET1 | TB4CP0I | TB4CPM1 | TB4CPM0 | TB4CLE | TB4CLK1 | TB4CLK0 | | Read/Write | R/W W* | | W* | | | /R/W | | | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | TB4FF1 inver<br>0: Trigger disa<br>1: Trigger ena | able | Software capture | INT9 occurs | | Up counter | TMRB4 input | | | Function | Invert when<br>UC4 is<br>loaded into<br>TB4CP1H/L | Invert when<br>UC4<br>matches<br>with<br>TB4RG1H/L | control 0: Software capture 1: Undefined | 10: TB4IN0↑ T<br>INT9 occur<br>11: TA5OUT↑ | s at rising edge<br>B4IN0↓<br>s at falling edge | 0: Clear<br>disable<br>1: Clear | 00: TB4IN0 pi<br>01: φT1<br>10: φT4<br>11: φT16 | n input | #### TMRB source clock | | 00 | External input clock (TBnIN0 pin input) | |-------------------------|----|-----------------------------------------| | <tbnclk1:0></tbnclk1:0> | 01 | фТ1 | | | 10 | фТ4 | | | 11 | ФТ16 | | | 11 | Ψ110 | ### Up counter clear control (UCn) | <trncl f=""></trncl> | 0 | Disable to clear up counter | 7/\\ | |----------------------|---|-----------------------------|------| | (TBHOLL) | 1 | Clear by match with TBnRG | 1H/L | ### Capture/Interrupt timing | | | Capture control | INT5 control | |-------------------------|-------------|----------------------------------------------------------------------------------------------|---------------------------------------------| | | 00 | Disable capture | INT generate at ris- | | | <u>)</u> 01 | Capture to TBnCP0H/L at rising edge of TBnIN0 Capture to TBnCP1H/L at rising edge of TBnIN1 | ing edge of TBnIN0 | | <tb0cpm1:0></tb0cpm1:0> | 10 | Capture to TBnCP0H/L at rising edge of TBnIN0 Capture to TBnCP1H/L at falling edge of TBnIN0 | INT generate at fall-<br>ing edge of TBnIN0 | | | 11 | Capture to TBnCP0H/L at rising edge of TAzOUT Capture to TBnCP1H/L at falling edge of TAzOUT | INT generate at rising edge of TBnIN0 | ### Software capture | <tbncp0i></tbncp0i> | 0 | Capture value of up counter to TBnCP0H/L. | |---------------------|---|-------------------------------------------| | \ TBIIOI 0 > | 1 | Undefined (Note 3) | Note 1: n=0,1,2,3,4 Note 2: z=1,3,5 Note 3: As described above, whenever 0 is written to TBnMOD<TBnCP0I>, the current value in the up counter is loaded into capture register TBnCP0H/L. However, note that the current value in the up counter is also loaded into capture register TBnCP0H/L when 1 is written to TBnMOD<TBnCP0I> while this bit is holding 0. Page 129 2007-12-03 TMRB Flip-Flop Control Register (Read-modify-write instructions are prohibited.) (1/2) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------|-------------|-----------------------------------------------------|-------------|-----------------------------------------------|-------------------------------------------|------------------------------------|------------------------------------|-----------------------------------------------------|-------------| | TDOFFOR | Bit symbol | TB0FF1C1 | TB0FF1C0 | TB0C1T1 | TB0C0T1 | TB0E1T1 | TB0E0T1 | TB0FF0C1 | TB0FF0C0 | | TB0FFCR<br>(0183H) | Read/Write | V | /* | | R | /W | $\wedge$ | V | /* | | , , | After reset | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | | | Function | TB0FF1 contro<br>00: Invert<br>01: Set<br>10: Clear | ol | TB0FF0 inver 0: Disable 1: Enable Invert when | sion trigger | Invert.when | Invert when | TB0FF0 contro<br>00: Invert<br>01: Set<br>10: Clear | ol | | | | 11: Don't care Note: Always | road as 11 | UC0 is<br>loaded into | UC0 is loaded into | UC0<br>matches | UC0<br>matches | 11: Don't care | road as 11 | | | | • | | TB0CP1H/L. | TB0CP0H/L. | TB0RG1H/L. | TB0RG0H/L. | | | | TB1FFCR | Bit symbol | TB1FF1C1 | TB1FF1C0 | TB1C1T1 | TB1C0T1 | TB1E1T1 | TB1E0T1 | TB1FF0C1 | TB1FF0C0 | | (0193H) | Read/Write | | <i>l</i> * | | | W | 1 | V | | | | After reset | 1 | 1 | 0 | 0 | 0 | 0 | (1) | 1 | | | | TB1FF1 control<br>00: Invert<br>01: Set | | 0: Disable<br>1: Enable | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | TB1FF0 control<br>00: Invert<br>01: Set | | | | Function | 10: Clear<br>11: Don't care | | Invert when UC1 is loaded into | Invert when UC1 is loaded into | Invert when UC1 matches | Invert when<br>UC1<br>matches | 10: Clear<br>11: Don't care | | | | | Note: Always | read as 11. | TB1CP1H/L. | TB1CP0H/L. | TB1RG1H/L. | TB1RG0H/L. | Note: Always | ead as 11. | | TB2FFCR | Bit symbol | TB2FF1C1 | TB2FF1C0 | TB2C1T1 | TB2C0T1 | TB2E1T1 | TB2E0T1 | TB2FF0C1 | TB2FF0C0 | | (01A3H) | Read/Write | V | <i>l</i> * | | R | W | | V | <i>l</i> * | | | After reset | 1 | 1 | 0 | V 0 // | 0 | 0 | 1 | 1 | | | Function | TB2FF1 contro<br>00: Invert<br>01: Set<br>10: Clear | ol | TB2FF0 inver<br>0: Disable<br>1: Enable | | | | TB2FF0 contro<br>00: Invert<br>01: Set<br>10: Clear | ol | | | Function | 11: Don't care | | Invert when UC2 is loaded into | Invert when<br>UC2 is<br>loaded into | Invert when UC2 matches | Invert when<br>UC2<br>matches | 11: Don't care | | | | | Note: Always | read as 11. | TB2CP1H/L. | TB2CP0H/L. | TB2RG1H/L. | TB2RG0H/L. | Note: Always | ead as 11. | | TDOFFOR | Bit symbol | TB3FF1C1 | TB3FF1C0 | TB3C1T1 | TB3C0T1 | TB3E1T1 | TB3E0T1 | TB3FF0C1 | TB3FF0C0 | | TB3FFCR<br>(01B3H) | Read/Write | // ) <u>v</u> | /* | A (C//A) R/W | | | | ٧ | /* | | . , | After reset | 1// | <b>√</b> 1 | 0 | $\bigg) \bigg)$ | 0 | 0 | 1 | 1 | | | | TB3FF1 contro<br>00: Invert<br>01: Set | ol < | TB3FF0 inver<br>0: Disable<br>1: Enable | sion trigger | | | TB3FF0 control 00: Invert 01: Set | | | _ | Function | 10: Clear<br>11: Don't care<br>Note: Always | read as 11. | Invert when UC3 is loaded into TB3CP1H/L. | Invert when UC3 is loaded into TB3CP0H/L. | Invert when UC3 matches TB3RG1H/L. | Invert when UC3 matches TB3RG0H/L. | 10: Clear 11: Don't care Note: Always | read as 11. | | | | | | | | <u>I</u> | | | | Page 130 2007-12-03 ## TMRB Flip-Flop Control Register (Read-modify-write instructions are prohibited.) (2/2) TB4FFCR (01C3H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---------------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------|---------------------------------------------|---------------------------------------------|----------| | Bit symbol | TB4FF1C1 | TB4FF1C0 | TB4C1T1 | TB4C0T1 | TB4E1T1 | TB4E0T1 | TB4FF0C1 | TB4FF0C0 | | Read/Write | V | V* | R/W | | | | W* | | | After reset | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | | | TB4FF1 contr<br>00: Invert<br>01: Set | ol | TB4FF0 inversions of the second secon | sion trigger | | | TB4FF0 contr<br>00: Invert<br>01: Set | ol | | Function | 10: Clear<br>11: Don't care<br>Note: Always | | Invert when UC4 is loaded into TB4CP1H/L. | Invert when UC4 is loaded into TB4CP0H/L. | Invert when UC4 matches TB4RG1H/L. | Invert when<br>UC4<br>matches<br>TB4RG0H/L. | 10: Clear<br>11: Don't care<br>Note: Always | | <TBnFF0C1:0>Timer flip-flop (TBnFF0) control | 00 | Invert TBnFF0. | |----|--------------------| | 01 | Set TBnFF0 to 1, | | 10 | Clear TBnFF0 to 0. | | 11 | Don't care | | | 01 | <TBnE0T1> TBnFF0 inversion when UCn matches TBnRG0H/L | <tbne0t1></tbne0t1> | 0 | Disable trigger (disable inversion). | |---------------------|---|--------------------------------------| | | 1 | Enable trigger (enable inversion). | <TBnE1T1> TBnFF0 inversion when UCn matches TBnRG1H/L | <trnf1t1></trnf1t1> | 0 | Disable trigger (disable inversion). | |---------------------|---|--------------------------------------| | CIDIL III | | Enable trigger (enable inversion). | <TBnC0T1> TBnFF0 inversion when UCn is loaded into TBnCP0H/L | <tbnc0t1></tbnc0t1> | 0 | Disable trigger (disable inversion). | |---------------------|-----|--------------------------------------| | CIDIICOT12 | / 1 | Enable trigger (enable inversion). | <TBnC1T1> TBnFF0 inversion when UCn is loaded into TBnCP1H/L | <tbng1t1></tbng1t1> | 0 (( | Disable trigger (disable inversion). | |---------------------|------|--------------------------------------| | CIDIOTIIS | 1 | Enable trigger (enable inversion). | <TBnFF1C1:0>Timer flip-flop (TBnFF1) control | | 00 | Invert TBnFF1. | |----------------|----|--------------------| | √ TBnFF1C1:0> | 01 | Set TBnFF1 to 1. | | CIBIII I IOI.0 | 10 | Clear TBnFF1 to 0. | | | 11 | Don't care | | | | | Note: n=0,1,2,3,4 Page 131 2007-12-03 ## 7.4 Operation in Each Mode ### 7.4.1 16-Bit Interval Timer Mode Generating interrupts at fixed intervals In this example the interrupt INTTB01 is set to be generated at fixed intervals. The interval time is set in the timer register TB0RG1H/L. Note: X: Don't care, -: No change ### 7.4.2 16-Bit Event Counter Mode If the external clock (TB0IN0 pin input) is selected as the input clock in 16-bit timer mode, the timer can be used as an event counter. The up-counter counts up on the rising edge of TB0IN0 input. To read the value of the counter, first perform software capture once, then read the captured value. Note 1: X: Don't care, -: No change Note 2: When the timer is used as an event counter, set the prescaler to run mode (TB0RUN<TB0PRUN> = 1). Page 132 2007-12-03 ## 7.4.3 16-Bit Programmable Pulse Generation (PPG) Output Mode Square wave pulses can be generated at any frequency and duty ratio. The output pulse may be either active-Low or active-High. In PPG mode a match between the value of the up-counter UC0 and either timer register TB0RG0 or TB0RG1 inverts the output value for timer flip-flop TB0FF0. The TB0FF0 output value is output on TB0OUT0. In this mode the following conditions must be satisfied. (value set in TB0RG0) < (value set in TB0RG1) Figure 7-2 Programmable Pulse Generation (PPG) Output Waveforms When the TB0RG0 double buffer is enabled in this mode, the value of register buffer 0 will be shifted into TB0RG0 when the up-counter value matches TB0RG1. This feature facilitates the handling of low-duty waves. Figure 7-3 Operation of Register Buffer Note: The values that can be set in TBxRGx range from 0001h to 0000h (equivalent to 10000h). If the maximum value 0000h is set, the match-detect signal goes active when the up-counter overflows. Page 133 2007-12-03 The following block diagram illustrates this mode. Figure 7-4 Block Diagram of 16-Bit PPG Mode The following example shows how to set 16-bit PPG output mode: Page 134 2007-12-03 ## 7.4.4 Capture function examples Used capture function, they can be applicable in many ways, for example: - 1. One-shot pulse output from external trigger pulse - 2. Frequency measurement - 3. Pulse width measurement - 4. Time difference measurement ### 7.4.4.1 One-shot pulse output from external trigger pulse Set the up counter UC0 in free-running mode with the internal input clock, input the external trigger pulse from TB0IN0 pin, and load the value of up-counter into capture register TB0CP0H/L at the rise edge of the TB0IN0 pin. When the interrupt INT5 is generated at the rise edge of TB0IN0 input, set the TB0CP0H/L value (c) plus a delay time (d) to TB0RG0H/L (= c + d), and set the above set value (c + d) plus a one-shot width (p) to TB0RG1H/L (= c + d + p). And, set "11" to timer flip-flop control register TB0FFCR<TB0E1T1, TB0E0T1>. Set to trigger enable for be inverted timer flip-flop TB0FF0 by UC0 matching with TB0RG0H/L and with TB0RG1H/L. When interrupt INTTB01 occurs, this inversion will be disabled after one-shot pulse is output. The (c), (d) and (p) correspond to c, d and p Figure 7-5. Figure 7-5 One-shot Pulse Output (with delay) Page 135 2007-12-03 Example: To output a 2-ms one-shot pulse with a 3-ms delay to the external trigger pulse to the TB0IN0 pin. | | | | | | * C | lock s | tate | | | System clock: High frequency (fc) | | |------------------|--------------|--------|------|------|-----------------------------|--------|------|-----|---------------|---------------------------------------------------------------------------------------------------------------------|---| | | | | | | | | | | | Clock gear: 1 (fc) | | | | | | | | | | | | | Prescaler clock: f <sub>FPH</sub> | | | TB0MOD | <b>←</b> | х | X | 1 | 0 | 1 | 0 | 0 | 1 | Set free running. Count with \$T1. Load the up counter value into TB0CP0H/L at the rising edge of TB0IN0 pin input. | | | TB0FFCR | ← | Χ | Χ | 0 | 0 | 0 | 0 | 1 | 0 | Clear TB0FF0 to 0. Disable inversion of TB0FF0. | | | P8CR | <b>←</b> | - | _ | _ | _ | _ | 1 | _ | - | Set P82 to function as the TB0OUT0 pin. | | | P8FC | ← | _ | _ | _ | _ | _ | 1 | _ | _ | Set P80 to TB0IN0 input mode. | | | INTE56 | <b>←</b> | Χ | _ | _ | _ | Х | 1 | 0 | 0 | Enable INT5. | | | INTETB0 | <b>←</b> | Χ | 0 | 0 | 0 | Х | 0 | 0 | 0 | Disable INTTB00 and INTTB01. | > | | TB0RUN | <b>←</b> | _ | 0 | Х | Χ | _ | 1 | Х | 1 | Start TMRB0. | ١ | | TB0RG0<br>TB0RG1 | ←<br>← | | | | ns/φT <sup>r</sup><br>ns/φT | | | | | | 1 | | TB0FFCR | <b>←</b> | Х | X | _ | _ | 1 | 1 | _ | _ | Enable TB0FF0 inversion when the up counter value match with TB0RG0H/L or TB0RG1H/L. | | | INTETB0 | ← | Х | 1 | 0 | 0 | Х | - | - | - | Enable INTTB01. | | | TB0FFCR | <b>←</b> | Х | Х | - | - | 0 | 0 | - ( | ( | Disable inversion of TB0FF0 when the up counter value match with value of TB0RG0H/L or TB0RG1H/L. | | | INTETB0 | $\leftarrow$ | Χ | 0 | 0 | 0 | Χ | - | _ | 1- | Disable INTTB01. | | | Note: | X: Do | on't c | are, | –: N | o cha | ange | | | $\mathcal{L}$ | | | When delay time is unnecessary, invert timer flip-flop TB0FF0 when up-counter value is loaded into capture register (TB0CP0H/L), and set the TB0CP0H/L value (c) plus the one-shot pulse width (p) to TB0RG1H/L when the interrupt INT5 occurs. The TB0FF0 inversion should be enable when the up counter (UC10) value matches TB0RG1H/L, and disabled when generating the interrupt INTTB01. Figure 7-6 One-shot Pulse Output (without delay) Page 136 2007-12-03 ### 7.4.4.2 Frequency measurement The frequency of the external clock can be measured in this mode. The clock is input through the TB0IN0 pin, and its frequency is measured by the 8-bit timers TMRA01 and the 16-bit timer/event counter (TMRB0). (TMRA01 is used to setting of measurement time by inversion TA1FF.) The TB0IN0 pin input should be for the input clock of TMRB0. Set to TB0MOD <TB0CPM1:0> = "11". The value of the up counter (UC10) is loaded into the capture register TB0CP0H/L at the rise edge of the timer flip-flop TA1FF of 8-bit timers (TMRA01), and into TB0CP1H/L at its fall edge. The frequency is calculated by difference between the loaded values in TB0CP0H/L and TB0CP1H/L when the interrupt (INTTA0 or INTTA1) is generates by either 8-bit timer. Figure 7-7 Frequency Measurement For example, if the value for the level 1 width of TA1FF of the 8-bit timer is set to 0.5 s and the difference between the values in TB0CP0H/L and TB0CP1H/L is 100, the frequency is $100 \div 0.5 \text{ s} = 200 \text{ Hz}$ . Note: The frequency in this example is calculated with 50 duty. Page 137 2007-12-03 ### 7.4.4.3 Pulse width measurement This mode allows to measure the high-level width of an external pulse. While keeping the 16-bit timer/event counter counting (Free running) with the internal clock input, external pulse is input through the TB0IN0 pin. Then the capture function is used to load the UC0 values into TB0CP0H/L and TB0CP1H/L at the rising edge and falling edge of the external trigger pulse respectively. The interrupt INT5 occurs at the falling edge of TB0IN0. The pulse width is obtained from the difference between the values of TB0CP0H/L and TB0CP1H/L and the internal clock cycle. For example, if the internal clock is $0.8~\mu s$ and the difference between TB0CP0H/L and TB0CP1H/L is 100, the pulse width will be $100 \times 0.8~\mu s = 80~\mu s$ . Additionally, the pulse width which is over the UCO maximum count time specified by the clock source, can be measured by changing software. Figure 7-8 Pulse Width Measurement Note: Only in this pulse width measuring mode (TB0MOD<TB0CPM1:0> = 10), external interrupt INT5 occurs at the falling edge of TB0IN0 pin input. In other modes, it occurs at the rising edge. The width of low-level can be measured from the difference between the first C2 and the second C1 at the second INT5 interrupt. Page 138 2007-12-03 ### 7.4.4.4 Time Difference Measurement This mode is used to measure the difference in time between the rising edges of external pulses input through TB0IN0 and TB0IN1. Keep the 16-bit timer/event counter (TMRB0) counting (Free running) with the internal clock, and load the UC0 value into TB0CP0H/L at the rising edge of the input pulse to TB0IN0. Then the interrupt INT5 is generated. Similarly, the UC0 value is loaded into TB0CP1H/L at the rising edge of the input pulse to TB0IN1, generating the interrupt INT6. The time difference between these pulses can be obtained by multiplying the value subtracted TB0CP0H/L from TB0CP1H/L and the internal clock cycle together at which loading the up counter value into TB0CP0H/L and TB0CP1H/L has been done. Figure 7-9 Time Difference Measurement Page 139 2007-12-03 # 8. Serial Channels (SIO) TMP91CW60 includes 3 serial I/O channels. For both channels either UART mode (Asynchronous transmission) or I/O interface mode (Synchronous transmission) can be selected. - 1. I/O interface mode - Mode 0: For transmitting and receiving I/O data using the synchronizing signal SCLK for extending I/O. - 2. UART mode - Mode 1: 7-bit data - Mode 1: 8-bit data - Mode 1: 9-bit data In mode 1 and mode 2, a parity bit can be added. Mode 3 has a wakeup function for the master controller to start slave controllers via a serial link (A multi-controller system). Figure 8-2 are block diagrams for each channel. SIO is compounded mainly prescaler, serial clock generation circuit, receiving buffer and control circuit, transmission buffer and control circuit. Both channels operate in the same function except for the following points; hence only the operation of channel 0 is explained below. Table 8-1 Differences in Serial Channel Specifications | | \$100 | SIO1 | SIO2 | |----------|--------------------------|--------------------------|--------------------------| | Pin name | TXD0 (P90)<br>RXD0 (P91) | TXD1 (P93)<br>RXD1 (P94) | TXD2 (P41)<br>RXD2 (P42) | | | CTS0/SCLK0 (P92) | CTS1/SCLK1 (P95) | CTS2/SCLK2 (P43) | Figure 8-1 Data Formats Page 140 2007-12-03 #### 8.1 **Block Diagrams** Figure 8-2 Block Diagram of the Serial Channel 0/1/2 2007-12-03 Page 141 ## 8.2 Operation of Each Circuit ## 8.2.1 Prescaler A 6-bit prescaler generates an operation clock for SIO0. The prescaler is active only when a baud rate generator is specified as a serial transfer clock. As an input clock of the prescaler, be sure to set SYSCR0<PRCK1> to "0" and then specify $f_{\text{FPH}}$ . This clock is used for $\phi$ T0 with being divided by 4. Table 8-2 shows prescaler clock resolution into the baud rate generator. Table 8-2 Prescaler Clock Resolution to Baud Rate Generator | Select System Clock | Gear Value | Select Prescaler Clock | Prescaler Output Clock Resolution | | | | | | |---------------------|---------------------|------------------------|-----------------------------------|--------------------|---------------------|---------------------|--|--| | <sysck></sysck> | <gear2:0></gear2:0> | <prck1></prck1> | φТО | фТ2 | φТ8 | фТ32 | | | | 1 (fs) | XXX | | 2 <sup>2</sup> /fs | 2 <sup>4</sup> /fs | 2 <sup>6</sup> /fs | 2 <sup>8</sup> /fs | | | | | 000 (fc) | | 2 <sup>2</sup> /fc | 2 <sup>4</sup> /fc | 2 <sup>6</sup> /fc | 2 <sup>8</sup> /fc | | | | | 001 (fc/2) | 0 (1/1) | 2 <sup>3</sup> /fc | 2 <sup>5</sup> /fc | 2 <sup>7</sup> /fe | 2 <sup>9</sup> /fc | | | | 0 (fc) | 010 (fc/4) | f <sub>FPH</sub> | 2 <sup>4</sup> /fc | 2 <sup>6</sup> /fc | 2 <sup>8</sup> /fc | 2 <sup>10</sup> /fc | | | | | 011 (fc/8) | | 2 <sup>5</sup> /fc | 2 <sup>7</sup> /fc | 2 <sup>9</sup> /fc | 2 <sup>11</sup> /fc | | | | | 100 (fc/16) | | 2 <sup>6</sup> /fc | 2 <sup>8</sup> /fc | 2 <sup>10</sup> /fc | 2 <sup>12</sup> /fc | | | The baud rate generator selects between 4 clock inputs: $\phi T0$ , $\phi T2$ , $\phi T8$ , and $\phi T32$ among the prescaler outputs. ## 8.2.2 Baud rate generator The baud rate generator is a circuit which generates transmission and receiving clocks which determine the transmission rate of the serial channels. The input clock to the baud rate generator, $\phi T0$ , $\phi T2$ , $\phi T8$ or $\phi T32$ , is generated by the 6-bit prescaler which is shared by the timers. One of these input clocks is selected using the BR0CR<BR0CK1:0> field in the baud rate generator control register. The baud rate generator includes a frequency divider, which divides the frequency by 1, N + (16 - K)/16 or 16 values, determining the transmission rate. The transmission rate is determined by the settings of BR0CR<BR0ADDE><BR0S3:0> and BR0ADD<BR0K3:0>. Page 142 2007-12-03 #### 8.2.2.1 In UART mode #### (1) When BROCR < BROADDE > = 0 The settings BR0ADD<BR0K3:0> are ignored. The baud rate generator divides the selected prescaler clock by N, which is set in BR0CK<BR0S3:0>. (N = 1, 2, 3 ... 16) #### (2) When BR0CR<BR0ADDE> = 1 The N + (16 - K)/16 division function is enabled. The baud rate generator divides the selected prescaler clock by N + (16 - K)/16 using the value of N set in BR0CR<BR0S3:0> (N = 2, 3 ... 15) and the value of K set in BR0ADD<BR0K3:0> (K = 1, 2, 3 ... 15) Note: If N = 1 and N = 16, the N + (16 - K)/16 division function is disabled. Set BR0CR<BR0ADDE> to "0" ## 8.2.2.2 In I/O interface mode The N + (16 - K)/16 division function is not available in I/O interface mode. Set BR0CR<BR0ADDE> to "0" before dividing by N. The method for calculating the transmission rate when the baud rate generator is used is explained below. (1) In UART mode Baud rate = Input clock of baud rate generator Frequency divider for baud rate generator ÷ 16 (2) In I/O interface mode Baud rate = $\frac{\text{Input clock of baud rate generator}}{\text{Frequency divider for baud rate generator}} \div 2$ ## 8.2.2.3 Integer divider (N divider) For example, when the source clock frequency (fc) =19.6608 MHz, the input clock frequency = $\phi$ T2 (fc/16), the frequency divider N (BR0CR<BR0S3:0>) = 8, and BR0CR<BR0ADDE> = 0, the baud rate in UART mode is as follows: Clock gear: 1 (fc) Prescaler clock: $f_{\text{FPH}}$ Baudrate= $$\frac{\text{fc/16}}{8} \div 16$$ = $19.6608 \times 10^6 \div 16 \div 8 \div 16 = 9600 \text{ (bps)}$ Note: The + (16 - K)/16 division function is disabled and setting BR0ADD<BR0K3:0> is invalid. Page 143 2007-12-03 ## 8.2.2.4 N + (16 - K)/16 divider (UART mode only) Accordingly, when the source clock frequency (fc) = 15.9744 MHz, the input clock frequency = $\phi$ T2, the frequency divider N (BR0CR<BR0S3:0>) = 6, K (BR0ADD<BR0K3:0>) = 8, and BR0CR<BR0ADDE> = 1, the baud rate in UART mode is as follows: \*Clock state System clock: High frequency (fc) Clock gear: 1 (fc) Prescaler clock: f<sub>FPH</sub> = $$15.9744 \times 10^6 \div 16 \div \left(6 + \frac{8}{16}\right) \div 16 = 9600 \text{(bps)}$$ Table 8-3 show examples of UART mode transfer rates. Additionally, the external clock input is available in the serial clock. The method for calculating the baud rate is explained below: - In UART mode Baud rate = External clock input frequency ÷ 16 It is necessary to satisfy (External clock input cycle) ≥ 4/f<sub>SYS</sub> - In I/O interface mode Baud rate = External clock input frequency It is necessary to satisfy (External clock input cycle) ≥ 16/f<sub>SYS</sub> Table 8-3 UART Baud Rate Selection (When baud rate generator is used and BR0CR<BR0ADDE>=0, SYSCR0<PRCK>=0) Unit (kbps) | fc [MHz] | Frequency Divider N | φT0<br>(fc/4) | φT2<br>(fc/16) | φT8<br>(fc/64) | φT32<br>(fc/256) | |---------------|---------------------|---------------|----------------|----------------|------------------| | 7.3728 | 1 | 115.200 | 28.800 | 7.200 | 1.800 | | <b>↑</b> | 3 | 38.400 | 9.600 | 2.400 | 0.600 | | <b>↑</b> | 6 | 19.200 | 4.800 | 1.200 | 0.300 | | ↑ <b>&gt;</b> | Α | 11.520 | 2.880 | 0.720 | 0.180 | | 1 | o | 9.600 | 2.400 | 0.600 | 0.150 | | <b>↑</b> (( ) | F | 7.680 | 1.920 | 0.480 | 0.120 | | 9.8304 | | 153.600 | 38.400 | 9.600 | 2.400 | | | 2 | 76.800 | 19.200 | 4.800 | 1.200 | | <u></u> | 4 | 38.400 | 9.600 | 2.400 | 0.600 | | | 5 | 30.720 | 7.680 | 1.920 | 0.480 | | <b>↑</b> | 8 | 19.200 | 4.800 | 1.200 | 0.300 | | <b>↑</b> | 10 | 9.600 | 2.400 | 0.600 | 0.150 | Note: Transmission rates in I/O interface mode are eight times faster than the values given above. Page 144 2007-12-03 Timer out clock (TA0TRG) can be used for source clock of UART mode only. Calculation method the frequency of TA0TRG Frequency of TA0TRG = Baud rate $\times$ 16 Note: In case of I/O interface mode, prohibit to use TA0TRG for source clock. ## 8.2.3 Serial clock generation circuit This circuit generates the basic clock for transmission and receiving data. #### 8.2.3.1 In I/O interface mode In SCLK output mode with the setting SC0CR<IOC> = "0", the basic clock is generated by dividing the output of the baud rate generator by 2, as described previously. In SCLK input mode with the setting SC0CR<IOC> = "1", the rising edge or falling edge will be detected according to the setting of the SC0CR<SCLKS> register to generate the basic clock. #### 8.2.3.2 In UART mode The SC0MOD0<SC1:0> setting determines whether the baud rate generator clock, the internal system clock $f_{SYS}$ , the match detect signal from timer TMRA0 or the external clock (SCLK0) is used to generate the basic clock SIOCLK. ## 8.2.4 Receiving counter The receiving counter is a 4-bit binary counter used in UART mode which counts up the pulses of the SIO-CLK clock. It takes 16 SIOCLK pulses to receive 1 bit of data; each data bit is sampled three times – on the 7th, 8th and 9th clock cycles. The value of the data bit is determined from these three samples using the majority rule. For example, if the data bit is sampled respectively as "1", "0" and "1" on 7th, 8th and 9th clock cycles, the received data bit is taken to be "1". A data bit sampled as "0", "0" and "1" is taken to be "0". ## 8.2.5 Receiving control ## 8.2.5.1 In I/O interface mode In SCLK output mode with the setting SC0CR<IOC> = "0", the RXD0 signal is sampled on the rising or falling edge of the shift clock which is output on the SCLK0 pin, according to the SC0CR<SCLKS> setting. In SCLK input mode with the setting SC0CR<IOC> = "1", the RXD0 signal is sampled on the rising or falling edge of the SCLK0 input, according to the SC0CR<SCLKS> setting. #### 8.2.5.2 In UART mode The receiving control block has a circuit which detects a start bit using the majority rule. Received bits are sampled three times; when two or more out of three samples are "0", the bit is recognized as the start bit and the receiving operation commences. The values of the data bits that are received are also determined using the majority rule. Page 145 2007-12-03 ## 8.2.6 Receiving buffers To prevent overrun errors, the receiving buffers are arranged in a double-buffer structure. Received data is stored one bit at a time in receiving buffer 1 (which is a shift register). When 7 or 8 bits of data have been stored in receiving buffer 1, the stored data is transmitted to receiving buffer 2 (SC0BUF); this causes an INTRX0 interrupt to be generated. The CPU only reads receiving buffer 2 (SC0BUF). Even before the CPU reads receiving buffer 2 (SC0BUF), the received data can be stored in receiving buffer 1. However, unless receiving buffer 2 (SC0BUF) is read before all bits of the next data are received by receiving buffer 1, an overrun error occurs. If an overrun error occurs, the contents of receiving buffer 1 will be lost, although the contents of receiving buffer 2 and SC0CR<RB8> will be preserved. SCOCR<RB8> is used to store either the parity bit – added in 8-bit UART mode – or the most significant bit (MSB) – in 9-bit UART mode. In 9-bit UART mode the wakeup function for the slave controller is enabled by setting SC0MOD0<WU> to "1"; in this mode INTRX0 interrupts occur only when the value of SC0CR<RB8> is "1". Note 1: The double buffer structure does not support SC0CR<RV08> Note 2: If the CPU reads receive buffer 2 while data is being transferred from receive buffer 1 to receive buffer 2, the data may not be read properly. To avoid this situation, a read of receive buffer 2 should be triggered by a receive interrupt. #### 8.2.7 Transmission counter The transmission counter is a 4-bit binary counter which is used in UART mode and which, like the receiving counter, counts the SIOCLK clock pulses; a TXDCLK pulse is generated every 16 SIOCLK clock pulses. Figure 8-3 Generation of the Transmission Clock ## 8.2.8 Transmission controller ### 8.2.8.1 In I/O interface mode In SCLK output mode with the setting SCOCR<IOC> = "0", the data in the transmission buffer is output one bit at a time to the TXDO pin on the rising or falling edge of the shift clock which is output on the SCLKO pin, according to the SCOCR<SCLKS> setting. In SCLK input mode with the setting SCOCR<IOC> = "1", the data in the transmission buffer is output one bit at a time on the TXDO pin on the rising or falling edge of the SCLKO input, according to the SCOCR<SCLKS> setting. #### 8.2.8.2 In UART mode When transmission data sent from the CPU is written to the transmission buffer, transmission starts on the rising edge of the next TXDCLK. Page 146 2007-12-03 #### 8.2.8.3 Handshake function Use of CTSO pin allows data can be sent in units of one frame; thus, overrun errors can be avoided. The handshake function is enabled or disabled by the SCOMODO<CTSE> setting. When the $\overline{\text{CTS0}}$ pin goes high on completion of the current data send, data transmission is halted until the $\overline{\text{CTS0}}$ pin goes low again. However, the INTTX0 interrupt is generated, it requests the next data send to the CPU. The next data is written in the transmission buffer and data transmission is halted. Though there is no $\overline{RTS}$ pin, a handshake function can be easily configured by setting any port assigned to be the $\overline{RTS}$ function. The $\overline{RTS}$ should be output "high" to request send data halt after data receive is completed by software in the $\overline{RXD}$ interrupt routine. Figure 8-4 Handshake Function Note 1: If the CTS0 signal goes high during transmission, no more data will be sent after completion of the current transmission. Note 2: Transmission starts on the first falling edge of the TXDCLK clock after the CTS0 signal has fallen. Figure 8-5 CTS0 (Clear to send) Timing Page 147 2007-12-03 TOSHIBA TMP91CW60 #### 8.2.9 Transmission buffer The transmission buffer (SC0BUF) shifts out and sends the transmission data written from the CPU from the least significant bit (LSB) in order. When all the bits are shifted out, the transmission buffer becomes empty and generates an INTTX0 interrupt. ## 8.2.10 Parity control circuit When SCOCR<PE> in the serial channel control register is set to "1", it is possible to transmit and receive data with parity. However, parity can be added only in 7-bit UART mode or 8-bit UART mode. The SCOCR<EVEN> field in the serial channel control register allows either even or odd parity to be selected. In the case of transmission, parity is automatically generated when data is written to the transmission buffer SC0BUF. The data is transmitted after the parity bit has been stored in SC0BUF<TB7> in 7-bit UART mode or in SC0MOD0<TB8> in 8-bit UART mode. SC0CR<PE> and SC0CR<EVEN> must be set before the transmission data is written to the transmission buffer. In the case of receiving, data is shifted into receiving buffer 1, and the parity is added after the data has been transmitted to receiving buffer 2 (SC0BUF), and then compared with SC0BUF<RB7> in 7-bit UART mode or with SC0CR<RB8> in 8-bit UART mode. If they are not equal, a parity error is generated and the SC0CR<PERR> flag is set. ## 8.2.11 Error flags Three error flags are provided to increase the reliability of data reception. ## 8.2.11.1 Overrun error <OERR> If all the bits of the next data item have been received in receiving buffer 1 while valid data still remains stored in receiving buffer 2 (SC0BUF), an overrun error is generated. The below is a recommended flow when the overrun error is generated. (INTRX interrupt routine) - 1. Read receiving buffer - 2. Read error flag - 3. if $\langle OERR \rangle = 1$ - a. Set to disable receiving (Write "0" to SC0MOD0<RXE>) - b. Wait to terminate current frame - c. Read receiving buffer - d. Read error flag - e. Set to enable receiving (Write "1" to SC0MOD0<RXE>) - f. Request to transmit again - 4. Other Note: Overrun errors are generated only with regard to receive buffer 2 (SC0BUF). Thus, if SC0CR<RB8> is not read, no overrun error will occur. Page 148 2007-12-03 ## 8.2.11.2 Parity error <PERR> The parity generated for the data shifted into receiving buffer 2 (SC0BUF) is compared with the parity bit received via the RXD pin. If they are not equal, a parity error is generated. Note: The parity error flag is cleared every time it is read. However, if a parity error is detected twice in succession and the parity error flag is read between the two parity errors, it may seem as if the flag had not been cleared. To avoid this situation, a read of the parity error flag should be triggered by a receive interrupt. ## 8.2.11.3 Framing error <FERR> The stop bit for the received data is sampled three times around the center. If the majority of the samples are "0", a framing error is generated. ## 8.2.12 Timing generation #### 8.2.12.1 In UART mode Table 8-4 Receiving | | | | (7/) | |----------------------|------------------------------|------------------------------------|---------------------------------| | Mode | 9 Bits | 8 Bits + Parity | 8 Bits, 7 Bits + Parity, 7 Bits | | Interrupt timing | Center of last bit (Bit8) | Center of last bit<br>(Parity bit) | Center of stop bit | | Framing error timing | Center of stop bit | Center of stop bit | Center of stop bit | | Parity error timing | | Center of last bit<br>(Parity bit) | Center of stop bit | | Overrun error timing | Center of last bit<br>(Bit8) | Center of last bit<br>(Parity bit) | Center of stop bit | Note 1: In 9 Bits and 8 Bits + Parity mode, interrupts coincide with the ninth bit pulse. Thus, when servicing the interrupt, it is necessary to wait for a 1-bit period (to allow the stop bit to be transferred) to allow checking for a framing error. Note 2: The higher the transfer rate, the later than the middle receive interrupts and errors occur. Table 8-5 Transmitting | Mode | 9 Bits | 8 Bits + Parity | 8 Bits, 7 Bits + Parity, 7 Bits | |------------------|------------------------------------------|-------------------------------------|-------------------------------------| | Interrupt timing | Just before stop bit is trans-<br>mitted | Just before stop bit is transmitted | Just before stop bit is transmitted | ## 8.2.12.2 I/O interface | Transmission interrupt | SCLK output mode | Immediately after the last bit. (See Figure 8-8) | | | |------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------|--|--| | timing | SCLK input mode | Immediately after rise of last SCLK signal rising mode, or immediately after fall in falling mode. (See Figure 8-9) | | | | Receiving interrupt | SCLK output mode | Timing used to transmit received data to receive buffer 2 (SC0BUF) (e.g., immediately after last SCLK). (See Figure 8-10) | | | | timing | SCLK input mode | Timing used to transmit received data to receive buffer 2 (SC0BUF) (e.g., immediately after last SCLK). (See Figure 8-11) | | | Page 149 2007-12-03 ## 8.3 SFR Serial Control Register (Read-modify-write instructions are prohibited.) SC0CR (0201H) SC1CR SC2CR (0211H) (0209H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------------------|-----------------------------|--------------------------------------|------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------| | Bit symbol | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC | | Read/Write | R | R | /W | R (Cle | eared to "0" whe | n read) | R | W | | After reset | Undefined | 0 | 0 | 0 | 0 | 0 | ) > 0 | 0 | | Function | Received data bit8 | Parity<br>0: Odd<br>1: Even | Parity addition 0: Disable 1: Enable | Overrun error flag 0: Undetect error 1: Detect error | Parity error flag 0: Undetect error 1: Detect error | Framing<br>error flag<br>0: Undetect<br>error<br>1: Detect<br>error | Edge selection for SCLK pin (I/O mode) 0: SCLK↑ 1: SCLK↓ | I/O interface<br>input clock<br>selection<br>0: Baud rate<br>generator<br>1: SCLK<br>pin input | Note1: As all error flags are cleared after reading, do not test only a single bit with a bit-testing instruction. Note2: A baud rate generator SCnCR<IOC> = "0" is unavailable as an input clock for an I/O interface if a prescaler clock is set to fc/16 whenSYSCR0<PRCK1> is "1". Note3: n =0, 1, 2. ## Serial Mode Control Register 0 SC0MOD0 (0202H) SC1MOD0 (020AH) SC2MOD0 (0212H) | | 7 | 6 | 5 < | 4 | 3 | (2) | 1 | 0 | |-------------|--------------------------------|-----------------------------------------|------------------------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------| | Bit symbol | TB8 | CTSE | RXE | WU | SM1 | SMO | SC1 | SC0 | | Read/Write | | | | R | w_ ( | 7 () | | | | After reset | 0 | 0 | 40 | 0 / | 0 | 0 | 0 | 0 | | Function | Transmis-<br>sion data<br>bit8 | Handshake function 0: Disable 1: Enable | Receive<br>function<br>0: Disable<br>1: Enable | Wakeup<br>function<br>0: Disable<br>1: Enable | Serial transmi<br>00: I/O interfa<br>01: 7-bit UAR<br>10: 8-bit UAR<br>11: 9-bit UAR | ce mode<br>T mode<br>T mode | Serial transmi<br>(UART)<br>00: Timer TA0<br>01: Baud rate<br>10: Internal cl<br>11: External cl<br>(SCLK inpu | TRG<br>generator<br>ock f <sub>SYS</sub><br>lock | Note1: SCLKpin and CTS pin | | SCLK pin | CTS pin | |------|----------|---------| | SIO0 | SCLKO | CTS0 | | SIO1 | SCLK1 | CTS1 | | SIO2 | SCLK2 | CTS2 | Note2: A baud rate generator SCnMOD0<SC1:0> = "01" is unavailable as a serial transfer clock if a prescaler clock is set to fc/16 whenSYSCR0<PRCK1> is "1". Note3: n =0, 1, 2. ## Serial Mode Control Register 1 SC0MOD1 (0205H) SC1MOD1 SC2MOD1 (0215H) (020DH) | | 7 🗸 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----------------------------|------------------------------|---|---|---|---|---|---| | Bit symbol | 1280 | FDPX0 | - | _ | - | - | - | _ | | Read/Write | R/W | R/W | _ | - | _ | - | - | - | | After reset | 0 | 0 | - | - | - | - | - | - | | Bit symbol | I2S1 | FDPX1 | _ | _ | _ | _ | _ | _ | | Read/Write | R/W | R/W | - | _ | - | - | - | - | | After reset | 0 | 0 | _ | - | _ | - | _ | - | | Bit symbol | 12S2 | FDPX2 | - | - | - | - | - | - | | Read/Write | R/W | R/W | _ | - | _ | - | _ | - | | After reset | 0 | 0 | - | - | - | - | - | - | | Function | IDLE2<br>0: Stop<br>1: Run | Duplex<br>0: Half<br>1: Full | | | | | | | Page 150 2007-12-03 #### **Baud Rate Generator Control** BR0CR (0203H) BR1CR (020BH) BR2CR (0213H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------------------|------------------------------------------------------|---------------------------------------------------------------|--------|-------|---------------------|---------------|-------| | Bit symbol | - | BR0ADDE | BR0CK1 | BR0CK0 | BR0S3 | BR0S2 | BR0S1 | BR0S0 | | Read/Write | | • | | R | W | $\wedge$ | | • | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit symbol | - | BR1ADDE | BR1CK1 | BR1CK0 | BR1S3 | BR1S2 | BR1S1 | BR1S0 | | Read/Write | | • | | R | W | | ))~ | • | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit symbol | - | BR2ADDE | BR2CK1 | BR2CK0 | BR2S3 | BR2S2 | BR2S1 | BR2S0 | | Read/Write | | | | R | w | | | | | After reset | 0 | 0 | 0 | 0 | 0 | ) P 0 | 0 | 0 | | Function | Always write "0". | + (16 - K)/16<br>division<br>0: Disable<br>1: Enable | Input clock se baud rate gen 00: φT0 01: φT2 10: φT8 11: φT32 | | | Setting of the divi | ded frequency | N" | BR0ADD (0204H) BR1ADD (020CH) BR2ADD (0214H) | | | | | | | | 90/ | | |-------------|---|-----------|------|--------------|---------------|-------|----------------------------------|-------| | | 7 | 6 | 5 | 4 | 3 | 2 | )1 | 0 | | Bit symbol | - | - | - < | ( ->> | BR0K3 | BR0K2 | BR0K1 | BR0K0 | | Read/Write | - | - | - | //- | | R | /W | | | After reset | _ | - | 7 | <del>-</del> | 0 ( \ | / | 0 | 0 | | Bit symbol | _ | - | 4-/ | > - / | BR1K3 | BR1K2 | BR1K1 | BR1K0 | | Read/Write | - | - | | - (( | | R | /W | | | After reset | - | - ( | 7 | - | 0 | 0 | 0 | 0 | | Bit symbol | _ | - | | - | BR2K3 | BR2K2 | BR2K1 | BR2K0 | | Read/Write | - | <i>F7</i> | | - | | R | /W | | | After reset | _ | - | )) - | | 0 | 0 | 0 | 0 | | Function | | 775 | | | $\rightarrow$ | • | cy divisor "K"<br>+ (16 - K)/16) | | Baud rate generator frequency divisor setting | | | BRnCR <br< th=""><th>nADDE&gt; = 1</th><th>BRnCR<brnadde> = 0</brnadde></th></br<> | nADDE> = 1 | BRnCR <brnadde> = 0</brnadde> | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------|-----------------------------------|------------------------------------------------------| | BRn<br><brn< th=""><th></th><th>0000(N=16)<br/>or<br/>0001(N=1)</th><th>0010(N=2)<br/>to<br/>1111(N=15)</th><th>0001(N=1)UART only<br/>to<br/>1111(N=15)<br/>0000(N=16)</th></brn<> | | 0000(N=16)<br>or<br>0001(N=1) | 0010(N=2)<br>to<br>1111(N=15) | 0001(N=1)UART only<br>to<br>1111(N=15)<br>0000(N=16) | | ) | 0000 | Disable | Disable | | | 7 | 0001 (K = 1)<br>to<br>1111 (K = 15) | Disable | Divided by<br>N + (16 - K)/<br>16 | Divided by N | Note: Availability of +(16 - K)/16 division function | N | UART mode | I/O mode | |---------|-----------|----------| | 2 to 15 | 0 | х | | 1, 16 | х | х | The baud rate generator can be set "1" in UART mode and disable + (16 - $\rm K)/16$ division function. Don't use in I/O interface mode. Note: Set BR1CR<BR1ADDE> to 1 after setting K (K = 1 to 15) to BR1ADD<BR1K3:0> when N+ (16 - K)/16 division function is used. Note: n = 0,1,2 Page 151 2007-12-03 Serial Transmission/receiving Buffer Registers (Read-modify-write instructions are prohibited.) ## 8.4 Operation in Each Mode ## 8.4.1 Mode 0 (I/O interface mode) This mode allows an increase in the number of I/O pins available for transmitting data to or receiving data from an external shift register. This mode includes the SCLK output mode to output synchronous clock SCLK and SCLK input mode to input external synchronous clock SCLK. Figure 8-6 SCLK Output Mode Connection Example Figure 8-7 SCLK Input Mode Connection Example Page 152 2007-12-03 #### 8.4.1.1 Transmission In SCLK output mode 8-bit data and a synchronous clock are output on the TXD0 and SCLK0 pins respectively each time the CPU writes the data to the transmission buffer. When all data is output, INTES0<ITX0C> will be set to generate the INTTX0 interrupt. Figure 8-8 Transmitting Operation in I/O Interface Mode (SCLK output mode) In SCLK input mode, 8-bit data is output on the TXD0 pin when the SCLK0 input becomes active after the data has been written to the transmission buffer by the CPU. When all data is output, INTESO<ITX0C> will be set to generate INTTX0 interrupt. Figure 8-9 Transmitting Operation in I/O Interface Mode (SCLK input mode) Page 153 2007-12-03 ## 8.4.1.2 Receiving In SCLK output mode, the synchronous clock is outputted from SCLK0 pin and the data is shifted to receiving buffer 1. This starts when the receive interrupt flag INTESO<IRX0C> is cleared by reading the received data. When 8-bit data are received, the data will be transmitted to receiving buffer 2 (SC0BUF according to the timing shown below) and INTESO<IRX0C> will be set to generate INTRX0 interrupt. The outputting for the first SCLK0 starts by setting SC0MOD0<RXE> to "1" Figure 8-10 Receiving Operation in I/O Interface Mode (SCLK output mode) In SCLK input mode, the data is shifted to receiving buffer 1 when the SCLK input becomes active after the receive interrupt flag INTESO<IRXOC> is cleared by reading the received data. When 8-bit data is received, the data will be shifted to receiving buffer 2 (SC0BUF according to the timing shown below) and INTESO<IRXOC> will be set again to be generate INTRX0 interrupt. Figure 8-11 Receiving Operation in I/O Interface Mode (SCLK input mode) Note: The system must be put in the receive enable state (SC0MOD0<RXE> = 1) before data can be received. Page 154 2007-12-03 ## 8.4.1.3 Transmission and receiving (Full duplex mode) When the full duplex mode is used, set the level of receive interrupt to "0" and set enable the interrupt level (1 to 6) to the transmission interrupt. In the transmission interrupt program, the receiving operation should be done like the above example before setting the next transmission data. Page 155 2007-12-03 ## 8.4.2 Mode 1 (7-bit UART mode) 7-bit UART mode is selected by setting serial channel mode register SC0MOD0<SM1:0> to "01". In this mode, a parity bit can be added. Use of a parity bit is enabled or disabled by the setting of the serial channel control register SC0CR<PE> bit; whether even parity or odd parity will be used is determined by the SC0CR<EVEN> setting when SC0CR<PE> is set to "1" (Enabled). Example: When transmission data of the following format, the control registers should be set as described below. This explanation applies to channel 0. Page 156 2007-12-03 ## 8.4.3 Mode 2 (8-bit UART mode) 8-bit UART mode is selected by setting SC0MOD0<SM1:0> to "10". In this mode, a parity bit can be added (Use of a parity bit is enabled or disabled by the setting of SC0CR<PE>); whether even parity or odd parity will be used is determined by the SC0CR<EVEN> setting when SC0CR<PE> is set to "1" (Enabled). Example: When receiving data of the following format, the control registers should be set as described below. Page 157 2007-12-03 ## 8.4.4 Mode 3 (9-bit UART mode) 9-bit UART mode is selected by setting SC0MOD0<SM1:0> to "11". In this mode parity bit cannot be added. In the case of transmission, the MSB (9th bit) is written to SC0MOD0<TB8>. In the case of receiving, it is stored in SC0CR<RB8>. When the buffer is written and read, the MSB is read or written first, before the rest of the SC0BUF data. ## 8.4.4.1 Wakeup function In 9-bit UART mode, the wakeup function for slave controllers is enabled by setting SC0MOD0<WU> to "1". The interrupt INTRX0 occurs only when <RB8> = "1". Note: The TXD pin of each slave controller must be in open-drain output mode. Figure 8-14 Serial Link Using Wakeup Function Page 158 2007-12-03 #### 8.4.4.2 Protocol - 1. Select 9-bit UART mode on the master and slave controllers. - 2. Set the SC0MOD0<WU> bit on each slave controller to "1" to enable data receiving. - 3. The master controller transmits one-frame data including the 8-bit select code for the slave controllers. The MSB (Bit8) <TB8> is set to "1". - 4. Each slave controller receives the above frame. Each controller checks the above select code against its own select code. The controller whose code matches clears its WU bit to "0". - 5. The master controller transmits data to the specified slave controller whose SC0MOD0<WU> bit is cleared to "0". The MSB (Bit8) <TB8> is cleared to "0". 6. The other slave controllers (whose <WU> bits remain at "1") ignore the received data because their MSBs (Bit8 or <RB8>) are set to "0", disabling INTRX0 interrupts. The clave controller (WU bit = "0") can treachild data to the master controller and it is possible. The slave controller (WU bit = "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. Page 159 2007-12-03 ## 8.4.4.3 Example To link two slave controllers serially with the master controller using the internal clock $f_{SYS}$ as the transfer clock. ## Main settings (except port setting) | Register | MSB | | | | | 6 | - | ો | SE | |----------|-----|---|-----|---|---|---|---|---|----| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | INTES0 | ← | X | 1 | 0 | 0 | X | 1 | 0 | 1 | | SC0MOD0 | ← | 1 | 0 | 1 | 0 | | 1 | 1 | 0 | | SC0BUF | ← | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 1 | Enable the INTTX0 interrupt and set it to interrupt level 4. Enable the INTRX0 interrupt and set it to interrupt level 5. Set f<sub>SYS</sub> as the transmission clock for 9-bit UART mode. Set the select code for slave controller 1. ## INTTX0 interrupt Register MSB 7 6 5 4 3 2 1 0 SCOMODO COMODO # Main settings (except port setting) ## INTRX0 interrupt | Register | MSB | 3 | | | | | | | LSB | | |-----------------------------|-------|------|--------|----|---|---|---|---|-----|------------------------| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | $Acc \leftarrow SC0BUF, if$ | Acc = | sele | ct coc | le | | | | | | | | then SC0MOD0 | ← | _ | _ | _ | 0 | _ | _ | _ | _ | Clear <wu> to "0"</wu> | Page 160 2007-12-03 # 9. Serial Bus Interface (SBI) The TMP91CW60 has a 2-channel serial bus interface which an $I^2C$ bus mode. This circuit supports only $I^2C$ bus mode (Multi master). The serial bus interface is connected to an external device through SDA0,SCL0,SDA1 and SCL1 in the I<sup>2</sup>C bus mode. # 9.1 Configuration Figure 9-1 Serial Bus Interface (SBI) # 9.2 Serial Bus Interface (SBI) Control The following registers are used to control the serial bus interface and monitor the operation status. - Serial bus interface control register 0 (SBI0CR0, SBI1CR0) - Serial bus interface control register 1 (SBI0CR1, SBI1CR1) - Serial bus interface control register 2 (SBI0CR2, SBI1CR2) - Serial bus interface data buffer register (SBI0DBR, SBI1DBR) - I<sup>2</sup>C bus address register (I2C0AR, I2C1AR) - Serial bus interface status register (SBI0SR, SBI1SR) - IDLE2 control register (SBI0BR, SBI1BR) Page 161 2007-12-03 # 9.3 Operation in I<sup>2</sup>C Bus Mode Both channels operate in the same function except for the following points; hence only the operation of channel 0 is explained below. ## 9.3.1 The Data Formats in the I<sup>2</sup>C Bus Mode The data formats in the I<sup>2</sup>C bus mode is shown below. (a) Addressing format (b) Addressing format (with restart) (c) Free data format (Data transferred from master device to slave device) S : Start condition R/W : Direction bit ACK : Acknowledge bit P : Stop condition Figure 9-2 Data Format in the I<sup>2</sup>C Bus Mode Page 162 2007-12-03 # 9.3.2 I<sup>2</sup>C Bus Mode Control Register The following registers are used to control and monitor the operation status when using the serial bus interface (SBI) in the $I^2C$ bus mode. Serial Bus Interface Control Register 0 (Read-modify-write instructions are prohibited.) SBI0CR0 (0247H) SBI1CR0 (024FH) | | | | | | | $\overline{}$ | | | |-------------|------------------------------------|---|---|---|-----------------|---------------|------|---| | | 7 | 6 | 5 | 4 | 3 | (//2 | 1 | 0 | | Bit symbol | SBI0EN | - | - | - | -// | | - | - | | Read/Write | R/W | | | | R | | | | | After reset | 0 | 0 | 0 | 0 | 0 | <i>)</i> 0 | 0 | 0 | | Bit symbol | SBI1EN | 1 | - | - | | - | _ | - | | Read/Write | R/W | | | | R | ^ | 4/ 0 | | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | Function | SBI operation 0: disable 1: enable | | | | Always read "0" | | | | Note <SBIEN>: When using SBI, <SBIEN> should be set "1" (SBI operation enable) before setting each register of SBI module. Serial Bus Interface Control Register 1 (Read-modify-write instructions are prohibited.) SBI0CR1 (0240H) SBI1CR1 (0248H) | michae e | ontroi regit | otor i (itead | -modify-write | INSTITUTION | are promble | od.j) | | | |-------------|--------------|-------------------------------|---------------|----------------------------------------|-------------|----------------|----------------------------------------------|-----------------| | | 7 | 6 | 5 | 4 // | 3 | 2 | 1 | 0 | | Bit symbol | BC2 | BC1 | BC0 | ACK | _)) | SCK2 | SCK1 | SCK0/<br>SWRMON | | Read/Write | | W | | R/W | | \ | V | R/W | | After reset | 0 | 0 < | 0 | 0 | - | 0 | 0 | 0/1 | | Bit symbol | BC2 | BC1 | BC0 | ACK | > - | SCK2 | SCK1 | SCK0/<br>SWRMON | | Read/Write | | (//w) | | R/W | _ | 1 | V | R/W | | After reset | 0 | 0 | 0 (( | 7/0 | - | 0 | 0 | 0/1 | | Function | Num | ber of transferre<br>(Note 1) | d bits | Acknowl-<br>edge mode<br>specification | | Internal seria | clock selection<br>reset monitor<br>(Note 2) | and software | #### Internal serial clock selection <SCK2:0> at write | | 000 | n = 4 | - (Note3) | | |--------|-----|------------|------------|------------------------------------------------------| | | 001 | n = 5 | 73.53 kHz | | | | 010 | n = 6 | 50.00 kHz | System clock: fc | | SCK2:0 | 011 | n = 7 | 30.49 kHz | Clock gear: fc/1<br>fc =20 MHz (Internal SCL output) | | SCK2.0 | 100 | n = 8 | 17.12 kHz | $fscl = (f_{SYS}/2) / (2^n + 36) [Hz]$ | | 7 | 101 | n = 9 | 9.12 kHz | | | | 110 | n = 10 | 4.72 kHz | | | | 111 | (Reserved) | (Reserved) | | ## Software reset state monitor <SWRMON> at read | SWRMON | 0 | During software reset | |----------|---|-----------------------| | OWNINGIV | 1 | Initial data | #### Acknowledge mode specification | ACK | 0 | Not generate clock pulse for acknowledge signal | |------|---|-------------------------------------------------| | NOIC | 1 | Generate clock pulse for acknowledge signal | Page 163 2007-12-03 Number of bits transferred | | | <ach< th=""><th>&lt;&gt; = 0</th><th><ach< th=""><th><b>⟨&gt; = 1</b></th></ach<></th></ach<> | <> = 0 | <ach< th=""><th><b>⟨&gt; = 1</b></th></ach<> | <b>⟨&gt; = 1</b> | |-------|-----------------|-----------------------------------------------------------------------------------------------|--------|----------------------------------------------|------------------| | | <bc2:0></bc2:0> | Number of clock pulses | Bits | Number of clock pulses | Bits | | | 000 | 8 | 8 | 9 | 8 | | | 001 | 1 | 1 | 2 | 1 | | BC2:0 | 010 | 2 | 2 | 3 | 2 | | | 011 | 3 | 3 | 4 | 3 | | | 100 | 4 | 4 | 5 | 4 | | | 101 | 5 | 5 | 6 ( | 7/4 | | | 110 | 6 | 6 | 12/ | 6 | | | 111 | 7 | 7 | 8 | 7 | Note 1: For the frequency of the SCL line clock, see 9.3.3.3 "Serial clock". Note 2: Initial data of SCK0 is "0", SWRMON is "1". Note 3: This I<sup>2</sup>C bus circuit dose not support high-speed mode, it supports standard mode only. The fscI speed can be selected over 100 kbps by fc and <SCK2:0>, however it's irregular operation. Serial Bus Interface Control Register 2 (Read-modify-write instructions are prohibited.) SBI0CR2 (0243H) SBI1CR2 (024BH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|------------------------|---------------------------------------|---------------------------------------|------------------------------------------|--------------------------------|--------|---------------|-------------| | Bit symbol | MST | TRX | BB | PIN | SBIM1 | SBIM0 | SWRST1 | SWRST0 | | Read/Write | | V | V | | V | v | 1 | N | | After reset | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Bit symbol | MST | TRX | BB | PIN | SBIM1 | SBIM0 | SWRST1 | SWRST0 | | Read/Write | | V | V | | У | v · | 1 | N | | After reset | 0 | 0 | 0 | 1 | ~ ( | (// 0) | 0 | 0 | | Function | Master/slave selection | Transmitter/<br>receiver<br>selection | Start/stop<br>condition<br>generation | Cancel<br>INTSBI<br>interrupt<br>request | Serial bus intertion mode sele | / | Software rese | et generate | ## Software reset generate | 011/2074.0 | 10 | | |------------|-----|-----------------------------------------------------------------| | SWRST1:0 | ↓ ↓ | Write "10" and "01", then an internal reset signal is generated | | | 01 | | ## Serial bus interface operating mode selection (Note 2) | | 00 | Port mode (Serial bus interface output disabled) | |------------|----|--------------------------------------------------| | SBIM1:0 | 01 | (Reserved) | | SBIIVI 1.0 | 10 | I <sup>2</sup> C bus mode | | | 11 | (Reserved) | #### INTSBI interrupt request | PIN | 0 | (- )) | |-------|---|--------------------------| | 1 111 | 1 | Cancel interrupt request | ## Start/stop condition generation | Ciail stop containen generatien | | | | |---------------------------------|---------|-------------------------------|--| | ВВ | | Generates the stop condition | | | | (// 1)) | Generates the start condition | | ## Transmitter/receiver selection | TRX | 0 | Receiver | |-----|-----|-------------| | IRA | , 1 | Transmitter | #### Master/slave selection | 4 | masto, our o colocion | | | | |---|-----------------------|-----|--------|--| | | Met | 0 \ | Slave | | | | IONOT | 1/1 | Master | | Note 1: Reading this register functions as SBI0SR/SBI1SR register. Note 2: Switch to port mode after confirming that the bus is free. Switch a mode between I<sup>2</sup>C bus mode and clocked-synchronous 8-bit SIO mode after confirming that input signals via port are high level. Page 165 2007-12-03 Serial Bus Interface Status Register (Read-modify-write instructions are prohibited.) SBI0SR (0243H) SBI1SR (024BH) | | 3 | • | | | | | | | |-------------|-------------------------------------|----------------------------------------------|-------------------------------------|-------------------------------------------|------------------------------------------|--------------------------------------------------|----------------------------------------|---------------------------------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit symbol | MST | TRX | BB | PIN | AL | AAS | AD0 | LRB | | Read/Write | | | | F | ? | | | | | After reset | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Bit symbol | MST | TRX | BB | PIN | AL | AAS | AD0 | LRB | | Read/Write | | | | F | ? | | | | | After reset | 0 | 0 | 0 | 1 | ~ ( | (// 0) | 0 | 0 | | Function | Master/slave<br>status moni-<br>tor | Transmitter/<br>receiver sta-<br>tus monitor | I <sup>2</sup> C bus status monitor | INTSBI<br>interrupt<br>request<br>monitor | Arbitration<br>lost detection<br>monitor | Slave<br>address<br>match detec-<br>tion monitor | GENERAL<br>CALL detec-<br>tion monitor | Last<br>received bit<br>monitor | Last received bit monitor | LRR | 0 | Last received bit was 0 | |------|---|-------------------------| | LIND | 1 | Last received bit was 1 | #### GENERAL CALL detection monitor | AD0 | 0 | Undetected | | |-----|---|-----------------------|--| | AD0 | 1 | GENERAL CALL detected | | #### Slave address match detection monitor | AAS | 0 | Undefected | |-----|---|----------------------------------------------| | | 1 | Slave address match or GENERAL CALL detected | #### Arbitration lost detection monitor | ΔΙ | 0 | | |-----|-----|---------------------------| | AL. | (1( | Arbitration lost detected | ## INTSBI interrupt request monitor | PIN | (// 0) | Interrupt requested | |-----|--------|---------------------| | | | Interrupt canceled | ## I<sup>2</sup>C bus status monitor | BB | 0 | Free | |----|---|------| | > | 1 | Busy | #### Transmitter/receiver status monitor | TRX | 0 | Receiver | |---------|---|-------------| | )) 1100 | ) | Transmitter | #### Master/slave status monitor | MST 📐 | )。 | Slave | |-------|----|--------| | Wier | 7 | Master | Note 1: Writing in this register functions as SBI0CR2/SBI1CR2. Note 2: The initial data SBI0SR/SBI1SR<PIN> is "1" if SBI operation is enable (SBI0CR0<SBI0EN>/SBI1CR0<SBI1EN> "1"). If SBI operation is disable (SBI0CR0<SBI0EN>/SBI1CR0<SBI1EN> "0"), the initial data of SBI0SR/SBI1SR<PIN> is "0". Page 166 2007-12-03 ## IDLE2 Control Register (Read-modify-write instructions are prohibited.) SBI0BR (0244H) SBI1BR (024CH) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|------------------|--------------------------------------------|---|---|------|----------------------|-----|------------------| | Bit symbol | - | I2SBI0 | _ | - | _ | - | _ | _ | | Read/Write | W | R/W | - | - | - | <u>_</u> | - | R/W | | After reset | 0 | 0 | - | - | - | - | - | 0 | | Bit symbol | - | I2SBI1 | _ | - | - | (F) | > - | - | | Read/Write | W | R/W | - | 1 | - / | $\frac{1}{2}$ | _ | R/W | | After reset | 0 | 0 | - | - | <- ( | V/\ <del>\{\</del> } | - | 0 | | Function | Always write "0" | Operation in IDLE2 mode 0: Stop 1: Operate | | | | | | Always write "0" | ## Serial Bus Interface Data Buffer Register (Read-modify-write instructions are prohibited.) SBI0DBR (0241H) SBI1DBR (0249H) | | | | | | / { } | | | | |-------------|---------------------------|-----|-----|-----|------------|-----|---------------------------|-----| | | 7 | 6 | 5 | 4 | <i>)</i> 3 | 2 | $\mathcal{U}/\mathcal{U}$ | 0 | | Bit symbol | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | ÓB1 | DB0 | | Read/Write | R (Received)W (Transfer) | | | | | | | | | After reset | Undefined | | | | | | | | | Bit symbol | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | Read/Write | R (Received)/W (Transfer) | | | | | | | | | After reset | Undefined | | | | | | | | Note 1: When writing transmitted data, start from the MSB (bit7). Receiving data is placed from LSB (bit0). Note 2: SBIODBR can't be read the written data. Therefore read-modify-write instruction (e.g., "BIT" instruction) is prohibitted. ## I<sup>2</sup>C Bus Address Register (Read-modify-write instructions are prohibited.) I2C0AR (0242H) I2C1AR (024AH) | iaroco i togi | iotor (rtoda n | ilouily white | Journal of the Carlot C | 10 pionibito | ., | | | | |---------------|----------------------------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----|---------------------------------------------------|-----|-----| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit symbol | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 | SA0 | ALS | | Read/Write | // ) w | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit symbol | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 | SA0 | ALS | | Read/Write | w | | | | | | | | | After reset | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Function | Slave address selection for when device is operating as slave device | | | | | Address<br>recognition<br>mode speci-<br>fication | | | Address recognition mode specification | / { · · · · · · · · · · · · · · · · · · | | | | | | |-----------------------------------------|---|-------------------------------|--|--|--| | ALS | 0 | Slave address recognition | | | | | | 1 | Non slave address recognition | | | | Page 167 2007-12-03 ## 9.3.3 Control in I<sup>2</sup>C Bus Mode ## 9.3.3.1 Acknowledge mode specification Set the SBI0CR1<ACK> to "1" for operation in the acknowledge mode. The TMP91CW60 generates an additional clock pulse for an acknowledge signal when operating in 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 in order to generate the acknowledge signal. Clear the <ACK> to "0" for operation in the non-acknowledge mode, the TMP91CW60 does not generate a clock pulse for the acknowledge signal when operating in the master mode. #### 9.3.3.2 Number of transfer bits The SBIOCR1<BC2:0> is used to select a number of bits for next transmitting and receiving data. Since the <BC2:0> is cleared to "000" as a start condition, a slave address and direction bit transmission are always executed in 8 bits. Other than these, the <BC2:0> retains a specified value. #### 9.3.3.3 Serial clock #### Clock source The SBIOCR1<SCK2:0> is used to select a maximum transfer frequency outputted on the SCL pin in master mode. Set the baud rates, which have been calculated according to the formula below, to meet the specifications of the I2C bus, such as the smallest pulse width of tLOW. Figure 9-3 Clock Source $$t_{LOW} = (2^{n-1}+29)/f_{SBI}$$ $t_{HIGH} = (2^{n-1}+7)/f_{SBI}$ $t_{SCI} = 1/(t_{LOW} + t_{HIGH}) = t_{SBI}/(2^n + 36)$ | SBI0CR1 <sck2:0></sck2:0> | n | |---------------------------|----| | 000 | 4 | | 001 | 5 | | 010 | 6 | | 011 | 7 | | 100 | 8 | | 101 | 9 | | 110 | 10 | Note: f<sub>SBI</sub> shows f<sub>SYS</sub>/2 Page 168 2007-12-03 #### (2) Clock synchronization In the I<sup>2</sup>C bus mode, in order to wired-AND a bus, a master device which pulls down a clock line to low level, in the first place, invalidate 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 TMP91CW60 has a clock synchronization function for normal data transfer even when more than one master exists on the bus. The example explains the clock synchronization procedures when two masters simultaneously exist on a bus. Figure 9-4 Clock Synchronization As master A pulls down 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 high-level width 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 internal SCL output 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 finishes counting low-level width of an own clock pulse 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 determined by the master device with the shortest high-level width and the master device with the longest low-level width from among those master devices connected to the bus. #### 9.3.3.4 Slave address and address recognition mode specification When the TMP91CW60 is used as a slave device, set the slave address <SA6:0> and <ALS> to the 12C0AR. Clear the <ALS> to "0" for the address recognition mode. #### 9.3.3.5 Master/slave selection Set the SBI0CR2<MST> to "1" for operating the TMP91CW60 as a master device. Clear the SBI0CR2<MST> to "0" for operation as a slave device. The <MST> is cleared to "0" by the hardware after a stop condition on the bus is detected or arbitration is lost. Page 169 2007-12-03 #### 9.3.3.6 Transmitter/receiver selection Set the SBI0CR2<TRX> to "1" for operating the TMP91CW60 as a transmitter. Clear the <TRX> to "0" for operation as a receiver. When data with an addressing format is transferred in slave mode, when a slave address with the same value that an I2C0AR or a GENERAL CALL is received (All 8-bit data are "0" after a start condition), the $\langle TRX \rangle$ is set to "1" by the hardware if the direction bit $\langle R/\overline{W} \rangle$ sent from the master device is "1", and $\langle TRX \rangle$ is cleared to "0" by the hardware if direction bit is "0". In the master mode, after an acknowledge signal is returned from the slave device, the <TRX> is cleared to "0" by the hardware if a transmitted direction bit is "1", and <TRX> is set to "1" by the hardware if direction is "0". When an acknowledge signal is not returned, the current condition is maintained. The $\langle TRX \rangle$ is cleared to "0" by the hardware after a stop condition on the $I^2C$ bus is detected or arbitration is lost. ## 9.3.3.7 Start/stop condition generation When the SBI0SR<BB> is "0", slave address and direction bit which are set to SBI0DBR are output on a bus after generating a start condition by writing "1" to the SBI0CR2<MST, TRX, BB, PIN>. It is necessary to set transmitted data to the data buffer register (SBI0DBR) and set "1" to <ACK> beforehand. SCL pin SDA pin Start condition Start condition Slave address and the direction bit Acknowledge signal Figure 9-5 Start Condition Generation and Slave Address Generation When the <BB> is "1", a sequence of generating a stop condition is started on the bus by writing "1" to the <MST, TRX, PIN>, and "0" to the <BB>. Do not modify the contents of <MST, TRX, BB, PIN> until a stop condition is generated on the bus. Figure 9-6 Stop Condition Generation The state of the bus can be ascertained by reading the contents of SBI0SR<BB>. SBI0SR<BB> will be set to "1" if a start condition has been detected on the bus, and will be cleared to "0" if a stop condition has been detected. Page 170 2007-12-03 #### 9.3.3.8 Interrupt service requests and interrupt cancellation When a serial bus interface interrupt request (INTSBI) occurs, the SBI0CR2<PIN> is cleared to "0". During the time that the SBI0CR2<PIN> is "0", the SCL line is pulled down to the low level. The <PIN> is cleared to "0" when an 1 word of data is transmitted or received. Either writing/reading data to/from SBI0DBR sets the <PIN> to "1". The time from the <PIN> being set to "1" until the SCL line is released takes t<sub>LOW</sub>. In the address recognition mode (<ALS> = "0"), <PIN> is cleared to "0" when the received slave address is the same as the value set at the I2C0AR or when a GENERAL CALL is received (All 8-bit data are "0" after a start condition). Although SBIOCR2<PIN> can be set to "1" by the program, the <PIN> is not cleared to "0" when it is written "0". ## 9.3.3.9 Serial bus interface operation mode selection SBIOCR2<SBIM1:0> is used to specify the serial bus interface operation mode. Set SBI0CR2<SBIM1:0> to "10" when the device is to be used in I<sup>2</sup>C bus mode after confirming pin condition of serial bus interface to "H". Switch to port mode after confirming a bus is free. ## 9.3.3.10 Arbitration lost detection monitor Since more than one master device can exist simultaneously on the bus in I<sup>2</sup>C bus mode, a bus arbitration procedure has been implemented in order to guarantee the integrity of transferred data. Data on the SDA line is used for I<sup>2</sup>C bus arbitration. The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on the 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 wired-AND and the SDA line is pulled down to the low level by master A. When the SCL line of the bus is pulled up at point b, the slave device reads the 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". Master B device which loses arbitration releases the internal SDA output in order not to affect 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 9-7 Arbitration Lost The TMP91CW60 compares the levels on the bus's SDA line with those of the internal SDA output on the rising edge of the SCL line. If the levels do not match, arbitration is lost and SBI0SR<AL> is set to "1". Page 171 2007-12-03 When SBIOSR<AL> is set to "1", SBIOSR<MST, TRX> are cleared to "00" and the mode is switched to slave receiver mode. Thus, clock output is stopped in data transfer after setting <AL> = "1". SBIOSR<AL> is cleared to "0" when data is written to or read from SBIODBR or when data is written to SBIOCR2. Figure 9-8 Example of when TMP91CW60 is a Master Device B (D7A = D7B, D6A = D6B) ## 9.3.3.11 Slave address match detection monitor SBIOSR<AAS> is set to "1" in slave mode, in address recognition mode (e.g., when I2COAR<ALS> = "0"), when a GENERAL CALL is received, or when a slave address matches the value set in I2COAR. When I2COAR<ALS> = "1", SBIOSR<AAS> is set to "1" after the first word of data has been received. SBIOSR<AAS> is cleared to "0" when data is written to or read from the data buffer register SBIODBR. #### 9.3.3.12 GENERAL CALL detection monitor SBIOSR<AD0> is set to "1" in slave mode, when a GENERAL CALL is received (All 8-bit received data is "0" after a start condition). SBIOSR<AD0> is cleared to "0" when a start condition or stop condition is detected on the bus. #### 9.3.3.13 Last received bit monitor The SDA line value stored at the rising edge of the SCL line is set to the SBIOSR<LRB>. In the acknowledge mode, immediately after an INTSBI interrupt request is generated, an acknowledge signal is read by reading the contents of the SBIOSR<LRB>. #### 9.3.3.14 Software reset function The software reset function is used to initialize the SBI circuit, when SBI is locked by external noises, etc. An internal reset signal pulse can be generated by setting SBIOCR2<SWRST1:0> to "10" and "01". This initializes the SBI circuit internally. All control registers and status registers are initialized as well. SBIOCR1<SWRMON> is automatically set to "1" after the SBI circuit has been initialized. Note: If the software reset is executed, operation selection is reset, and its mode is set to port mode from I<sup>2</sup>C mode. Page 172 2007-12-03 ## 9.3.3.15 Serial bus interface data buffer register (SBI0DBR) The received data can be read and transferred data can be written by reading or writing the SBIODBR. In the master mode, after the start condition is generated the slave address and the direction bit are set in this register. ## 9.3.3.16 I<sup>2</sup>CBUS address register (I2C0AR) I2C0AR<SA6:0> is used to set the slave address when the TMP91CW60 functions as a slave device. The slave address output from the master device is recognized by setting the I2C0AR<ALS> to "0". The data format is the addressing format. When the slave address is not recognized at the <ALS> = "1", the data format is the free data format. ## 9.3.3.17 Setting register for IDLE2 mode operation (SBI0BR0) SBI0BR0<I2SBI0> is the register setting operation/stop during IDLE2 mode. Therefore, setting <I2SBI0> is necessary before the HALT instruction is executed. ## 9.3.4 Data Transfer in I<sup>2</sup>C Bus Mode #### 9.3.4.1 Device initialization Set the SBI0CR1<ACK, SCK2:0>, clear bits 2 to 0 and 4 in the SBI0CR1 to "0". Set a slave address <SA6:0> and the <ALS> (<ALS> = "0" when an addressing format) to the I2C0AR. For specifying the default setting to a slave receiver mode, clear "0" to the SBIOCR2<MST, TRX, BB>, set "1" to the <PIN>, "10" to the <SBIM1:0>, and write "0" to bit 1, 0. Page 173 2007-12-03 ### 9.3.4.2 Start condition and slave address generation #### (1) Master mode In the master mode, the start condition and the slave address are generated as follows. Check a bus free status (when $\langle BB \rangle = "0"$ ). Set the SBI0CR1<ACK> to "1" (Acknowledge mode) and specify a slave address and a direction bit to be transmitted to the SBI0DBR. When SBIOCR2<BB> = "0", the start condition are generated by writing "1" to SBIOCR2<MST, TRX, BB, PIN>. Subsequently to the start condition, nine clocks are output from the SCL pin. While eight clocks are output, the slave address and the direction bit which are set to the SBIODBR. At the 9th clock, the SDA line is released and the acknowledge signal is received from the slave device. An INTSBI0 interrupt request occurs at the falling edge of the 9th clock. The <PIN> is cleared to "0". In the master mode, the SCL pin is pulled down to the low level while <PIN> is "0". When an interrupt request occurs, the <TRX> is changed according to the direction bit only when an acknowledge signal is returned from the slave device. #### Setting in main routine In INTSBIO interrupt routine INTCLR <-- 0x30 ; Clear the interrupt request Process End of interrupt ## (2) Slave mode In the slave mode, the start condition and the slave address are received. After the start condition is received from the master device, while eight clocks are output from the SCL pin, the slave address and the direction bit which are output from the master device are received. When a GENERAL CALL or the same address as the slave address set in I2C0AR is received, the SDA line is pulled down to the low level at the 9th clock, and the acknowledge signal is output. An INTSBIO interrupt request occurs on the falling edge of the 9th clock. The $\langle PIN \rangle$ is cleared to "0". In slave mode the SCL line is pulled down to the low level while the $\langle PIN \rangle$ = "0". Page 174 2007-12-03 Figure 9-9 Start Condition Generation and Slave Address Transfer #### 9.3.4.3 1-word data transfer Check the <MST> by the INTSBI0 interrupt process after the 1-word data transfer is completed, and determine whether the mode is a master or slave. (1) If <MST> = "1" (Master mode) Check the <TRX> and determine whether the mode is a transmitter or receiver. (a) When the <TRX> = "1" (Transmitter mode) Check the <LRB>. When <LRB> is "1", a receiver does not request data. Implement the process to generate a stop condition (Refer to below) and terminate data transfer. When the <LRB> is "0", the receiver requests new data. When the next transmitted data is 8 bits, write the transmitted data to SBIODBR. When the next transmitted data is other than 8 bits, set the <BC2:0> <ACK> and write the transmitted data to SBI0DBR. After written the data, <PIN> becomes "1", a serial clock pulse is generated for transferring a new 1 word of data from the SCL pin, and then the 1-word data is transmitted. After the data is transmitted, an INTSBI interrupt request occurs. The <PIN> becomes "0" and the SCL line is pulled down to the low level. If the data to be transferred is more than one word in length, repeat the procedure from the <LRB> checking above. if MST = 0 Then shift to the process when slave mode Then shift to the process when receiver mode. if LRB = 0 Note: X: Don't care if TRX = 0 Then shift to the process that generates stop condition. 3 SBI0CR1 Set the bit number of transmit and ACK. SBI0DBR Write the transmit data. End of interrupt > 2007-12-03 Page 175 Figure 9-10 Example in which <BC2:0> = "000" and <ACK> = "1" in Transmitter Mode ## (b) When the <TRX> is "0" (Receiver mode) When the next transmitted data is other than 8 bits, set <BC2:0> <ACK> and read the received data from SBI0DBR to release the SCL line (Data which is read immediately after a slave address is sent is undefined). After the data is read, <PIN> becomes "1". Serial clock pulse for transferring new 1 word of data is defined SCL and outputs "L" level from SDA pin with acknowledge timing. An INTSBIO interrupt request then occurs and the <PIN> becomes "0", then the TMP91CW60 pulls down the SCL pin to the low level. The TMP91CW60 outputs a clock pulse for 1 word of data transfer and the acknowledge signal each time that received data is read from the SBIODBR. Figure 9-11 Example of when <BC2:0> = "000", <ACK> = "1" in Receiver Mode In order to terminate the transmission of data to a transmitter, clear <ACK> to "0" before reading data which is 1 word before the last data to be received. The last data word does not generate a clock pulse as the acknowledge signal. After the data has been transmitted and an interrupt request has been generated, set <BC2:0> to "001" and read the data. The TMP91CW60 generates a clock pulse for an 1-bit data transfer. Since the master device is a receiver, the SDA line on the bus remains high. The transmitter interprets the high signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete. After the one data bit has been received and an interrupt request been generated, the TMP91CW60 generates a stop condition and terminates data transfer. Page 176 2007-12-03 Figure 9-12 Termination of Data Transfer in Master Receiver Mode In the slave mode the TMP91CW60 operates either in normal slave mode or in slave mode after losing arbitration. In the slave mode, an INTSBI0 interrupt request occurs when the TMP91CW60 receives a slave address or a GENERAL CALL from the master device, or when a GENERAL CALL is received and data transfer is complete, or after matching received address. In the master mode, the TMP91CW60 operates in a slave mode if it detects losing arbitration. An INTSBI0 interrupt request occurs when a word data transfer terminates after losing arbitration. When an INTSBI0 interrupt request occurs the <PIN> is cleared to "0" and the SCL pin is pulled down to the low level. Either reading/writing from/ to the SBI0DBR or setting the <PIN> to "1" will release the SCL pin after taking t<sub>LOW</sub> time. Check the SBI0SR<AL>, <TRX>, <AAS>, and <AD0> and implements processes according to conditions listed in the next table. Page 177 2007-12-03 Example: In case matching slave address in slave receive mode, direction bit is "1". INTSBI0 interrupt if TRX = 0 Then shift to other process if AL = 1 Then shift to other process if AAS = 0 Then shift to other process 7 6 5 4 3 2 1 0 $\texttt{SBI0CR1} \ \leftarrow \ \texttt{X} \ \texttt{X} \ \texttt{X} \ \texttt{1} \ \texttt{X} \ \texttt{X} \ \texttt{X}$ Set the bit number of transmit. SBIODBR $\leftarrow$ X X X X X X X X Set the data of transmit. Note: X: Don't care Table 9-1 Operation in the Slave Mode | <trx></trx> | <al></al> | <aas></aas> | <ad0></ad0> | Conditions | Process | |-------------|-----------|-------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 | 1 | 0 | The TMP91CW60 loses arbitration when transmitting a slave address and receives a slave address for which the value of the direction bit sent from another master is "1". | Set the number of bits a word in <bc2:0> and write the transmitted data to</bc2:0> | | 1 | | 1 | 0 | In slave receiver mode, the TMP91CW60 receives a slave address for which the value of the direction bit sent from the master is "1". | SBIODER. | | | 0 | 0 | | In slave transmitter mode, a single word of data is transmitted. | Check the <lrb> setting. If <lrb> is set to "1", set <pin> to "1" since the receiver win no request the data which follows. Then, clear <trx> to "0" to release the bus. If <lrb> is cleared to "0", set <bc2:0> to the number of bits in a word and write the transmitted data to SBIODBR since the receiver requests next data.</bc2:0></lrb></trx></pin></lrb></lrb> | | | | 1 | 1/0 | The TMP91CW60 loses arbitration when transmitting a slave address and receives a slave address or GENERAL CALL for which the value of the direction bit sent from another master is "0". | | | 0 | | 0 | 0 | The TMP91CW60 loses arbitration when transmitting a slave address or data and terminates word data transfer. | Read the SBI0DBR for setting the <pin> to "1" (Reading dummy data) or set the <pin> to "1".</pin></pin> | | | | 1 | 1/0 | In slave receiver mode, the TMP91CW60 receives a slave address or GENERAL CALL for which the value of the direction bit sent from the master is "0". | | | | | 0 | 1/0 | In slave receiver mode, the TMP91CW60 terminates receiving word data. | Set <bc2:0> to the number of bits in a word and read the received data from SBI0DBR.</bc2:0> | 2007-12-03 Page 178 #### 9.3.4.4 Stop condition generation When SBIOSR<BB> = "1", the sequence for generating a stop condition is started by writing "1" to SBIOCR2<MST, TRX, PIN> and "0" to SBIOCR2<BB>. Do not modify the contents of SBIOCR2<MST, TRX, PIN, BB> until a stop condition has been generated on the bus. When the bus's SCL line has been pulled low by another device, the TMP91CW60 generates a stop condition when the other device has released the SCL line and SDA pin rising. Figure 9-13 Stop Condition Generation (Single master) Figure 9-14 Condition Generation (Multi master) Page 179 2007-12-03 TOSHIBA TMP91CW60 #### 9.3.4.5 Restart Restart is used during data transfer between a master device and a slave to change the data transfer direction. The following description explains how to restart when the TMP91CW60 is in Master mode. Clear SBI0CR2<MST, TRX, BB> to "0" and set SBI0CR2<PIN> to "1" to release the bus. The SDA line remains High and the SCL pin is released. Since a stop condition has not been generated on the bus, other devices assume the bus to be in busy state. And confirm SCL pin, that SCL pin is released and become bus-free state by SBIOSR<BB> = "0" or signal level "1" of SCL pin by sensing its port (change to input mode). Check the <LRB> until it becomes "1" to check that the SCL line on a bus is not pulled down to the low level by other devices. After confirming that the bus remains in a free state, generate a start condition using the procedure described in 9.3.4.2. In order to satisfy the setup time requirements when restarting, take at least 4.7 µs of waiting time by software from the time of restarting to confirm that the bus is free until the time to generate the start condition. Figure 9-15 Timing Diagram for TMP91CW60 Restart Note: Don't write <MST> "0", when <MST> "0" condition. (Cannot be restarted) Page 180 2007-12-03 ## 10. 10-bit AD Converter (ADC) The TMP91CW60 have a 10-bit successive approximation type AD converter. ## 10.1 Configuration The circuit configuration of the 10-bit AD converter is shown in Figure 10-1. It consists of control register ADCCR1 and ADCCR2, converted value register ADCDRH and ADCDRL, a DA converter, a sample-hold circuit, a comparator, and a successive comparison circuit. Note: Before using AD converter, set appropriate value to I/O port register combining a analog input port. For details, see the section on "I/O ports". Figure 10-1 10-bit AD Converter # 10.2 Register configuration The AD converter consists of the following four registers: 1. AD converter control register 1 (ADCCR1) This register selects the analog channels and operation mode (single or repeat) in which to perform AD conversion and controls the AD converter as it starts operating. 2. AD converter control register 2 (ADCCR2) This register selects the AD conversion time and controls the connection of the DA converter (Ladder resistor network) and monitors the operating status of the AD converter. 3. AD converted value register (ADCDRH, ADCDRL) This register used to store the digital value after being converted by the AD converter. Page 181 2007-12-03 #### AD Converter Control Register 1 ADCCR1 (02B0H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|---------------------------------------------------|---------------------------------------------------------------|-------------------|-----------------------------------------|--------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|------------|--| | Bit symbol | ADRS | AM | MD | AINEN | SAIN | | | | | | Read/Write | | | | R | W | | SAIN 0 0 0 nalog input channel select 00: AN4 1000: AN8 1100: AN12 10: AN5 1001: AN9 1101: AN13 10: AN6 1010: AN10 1110: AN14 | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | AD conver- | AD operating | AD operating mode | | Analog input channel select | | | | | | Function | sion start<br>0: -<br>1: AD con-<br>version start | 00: AD opera<br>01: single mo<br>10: Reserved<br>11: Repeat m | de | Analog input control 0:disable 1:enable | 0000: AN0<br>0001: AN1<br>0010: AN2<br>0011: AN3 | 0100: AN4<br>0101: AN5<br>0110: AN6<br>0111: AN7 | 1001: AN9 | 1101: AN13 | | - Note 1: Select analog input channel during AD converter stops (ADCCR2<ADBF> = "0") - Note 2: When the analog input channel is all use disabling, the ADCCR1<AINEN> should be set to "0". - Note 3: During conversion, Do not perform port output instruction to maintain a precision for all of the pins because analog input port use as general input port. And for port near to analog input, Do not input intense signaling of change. - Note 4: The ADCCR1<ADRS> is automatically cleared to "0" after starting conversion. - Note 5: Do not set ADCCR1<ADRS> newly again during AD conversion. Before setting ADCCR1<ADRS> newly again, check ADCDR2<EOCF> to see that the conversion is completed or wait until the interrupt signal (INTADC) is generated (e.g., interrupt handling routine). - Note 6: Starting of STOP mode, SLOW mode, and the IDLE1 mode initializes the AD control register 1 (ADCCR1) except for SAIN. Moreover, in the case of the IDLE2 mode, it controls by the <I2AD> bit of ADCCR2. Therefore, to use AD converter again, set the ADCCR1 newly after returning to NORMAL mode. #### AD Converter Control Register 2 (Read-modify-write instructions are prohibited.) ADCCR2 (02B1H) | ſ | | 7 | 6 | 5 | 4 << | 3 | 2 | 1 | 0 | | | |---|-------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------|-----------|---|----------------|-------------|--|--| | | Bit symbol | EOCF | ADBF | RSEL | I2AD | | A | ACK | | | | | | Read/Write | R | | | R/W | | | | | | | | | After reset | 0 | (0( | 0 | 0 | 1 | 1 | 0 | 0 | | | | | Function | AD conversion end flag O:Before or during conversion 1: Conversion completed | AD conversion BUSY flag 0: During stop of AD conversion 1: During AD conversion | Storing of an AD conversion result 0: 10bit mode 1: 8bit mode | IDLE2 con-<br>trol<br>0:Stop<br>1:Operation | See" Tabl | | on time select | sion time " | | | Note 1: Starting of STOP mode, SLOW mode, and the IDLE1 mode initializes the AD control register 2 (ADCCR2) except for ACK and I2AD. Moreover, in the case of the IDLE2 mode, it controls by the <I2AD> bit of ADCCR2. Therefore, to use AD converter again, set the ADCCR2 newly after returning to NORMAL mode. Therefore, the AD conversion result should be read to ADCDRL more first than ADCDRH. Note 2: The ADCCR2<EOCF> is cleared to "0" when reading the ADCDRH. Note 3: The ADCCR2<ADBF> is set to "1" when AD conversion starts, and cleared to "0" when AD conversion finished. Page 182 2007-12-03 Table 10-1 ACK setting and Conversion time | Condition | Conversion | 20MHz | 16MHz | 10 MHz | 8MHz | 4 MHz | 2 MHz | | | |-----------|------------|---------|---------|----------|----------|-----------------|----------|--|--| | ACK | time | ZUMHZ | TOWINZ | 10 MHZ | OIVITZ | 4 IVITZ | Z IVITIZ | | | | 0xxx | Reserved | | | | | | | | | | 1000 | Reserved | | | | | | | | | | 1001 | Reserved | | | | | | | | | | 1010 | 78/fc | = | = | = | = | 19.5 μs | 39.0 μs | | | | 1011 | 156/fc | = | - | 15.6 μs | 19.5 μs | <b>3</b> 9.0 μs | 78.0 μs | | | | 1100 | 312/fc | 15.6 μs | 19.5 μs | 31.2 μs | 39.0 μs | 78.0 μs | 156.0 μs | | | | 1101 | 624/fc | 31.2 μs | 39.0 μs | 62.4 μs | 78.0 μs | 156.0 μs | - | | | | 1110 | 1248/fc | 62.4 μs | 78.0 μs | 124.8 μs | 156.0 μs | - | | | | | 1111 | | | | Reserved | | | | | | Note 1: Setting for "-" in the above table are inhibited. fc: High Frequency oscillation clock [Hz] Note 2: Set conversion time setting should be kept more than the following time by Analog reference voltage. - V<sub>REFH</sub> = 4.5 to 5.5 V 15.6 us and more #### AD Converted value Register H (8-bit storing mode) ADCDRH (02B3H) | | 7 | 6 | 5 | → 4 // | 3 | 2 | 1 | 0 | | | |-------------|------|------|------|--------|------|------|------|------|--|--| | Bit symbol | AD09 | AD08 | AD07 | AD06 | AD05 | AD04 | AD03 | AD02 | | | | Read/Write | | R | | | | | | | | | | After reset | 0 | 0 | 0 | 0 🔨 | 0 | 0 | 0 | 0 | | | #### AD Converted value Register H (10-bit storing mode) ADCDRH (02B3H) | | 7 (// 6) | 5 4 | 3 | 2 | 1 | 0 | |-------------|----------|----------|---|---|------|------| | Bit symbol | | ~- (V/\$ | = | = | AD09 | AD08 | | Read/Write | | | R | | | | | After reset | 0 0 | 0 0 | 0 | 0 | 0 | 0 | #### AD Converted value Register L ADCDRL (02B2H) | | | $\searrow_{i}$ | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------------|----------------|------|------|------|------|------|------|------| | | Bit symbol | AD07 | AD06 | AD05 | AD04 | AD03 | AD02 | AD01 | AD00 | | | Read/Write | | | | - | R | | | | | _ | After reset | 0( | | 0 | 0 | 0 | 0 | 0 | 0 | Note: At the time of 10-bit storing mode, if the bit 7 to 2 of ADCDRH is read, "0" will be read. Page 183 2007-12-03 IRA TMP91CW60 #### 10.3 Function #### 10.3.1 Single mode After setting ADCCR1<AMD> to "01" (single mode), set ADCCR1<ADRS> to "1". AD conversion of the voltage at the analog input pin specified by ADCCR1<SAIN> is thereby started. After completion of the AD conversion, the conversion result is stored in AD converted value registers (ADCDRH, ADCDRL) and at the same time ADCCR2<EOCF> is set to 1, the AD conversion finished interrupt (INTADC) is generated. ADCCR1<ADRS> is automatically cleared after AD conversion has started. Do not set ADCCR1<ADRS> newly again (Restart) during AD conversion. Before setting ADCCR1<ADRS> newly again, check ADCCR2<EOCF> to see that the conversion is completed or wait until the interrupt signal (INTADC) is generated (e.g., interrupt handling routine). Page 184 2007-12-03 #### 10.3.2 Repeat Mode AD conversion of the voltage at the analog input pin specified by ADCCR1<SAIN> is performed repeatedly. In this mode, AD conversion is started by setting ADCCR1<ADRS> to "1" after setting ADCCR1<AMD> to "11" (Repeat mode). After completion of the AD conversion, the conversion result is stored in AD converted value registers (ADCDRL, ADCDRH) and at the same time ADCCR2<EOCF> is set to 1, the AD conversion finished interrupt (INTADC) is generated. In repeat mode, each time one AD conversion is completed, the next AD conversion is started. To stop AD conversion, set ADCCR1<AMD> to "00" (Disable mode) by writing 0s. The AD convert operation is stopped immediately. The converted value at this time is not stored in the AD converted value register. Figure 10-3 Repeat Mode ### 10.3.3 Register Setting - 1. Set up the AD converter control register 1 (ADCCR1) as follows: - Choose the channel to AD convert using AD input channel select (SAIN). - Specify analog input enable for analog input control (AINDS). - Specify AMD for the AD converter control operation mode (ssingle or repeat mode). - 2. Set up the AD converter control register 2 (ADCCR2) as follows: Set the AD conversion time using AD conversion time (ACK). For details on how to set the conversion time, refer to Table 10-1 and AD converter control register 2. - 3. After setting up (1) and (2) above, set AD conversion start (ADRS) of AD converter control register 1 (ADCCR1) to "1". If software start mode has been selected, AD conversion starts immediately. - 4. After an elapse of the specified AD conversion time, the AD converted value is stored in AD converted value register (ADCDRH and ADCDRL) and the AD conversion finished flag (EOCF) of AD converter control register 2 (ADCCR2) is set to "1", upon which time AD conversion interrupt INTADC is generated. - 5. EOCF is cleared to "0" by a read of the conversion result. However, if reconverted before a register read, although EOCF is cleared the previous conversion result is retained until the next conversion is completed. Page 185 2007-12-03 Example :After selecting the conversion time 19.5 µs at 16 MHz and the analog input channel AIN3 pin, perform AD conversion once. After checking EOCF, read the converted value, store the lower 2 bits in address 0009EH nd store the upper 8 bits in address 0009FH in RAM. The operation mode is single mode. | | LD | (ADCCR1), 00110011B | ; Select AIN3 | |--------|------|---------------------|----------------------------------------------------| | | LD | (ADCCR2), 00001100B | ;Select conversion time(312/fc) and operation mode | | | SET | (ADCCR1) . 7 | ; ADRS = 1(AD conversion start) | | SLOOP: | TEST | (ADCCR2) . 7 | ; EOCF=1? | | | JRS | T, SLOOP | | | | LD | A , (ADCDRL) | ; Read result data | | | LD | (9EH) , A | \(\frac{1}{2}\) | | | LD | A , (ADCDRH) | , Read result data | | | LD | (9FH), A | 4.90 | | | | | A 7(///// | ## 10.4 IDLE1/STOP/SLOW Modes during AD Conversion When standby mode (IDLE1,STOP or SLOW mode) is entered forcibly during AD conversion, the AD convert operation is suspended and the AD converter is initialized (ADCCR1 and ADCCR2 are initialized to initial value). Also, the conversion result is indeterminate. (Conversion results up to the previous operation are cleared, so be sure to read the conversion results before entering standby mode (IDLE1,STOP or SLOW mode).) When restored from standby mode (IDLE1,STOP or SLOW mode), AD conversion is not automatically restarted, so it is necessary to restart AD conversion. Note that since the analog reference voltage is automatically disconnected, there is no possibility of current flowing into the analog reference voltage. Moreover, in the case of the IDLE2 mode, it controls by the <I2AD> bit of ADCCR2. Page 186 2007-12-03 ## 10.5 Analog Input Voltage and AD Conversion Result The analog input voltage is corresponded to the 10-bit digital value converted by the AD as shown in Figure 10-4. Figure 10-4 Analog Input Voltage and AD Conversion Result (Typ.) Page 187 2007-12-03 **TMP91CW60** #### 10.6 Precautions about AD Converter #### 10.6.1 Analog input pin voltage range Make sure the analog input pins (AN0 to AN15) are used at voltages within $V_{REFH}$ to $A_{VSS}$ . If any voltage outside this range is applied to one of the analog input pins, the converted value on that pin becomes uncertain. The other analog input pins also are affected by that. #### 10.6.2 Analog input shared pins The analog input pins (AN0 to AN15) are shared with input/output ports. When using any of the analog inputs to execute AD conversion, do not execute input/output instructions for all other ports. This is necessary to prevent the accuracy of AD conversion from degrading. Not only these analog input shared pins, some other pins may also be affected by noise arising from input/output to and from adjacent pins. #### 10.6.3 Noise Countermeasure The internal equivalent circuit of the analog input pins is shown in Figure 10-5. The higher the output impedance of the analog input source, more easily they are susceptible to noise. Therefore, make sure the output impedance of the signal source in your design is $5k\Omega$ or less. Toshiba also recommends attaching a capacitor external to the chip. Figure 10-5 Analog Input Equivalent Circuit and Example of Input Pin Processing Page 188 2007-12-03 TOSHIBA TMP91CW60 ## 11. Program Patch Logic The TMP91CW60 has a program patch logic, which enables the user to fix the program code in the on-chip ROM without generating a new mask. Patch program must be read into on-chip RAM from external memory during the startup routine. Up to six two-byte sequences, or banks (Twelve bytes in total) can be replaced with patch code. More significant code correction can be performed by replacing program code with single-byte instruction code which generates a software interrupt (SWI) to make a branch to a specified location in the on-chip RAM area. The program patch logic only compares addresses in the on-chip ROM area; it cannot fix the program code in the on-chip peripheral, on-chip RAM and external ROM areas. Each of six banks is independently programmable, and functionally equivalent. In the following sections, any references to bank0 also apply to other banks. #### 11.1 Block Diagram **CPU** ROM ROMRD **ROMRD** Address bus Data bus Match **Output** (Bank0) (Bank0) enab l e signal Address substitution Address compare registers registers (ROMSUBOL/H) (ROMCMP00 to ROMCMP02) (Bank1) (Bank1) Address substitution Address compare registers Address (ROMCMP10 to ROMCMP12) registers (ROMSUB1L/H) 0utput (Bank2) Address compare registers Address substitution (ROMCMP20 to ROMCMP22) control registers(ROMSUB2L/H) compare (Bank3) (Bank3) Address compare registers Address substitution (ROMCMP30 to ROMCMP32) registers (ROMSUB3L/H) Б (Bank4) (Bank4) 00 Address substitution Address compare registers (ROMCMP40 to ROMCMP42) registers(ROMSUB4L/H) Address compare registers Address substitution registers(ROMSUB5L/H) (ROMCMP50 to ROMCMP52) Figure 11-1 Program Patch Logic Diagram Page 189 2007-12-03 ## 11.2 SFR Descriptions The program patch logic consists of six banks (0 to 5). Each bank is provided with three bytes of address compare registers (ROMCMPx0 to ROMCMPx2) and two bytes of address substitution registers (ROMSUBxL and ROMSUBxH). #### Bank0 Address Compare Register 0 | ROMCMP00 | |--------------| | (0400H) | | RMW | | instructions | | are prohib- | | ited | | | 7 | 6 | 5 | 4 | ⟨3∖ | (//2) | 1 | 0 | | |-------------|-----------------------------------|--------|--------|--------|--------|--------|--------|---|--| | Bit symbol | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | - | | | Read/Write | | | | W | | )> | | - | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | | | Function | Target ROM address (Lower 7 bits) | | | | | | | | | #### Bank0 Address Compare Register 1 | ROMCMP01 | |--------------| | (0401H) | | RMW | | instructions | | are prohib- | | ited. | | | | 7 | 6 | 5 | 4 | 3 | 2 | <u>\rightarrow 1</u> | 0 | | |---|-------------|--------|--------|------------------------------------|--------|--------|-------------|----------------------|--------|--| | 1 | Bit symbol | ROMC15 | ROMC14 | ROMC13 < | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | | | Read/Write | | | | 1 | N ( | 77/\ | | | | | 3 | After reset | 0 | 0 | 0 | 0 | 0 | <u>()</u> 0 | 0 | 0 | | | | Function | | | Target ROM address (Middle 8 bits) | | | | | | | #### Bank0 Address Compare Register 2 ROMCMP02 (0402H) RMW instructions are prohibited. | | | 7 | 6 | ) ) 5 | 4 | 3 | 2 | 1 | 0 | | |---|-------------|--------|---------|-----------------------------------|----------------|--------|--------|--------|--------|--| | 2 | Bit symbol | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | | Read/Write | | ((// )) | w | | | | | | | | | After reset | / 0 | | 0 (( | // <b>(</b> 0) | 0 | 0 | 0 | 0 | | | | Function | | | Target ROM address (Upper 8 bits) | | | | | | | ### Bank0 Data Substitution Register L | ROMSUB0L | |--------------| | (0404H) | | RMW | | instructions | | are prohib- | | ited. | | | T | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit symbol | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | Read/Write | | \ | V | | | | | | | After reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | Function Patch code (Lower 8 bits) | | | | | | | · | | #### Bank0 Data Substitution Register H ROMSUBOH (0405H) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---|-------------|---------------------------|--------|--------|--------|--------|--------|--------|--------|--|--| | Н | Bit symbol | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | | | Read/Write | W | | | | | | | | | | | 3 | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Function | Patch code (Upper 8 bits) | | | | | | | | | | Note 1: The ROMCMP00/01/02, and ROMSUB0L/0H registers do not support read-modify-write operation. Note 2: Bit0 of the Address Compare Register 0 is read as undefined. Page 190 2007-12-03 #### Bank1 Address Compare Register 0 ROMCMP10 (0408H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-----------------------------------|--------|--------|--------|--------|--------|--------|---| | Bit symbol | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | = | | Read/Write | | | | W | | | | = | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | = | | Function | Target ROM address (Lower 7 bits) | | | | | | | | #### Bank1 Address Compare Register 1 ROMCMP11 (0409H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | <i>J</i> ) 2 | 1 | 0 | | | | |-------------|--------|------------------------------------|--------|--------|--------|--------------|--------|--------|--|--|--| | Bit symbol | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | | | | Read/Write | | | | | N | ( | >(// / | | | | | | After reset | 0 | 0 | 0 | 0 ( | /\\\ 0 | ~ 0 (( | 0 | 0 | | | | | Function | | Target ROM address (Middle 8 bits) | | | | | | | | | | #### Bank1 Address Compare Register 2 ROMCMP12 (040AH) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 ((/ | / \)2 | 1 | 0 | |---|-------------|--------|-----------------------------------|--------|--------|--------|--------|--------|--------| | 2 | Bit symbol | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | Read/Write | | / | | <4 | w )) | | | | | ; | After reset | 0 | 0 | 0 | 0 | 0// | 0 | 0 | 0 | | | Function | | Target ROM address (Upper 8 bits) | | | | | | | #### Bank1 Data Substitution Register L ROMSUB1L (040CH) RMW instructions are prohibited. | | 7 | 6 | 5 (( | 7/4 | 3 | 2 | 1 | 0 | |-------------|---------------------------|--------|--------|--------|--------|--------|--------|--------| | Bit symbol | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | Read/Write | W | | | | | | | | | After reset | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | Function | Patch code (Lower 8 bits) | | | | | | | | #### Bank1 Data Substitution Register H ROMSUB1H (040DH) RMW instructions are prohibited. | £ | | 7 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---|-------------|--------|--------|--------|--------------|----------------|--------|--------|--------|--| | | Bit symbol | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | | Read/Write | w | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Function | | | | Patch code ( | (Upper 8 bits) | | | | | Note 1: The ROMCMP10/11/12, and ROMSUB1L/1H registers do not support read-modify-write operation. Note 2: Bit0 of the Address Compare Register 0 is read as undefined. #### Bank2 Address Compare Register 0 ROMCMP20 (0410H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-----------------------------------|--------|--------|--------|--------|--------|--------|---| | Bit symbol | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | = | | Read/Write | | | | W | | | | = | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | = | | Function | Target ROM address (Lower 7 bits) | | | | | | | _ | #### Bank2 Address Compare Register 1 ROMCMP21 (0411H) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 | <i>J</i> ) 2 | 1 | 0 | |---|-------------|--------|--------|------------------|--------|--------|--------------|--------|--------| | 1 | Bit symbol | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | | Read/Write | | | | | N | ( | >// | | | 3 | After reset | 0 | 0 | 0 | 0 ( | / \ 0 | ~ 0 (( | 0 | 0 | | | Function | | | ess (Middle 8 bi | ts) | Z(1) | | | | #### Bank2 Address Compare Register 2 ROMCMP22 (0412H) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 ((/ | / \)2 | 1 | 0 | |---|-------------|--------|-----------------------------------|--------|--------|--------|--------|--------|--------| | 2 | Bit symbol | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | Read/Write | | / | | <4 | w )) | | | | | 8 | After reset | 0 | 0 | 0 | 0 | 0// | 0 | 0 | 0 | | | Function | | Target ROM address (Upper 8 bits) | | | | | | | #### Bank2 Data Substitution Register L ROMSUB2L (0414H) RMW instructions are prohibited. | | 7 | 6 | 5 (( | 7/4 | 3 | 2 | 1 | 0 | |-------------|--------|--------|--------|--------------|---------------|--------|--------|--------| | Bit symbol | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | Read/Write | | _ | | \ \ | V | | | | | After reset | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | Function | \ \ \ | ^ | | Patch code ( | Lower 8 bits) | | | | #### Bank2 Data Substitution Register H ROMSUB2H (0415H) RMW instructions are prohibited. | | 7 | > 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------|--------|--------|--------------|---------------|--------|--------|--------| | Bit symbol | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | Read/Write | | | | V | V | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Function | | | | Patch code ( | Upper 8 bits) | | | | Note 1: The ROMCMP20/21/22, and ROMSUB2L/2H registers do not support read-modify-write operation. Note 2: Bit0 of the Address Compare Register 0 is read as undefined. Page 192 2007-12-03 #### Bank3 Address Compare Register 0 ROMCMP30 (0418H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------|--------|-----------|----------------|-------------|--------|--------|---| | Bit symbol | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | - | | Read/Write | | | | W | | | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | = | | Function | | | Target RC | OM address (Lo | wer 7 bits) | | | _ | #### Bank3 Address Compare Register 1 ROMCMP31 (0419H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | <i>J</i> ) 2 | 1 | 0 | |-------------|--------|--------|--------|----------------|------------------|--------------|--------|--------| | Bit symbol | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | Read/Write | | | | | N | ( | >(// / | | | After reset | 0 | 0 | 0 | 0 ( | /\\ 0 | 0 ( | 0 | 0 | | Function | | | Ta | arget ROM addr | ess (Middle 8 bi | its) | べつ) | | #### Bank3 Address Compare Register 2 ROMCMP32 (041AH) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 ((/ | / \)2 | 1 | 0 | |---|-------------|--------|--------|--------|----------------|------------------|--------|--------|--------| | 2 | Bit symbol | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | Read/Write | | | | <4 | w )) | | | | | 8 | After reset | 0 | 0 ( | 0 | 0 | 0// | 0 | 0 | 0 | | | Function | | | Т | arget ROM addı | ress (Upper 8 bi | ts) | | | #### Bank3 Data Substitution Register L ROMSUB3L (041CH) RMW instructions are prohibited. | | 7 | 6 | 5 (( | 7/4 | 3 | 2 | 1 | 0 | |-------------|--------|--------|--------|--------------|---------------|--------|--------|--------| | Bit symbol | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | Read/Write | | _ | | \ \ | V | | | | | After reset | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | Function | \ \ \ | ^ | | Patch code ( | Lower 8 bits) | | | | #### Bank3 Data Substitution Register H ROMSUB3H (041DH) RMW instructions are prohibited. | | 7 | > (6) | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------|--------|--------|--------------|---------------|--------|--------|--------| | Bit symbol | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | Read/Write | | | | V | V | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Function | | | | Patch code ( | Upper 8 bits) | | | | Note 1: The ROMCMP30/31/32, and ROMSUB3L/3H registers do not support read-modify-write operation. Note 2: Bit0 of the Address Compare Register 0 is read as undefined. Page 193 2007-12-03 #### Bank4 Address Compare Register 0 ROMCMP40 (0420H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------|--------|-----------|----------------|-------------|--------|--------|---| | Bit symbol | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | - | | Read/Write | | | | W | | | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | = | | Function | | | Target RC | OM address (Lo | wer 7 bits) | | | = | #### Bank4 Address Compare Register 1 ROMCMP41 (0421H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | <i>J</i> ) 2 | 1 | 0 | |-------------|--------|--------|--------|----------------|------------------|--------------|--------|--------| | Bit symbol | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | Read/Write | | | | | N | ( | >(// / | | | After reset | 0 | 0 | 0 | 0 ( | /\\ 0 | 0 ( | 0 | 0 | | Function | | | Ta | arget ROM addr | ess (Middle 8 bi | its) | べつ) | | #### Bank4 Address Compare Register 2 ROMCMP42 (0422H) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 ((/ | / \)2 | 1 | 0 | |---|-------------|--------|--------|--------|----------------|-----------------|--------|--------|--------| | 2 | Bit symbol | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | Read/Write | | | | <4 | w )) | | | | | 8 | After reset | 0 | 0 ( | 0 | 0 | 0// | 0 | 0 | 0 | | | Function | | | Т | arget ROM addı | ess (Upper 8 bi | ts) | | | #### Bank4 Data Substitution Register L ROMSUB4L (0424H) RMW instructions are prohibited. | | 7 | 6 | 5 (( | 7/4 | 3 | 2 | 1 | 0 | |-------------|--------|--------|--------|--------------|---------------|--------|--------|--------| | Bit symbol | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | Read/Write | | _ | | \ \ \ \ | V | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Function | \ \ \ | ^ | | Patch code ( | Lower 8 bits) | | | · | #### Bank4 Data Substitution Register H | < | |--------------| | ROMSUB4H | | (0425H) | | RMW | | instructions | | are prohib- | | ited. | | | | | 7 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------------|--------|---------------------------|--------|--------|--------|--------|--------|--------|--|--|--|--| | Bit symbol | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | | | | Read/Write | | | | W | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Function | | Patch code (Upper 8 bits) | | | | | | | | | | | Note 1: The ROMCMP40/41/42, and ROMSUB4L/4H registers do not support read-modify-write operation. Note 2: Bit0 of the Address Compare Register 0 is read as undefined. Page 194 2007-12-03 #### Bank5 Address Compare Register 0 ROMCMP50 (0428H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|--------|-----------------------------------|--------|--------|--------|--------|--------|---|--|--| | Bit symbol | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | - | | | | Read/Write | W | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | = | | | | Function | | Target ROM address (Lower 7 bits) | | | | | | | | | #### Bank5 Address Compare Register 1 ROMCMP51 (0429H) RMW instructions are prohibited. | | 7 | 6 | 5 | 4 | 3 | <i>J</i> ) 2 | 1 | 0 | |-------------|--------|--------|--------|----------------|------------------|--------------|--------|--------| | Bit symbol | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | Read/Write | | | | | N | ( | >(// / | | | After reset | 0 | 0 | 0 | 0 ( | /\\ 0 | 0 ( | 0 | 0 | | Function | | | Ta | arget ROM addr | ess (Middle 8 bi | its) | べつ) | | #### Bank5 Address Compare Register 2 ROMCMP52 (042AH) RMW instructions are prohibited. | | | 7 | 6 | 5 | 4 | 3 ((/ | / \)2 | 1 | 0 | |---|-------------|--------|--------|--------|----------------|------------------|--------|--------|--------| | 2 | Bit symbol | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | Read/Write | | / | | <4 | w )) | | | | | 8 | After reset | 0 | 0 | 0 | 0 | 0// | 0 | 0 | 0 | | | Function | | | Т | arget ROM addı | ress (Upper 8 bi | ts) | | | #### Bank5 Data Substitution Register L ROMSUB5L (042CH) RMW instructions are prohibited. | | 7 | 6 | 5 (( | 7/4 | 3 | 2 | 1 | 0 | | | |-------------|--------|--------|--------|--------------|---------------|--------|--------|--------|--|--| | Bit symbol | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | | | Read/Write | | W | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Function | \ \ \ | ^ | | Patch code ( | Lower 8 bits) | | | | | | #### Bank5 Data Substitution Register H | < | |--------------| | ROMSUB5H | | (042DH) | | RMW | | instructions | | are prohib- | | ited. | | | | | 7 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------------|--------|---------------------------|--------|--------|--------|--------|--------|--------|--|--|--|--| | Bit symbol | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | | | | Read/Write | | | | W | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Function | | Patch code (Upper 8 bits) | | | | | | | | | | | Note 1: The ROMCMP50/51/52, and ROMSUB5L/5H registers do not support read-modify-write operation. Note 2: Bit0 of the Address Compare Register 0 is read as undefined. Page 195 2007-12-03 TMP91CW60 ## 11.3 Operation #### 11.3.1 Replacing data Two consecutive bytes of data can be replaced for each bank. A two-byte sequence to be replaced must start at an even address. If only a single byte at an even or odd address need be replaced, set the current masked ROM data in the other byte. Correction procedure: Load the address compare registers (ROMCMP00 to ROMCMP02) with the target address where ROM data need be replaced. Store 2-byte patch code in the ROMSUB0L and ROMSUB0H registers. When the CPU address matches the value stored in the ROMCMP00 to ROMCMP02 registers, the program patch logic disables RD output to the masked ROM and drives out the code stored in the ROMSUB0L and ROMSUB0H to the internal bus. The CPU thus fetches the patch code. Figure 11-2 Example Patch Code Implementation Page 196 2007-12-03 b. Replacing 33H at address FF1233H with BBH Figure 11-3 Example Patch Code Implementation c. Replacing 44H at address FF1234H with CCH and 55H at address FF1235H with DDH Figure 11-4 Example Patch Code Implementation Page 197 2007-12-03 | d Daniasing 7711 at address FF1007 | 11 | CE400011 with CELL (Dearwinian true beates) | |-------------------------------------|-------------------------------|---------------------------------------------| | u. Replacing //n at address FF 123/ | IT WILL EET AND OOT ALAQUIESS | FF1238H with FFH (Requiring two banks) | | | 1 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------|---|---|---|---|---|---|---|---|-----------------------------------------------------------| | ROMCMP00 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | Stores 36 in address compare register 0 for bank0. | | ROMCMP01 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Stores 12 in address compare register 1 for bank0. | | ROMCMP02 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Stores FF in address compare register 2 for bank0. | | ROMSUB0L | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | Store 66 in address substitution register low for bank0. | | ROMSUB0H | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | Store EE in address substitution register high for bank0. | | ROMCMP10 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | Stores 38 in address compare register 0 for bank1. | | ROMCMP11 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Stores 12 in address compare register 1 for bank1. | | ROMCMP12 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Stores FF in address compare register 2 for bank1. | | ROMSUB1L | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Store FF in address substitution register low for bank1. | | ROMSUB1H | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Store 99 in address substitution register high for bank1. | Figure 11-5 Example Patch Code Implementation Page 198 2007-12-03 **TMP91CW60** #### 11.3.2 Using an interrupt to cause a branch A wider range of program code can also be fixed using a software interrupt (SWI). With a patch code loaded into on-chip RAM, the program patch logic can be used to replace program code at a specified address with a single-byte SWI instruction, which causes a branch to the patch program. Note that this method can only be used if the original masked ROM has been developed with <u>on-chip RAM</u> <u>addresses specified as SWI vector addresses.</u> Correction procedure: Load the address compare registers (ROMCMP00 to ROMCMP02) with the start address of the program code that is to be fixed. If it is an even address, store an SWI instruction code (e.g., SWI:F9H) in the ROMSUBL. If the start address is an odd address, store an SWI instruction code in the ROMSUBH and the current ROM data at the preceding even address in the ROMSUBL. When the CPU address matches the value stored in the ROMCMP00 to ROMCMP02 registers, the program patch logic disables RD output to the masked ROM and drives out the SWI instruction code to the internal bus. Upon fetching the SWI code, the CPU makes a branch to the internal RAM area to execute the preloaded code. At the end of the patch program executed from the internal RAM, the CPU directly rewrites the saved PC value so that it points to the address following the patch code, and then executes a RETI. The following shows an example: Example: Fixing a program within the range from FF5000H to FF507FH Before developing the original masked ROM, set the SWI1 vector reference address to 001500H (onchip RAM area). Use the startup routine to load the patch code to on-chip RAM (001500H to 0015EFH). Store the start address (FF5000H) of the ROM area to be fixed in the ROMCMP00 to ROMCMP02. Store the SWI1 instruction code (F9H) in the ROMSUB0L and the current data at FF5001H (AAH) in the ROMSUB0H. When the CPU address matches the value stored in ROMCMP00 to ROMCMP02, the program patch logic replaces the ROM-based code at FF5000H with F9H. The CPU then executes the SWI1 instruction, which causes a branch to 001500H in the on-chip RAM area. After executing the patch program the CPU finally rewrites the saved PC value to FF5080H and executes a RETI. Page 199 2007-12-03 Figure 11-6 Example ROM Correction TOSHIBA TMP91CW60 ## 12. Watchdog Timer (Runaway detection timer) The TMP91CW60 features a watchdog timer for detecting runaway. The watchdog timer (WDT) is used to return the CPU to 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. Connecting the watchdog timer output to the reset pin internally forces a reset. (The level of external RESET pin is not changed) ## 12.1 Configuration Figure 12-1 is a block diagram of he watchdog timer (WDT). Figure 12-1 Block Diagram of Watchdog Timer Note: It needs to care designing the total machine set, because watchdog timer can't operate completely by external noise. Page 201 2007-12-03 ### 12.2 Operation The watchdog timer generates an INTWD interrupt when the detection time set in the WDMOD<WDTP1:0> has elapsed. The watchdog timer must be cleared "0" by software before an INTWD interrupt will be generated. If the CPU malfunctions (e.g., if runaway occurs) due to causes such as noise, but does not execute the instruction used to clear the binary counter, the binary counter will overflow and an INTWD interrupt will be generated. The CPU will detect malfunction (Runaway) due to the INTWD interrupt and in this case it is possible to return to the CPU to normal operation by means of an anti-malfunction program. The watchdog timer works immediately after reset. The watchdog timer does not operate in IDLE1 or STOP mode. When the device is in IDLE2 mode, the operation of WDT depends on the WDMOD<I2WDT> setting. Ensure that WDMOD<I2WDT> is set before the device enters IDLE2 mode. The watchdog timer consists of a 22-stage binary counter which uses the system clock ( $f_{SYS}$ ) as the input clock. The binary counter can output $f_{SYS}/2^{15}$ , $f_{SYS}/2^{17}$ , $f_{SYS}/2^{19}$ and $f_{SYS}/2^{21}$ . Figure 12-2 Normal Mode The runaway is detected when an overflow occurs, and the watchdog timer can reset this device. In this case, the reset time will be between 22 and 29 states (51.2 $\mu$ s at $f_{OSCH} = 20$ MHz) as shown in Figure 12-3. After a reset, the $f_{SYS}$ clock (1 cycle = 1 state) is $f_{FPH}/2$ , where $f_{FPH}$ is generated by dividing the high-speed oscillator clock ( $f_{OSCH}$ ) by sixteen through the clock gear function. Page 202 2007-12-03 TMP91CW60 ### 12.3 Control Registers The watchdog timer WDT is controlled by two control registers WDMOD and WDCR. #### 12.3.1 Watchdog timer mode register (WDMOD) a. Setting the detection time for the watchdog timer in <WDTP1:0> This 2-bit register is used for setting the watchdog timer interrupt time used when detecting runaway. After reset, this register is initialized to WDMOD<WDTP1:0> = "00" ( $2^{15}$ / $f_{SYS}$ [S]). b. Watchdog timer enable/disable control register < WDTE After reset, WDMOD<WDTE> is initialized to "1", enabling the watchdog timer. To disable the watchdog timer, it is necessary to set this bit to "0" and to write the disable code (B1H) to 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 the watchdog timer from the disabled state to the enabled state merely by setting <WDTE> to "1". c. Watchdog timer out reset connection <RESCR> This register is used to connect the output of the watchdog timer with the internal RESET. Since WDMOD<RESCR> is initialized to "0" on reset, a reset by the watchdog timer will not be performed. ### 12.3.2 Watchdog timer control register (WDCR) This register is used to disable and clear the binary counter for the watchdog timer. · Disable control The watchdog timer can be disabled by clearing WDMOD<WDTE> to "0" and then writing the disable code (B1H) to the WDCR register. Enable control Set WDMOD<WDTE> to "1' · Watchdog timer clear control To clear the binary counter and cause counting to resume, write the clear code (4EH) to the WDCR register. Page 203 2007-12-03 #### Watchdog Timer Mode Register WDMOD (0300H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---|---|------------------|------------------|-------------------| | Bit symbol | WDTE | WDTP1 | WDTP1 WDTP0 | | - | I2WDT | RESCR | - | | Read/Write | R/W | R | W | _ | - | R | R/W | | | After reset | 1 | 0 | 0 | - | - | 0 | 0 | 0 | | Function | WDT control 1: Enable | Select detection on the select detection of the select detection on the selection of se | ng time | | | IDLE2<br>control | Reset<br>control | Always write "0". | Watchdog timer out control | RESCR | 0 | - | |-------|---|-------------------------------------| | KLOOK | 1 | Connect WDT out to a internal reset | IDLE2 control | I2WDT | 0 | Stop | | |--------|---|-----------|-----| | 120001 | 1 | Operation | 200 | Watchdog timer detection time @fc = 20 MHz, fs = 32.768 kHz | SYSCR1 | SYSCR1 | | Watchdog Time | r Detection Time | е | |---------------------------|---------------------|----------|---------------|------------------|------------| | System Clock | Gear Value | | WDMOD< | WDTP1:0> | | | Selection <sysck></sysck> | <gear2:0></gear2:0> | > 00 // | 01 | 10 | 11 | | 1(fs) | XXX | 2.0 s | 8.0 s | 32.0 s | 128.0 s | | | 000 (fc) | 3.28 ms | 13.11 ms | 52.43 ms | 209.72 ms | | | 001 (fc/2) | 6.55 ms | 26.21 ms | 104.86 ms | 419.43 ms | | 0(fc) | 010(fc/4) | 13.11 ms | 52.43 ms | 209.72 ms | 838.86 ms | | | 011 (fc/8) | 26.21 ms | 104.86 ms | 419.43 ms | 1677.72 ms | | | 100 (fc/16) | 52.43 ms | 209.72 ms | 838.86 ms | 3355.44 ms | Watchdog timer enable/disable control | WATE | 0 | Disabled | |-------|-----|----------| | WEILE | 1 _ | Enabled | ## Watchdog Timer Control Register WDCR (0301H) RMW instructions are prohibited. | | | | | | | | 1 | | |-------------|----------------------------------------------|---------|---|---|---|---|---|---| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit symbol | | | | | - | | | | | Read/Write | | . (( )) | | ١ | V | | | | | After reset | )/> | | | | - | | | | | Function | B1H: WDT disable code<br>4EH: WDT clear code | | | | | | | | #### Disable/clear WDT | B1H | Disable code | |--------|--------------| | 4EH | Clear code | | Others | Don't care | Page 204 2007-12-03 # 13. Special timer for CLOCK The TMP91CW60 includes a timer that is used for a clock operation. An interrupt (INTRTC) can be generated each 0.0625 [s] or 0.125 [s] or 0.25 [s] or 0.50 [s] by using a low frequency clock of 32.768 kHz. A clock function can be easily used. In addition, INTRTC can return from each standby mode except STOP mode. A special timer for CLOCK can operate in all modes in which a low-frequency oscillation is operated. The special timer for CLOCK is controlled by the special timer for CLOCK control register (RTCCR) as shown in. ## 13.1 Configuration Figure 13-1 Block Diagram for Special Timer for CLOCK #### Special Timer for CLOCK Control Register RTCCR (0310H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------------------|---|------|----------|---|----------------------------------------------------------------------------------------------------------|---------|-----------------------------| | Bit symbol | | | - ( | 77/_ | - | RTCSEL1 | RTCSEL0 | RTCRUN | | Read/Write | R/W | _ | (- ( | <u> </u> | - | R | /W | R/W | | After reset | 0 | | // | ) | - | 0 | 0 | 0 | | Function | Always write "0". | | | - | ı | 00: 2 <sup>14</sup> /fs<br>01: 2 <sup>13</sup> /fs<br>10: 2 <sup>12</sup> /fs<br>11: 2 <sup>11</sup> /fs | | 0: Stop & clear<br>1: Count | Counting operation | <rtcrun></rtcrun> | 0 | Stop & clear | |-------------------|---|--------------| | (IN ORONA) | 1 | Count | Interrupt generation cycle (fs = 32.768 kHz) | <rtcsel1:0></rtcsel1:0> | 00 | 0.50 s | |-------------------------|----|----------| | | 11 | 0.25 s | | | 10 | 0.125 s | | | 11 | 0.0625 s | Page 205 2007-12-03 ## 14. Electrical Characteristics ## 14.1 Absolute Maximum Ratings | Parameter | Symbol | Pin name | Rating | Unit | |---------------------------------------------|--------------------------|-------------------------------------------------|-------------------------------|------| | Supply voltage | V <sub>CC</sub> | | -0.5 to 6.0 | ) v | | Input voltage | V <sub>IN</sub> | | -0.5 to V <sub>CC</sub> + 0.5 | V | | Output current (Per pin) | I <sub>OL1</sub> | P5, P6, P96, P97 | (2)) | mA | | Output current (Per pin) | I <sub>OL2</sub> | P0, P1, P2, P3, P4, P7, P8, P90-P95, PA, PB, PZ | 5 | mA | | Output current (Per pin) | I <sub>OH1</sub> | P5, P6, P96, P97 | <u> </u> | mA | | Output current (Per pin) | I <sub>OH2</sub> | P0, P1, P2, P3, P4, P7, P8, P90-P95, PA, PB, PZ | -5 | mA | | Output current (Total) | $\Sigma I_{OL}$ | (7) | > 80 | mA | | Output current (Total) | $\Sigma$ I <sub>OH</sub> | | \$80 | mA | | Power dissipation (T <sub>OPR</sub> = 85°C) | PD | | 600 | mW | | Soldering temperature (10 s) | T <sub>SOLDER</sub> | | 260 | √ °C | | Storage temperature | T <sub>STG</sub> | | -65 to 150 | °C | | Operating temperature | T <sub>OPR</sub> | | -40 to 85 | °C | Note: Absolute maximum ratings are limiting values of operating and environmental conditions which should not be exceeded under the worst possible conditions. The equipment manufacturer should design so that no absolute maximum rating value is exceeded. Exposure to conditions beyond those listed above may cause permanent damage to the device or affect device reliability, which could increase potential risks of personal injury due to IC blowup and/or burning. #### Solderability of lead free products | Test Parameter | Test Condition | Note | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | Solderability | Use of Sn-37Pb solder Bath Solder bath temperature 230 °C, Dipping time 5 [s] The number of times One, Use of R-type flux Use of Sn-3.0Ag-0.5 Cu solder Bath Solder bath temperature 245°C, Dipping time 5 [s] The number of times One, Use of R-type flux (use of lead free) | Pass: solderability rate until forming ≥ 95% | ## 14.2 DC Electrical Characteristics | | Parameter | Symbol | Condition | Min | Тур. | Max | Unit | |----------------------------|--------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------|-----------------------|------| | Power<br>supply<br>voltage | $(AV_{CC} = DV_{CC})$ $(AV_{SS} = DV_{SS} = 0V)$ | V <sub>CC</sub> | fc = 4 to 20 MHz<br>fs = 30 to 34 kHz | 4.5 | | 5.5 | V | | | P00 to P17(AD0 to AD15) | V <sub>IL</sub> | | | | 0.8 | | | Low-level | P20 to P27, PZ0 to PZ3 | V <sub>IL1</sub> | | | | 0.3 V <sub>CC</sub> | | | input volt- | RESET, NMI, P30 to PB3 | $V_{IL2}$ | $V_{CC} = 4.5 \text{ to } 5.5 \text{ V}$ | -0.3 | 7\\ | 0.25 V <sub>CC</sub> | V | | age | AM0, AM1 | V <sub>IL3</sub> | • | | | 0.3 | | | | X1 | $V_{IL4}$ | | | | 0.2 V <sub>CC</sub> | | | | P00 to P17(AD0 to AD15) | V <sub>IH</sub> | | 2.2 | V | | | | High-level | P20 to P27, PZ0 to PZ3 | V <sub>IH1</sub> | | 0.7 V <sub>CC</sub> | | | | | input volt- | RESET, NMI, P30 to PB3 | V <sub>IH2</sub> | V <sub>CC</sub> = 4.5 to 5.5 V | 0.75 V <sub>CC</sub> | | V <sub>CC</sub> + 0.3 | V | | age | AM0, AM1 | V <sub>IH3</sub> | | V <sub>CC</sub> - 0.3 | | | | | | X1 | V <sub>IH4</sub> | | 0.8 V <sub>CC</sub> | | | | | Low-level o | utput voltage | V <sub>OL</sub> | I <sub>OL</sub> = 1.6 mA<br>(V <sub>CC</sub> = 4.5 to 5.5 V) | | 7 | 0.45 | V | | High-level o | output voltage | V <sub>OH</sub> | $I_{OH} = -400 \mu\text{A}$ $(V_{CC} = 4.5 \text{ to } 5.5 \text{ V})$ $I_{OH} = -1.6 \text{mA}$ $(V_{CC} = 4.5 \text{ to } 5.5 \text{ V})$ | 2.4 | ) | | ٧ | | Input leaka | ge current | I <sub>LI</sub> | $0.0 \le V_{IN} \le V_{CC}$ | | 0.02 | ± 5 | ۸ | | Output leak | age current | I <sub>L</sub> o ( | $0.2 \leq V_{IN} \leq V_{CC} - 0.2$ | | 0.05 | ± 10 | μА | | Power down<br>(while RAM | n voltage<br>is being backed up in STOP mode) | V <sub>STOP</sub> | $V_{1L2} = 0.2 V_{CC}$<br>$V_{1H2} = 0.8 V_{CC}$ | 2.0 | | 5.5 | V | | RESET pull | -up resistor | R <sub>RST</sub> | V <sub>CC</sub> = 4.5 to 5.5 V | 50 | | 230 | kΩ | | Pin capacita | ance | C <sub>IO</sub> | fc = 1 MHz | | | 10 | pF | | Schmitt wid | | V <sub>TH</sub> | V <sub>CC</sub> = 4.5 to 5.5 V | 0.4 | 1.0 | | ٧ | | Programma | ble pull-up resistor | RKH | V <sub>CC</sub> = 4.5 to 5.5 V | 50 | | 230 | kΩ | | NORMAL (N | Note 2) | | V <sub>CC</sub> = 4.5 to 5.5 V | | 18 | 26 | | | IDLE2 | IDLE2 | | $V_{CC} = 4.5 \text{ to } 5.5 \text{ V}$ $f_{C} = 20 \text{ MHz}$ | | 6.5 | 14.5 | mA | | IDLE1 | | | | | 2.5 | 7.5 | | | ` | SLOW (Note 2) | | V <sub>CC</sub> = 4.5 to 5.5 V | | 48 | 75 | | | IDLE2 | | 91 | fs = 32.768 kHz | | 28 | 55 | μΑ | | IDLE1 | | | > | | 24 | 47 | | | STOP | | | $V_{CC} = 4.5 \text{ to } 5.5 \text{ V}$ | | 0.5 | 10 | μΑ | Note 1: Typical values show those at $T_{OPR} = 25^{\circ}C$ and VDD = 5 V. Note 2: $I_{CC}$ measurement conditions (NORMAL, SLOW): All functions are operational; output pins are open and input pins are level fixed. Data and address bus CL = 30 pF loaded. Page 207 2007-12-03 ## 14.3 AC Characteristics 14.3.1 $V_{CC} = 5.0 \text{ V} \pm 10\%$ | No. | Parameter | Symbol | Vari | iable | f <sub>FPH</sub> = | 20MHz | Unit | |------|------------------------------------------------------------|-------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------|------| | 110. | r dramete. | Cymbol | Min | Max | Min | Max | OTHE | | 1 | f <sub>FPH</sub> period (= x) | t <sub>FPH</sub> | 50.0 | 31250 | 50.0 | | ns | | 2 | A0 to A15 valid → ALE falling | t <sub>AL</sub> | 0.5 x -15 | $\langle \langle \langle \langle \langle \langle \rangle \rangle \rangle \rangle \rangle \langle \langle \langle \langle \langle \langle \rangle \rangle \rangle \rangle \rangle \langle \langle \langle \langle \langle \langle \rangle \rangle \rangle \rangle \rangle \langle \langle \langle \langle \langle \langle \langle \rangle \rangle \rangle \rangle \rangle \rangle \langle \langle \langle \langle \langle \langle \langle \langle \rangle \rangle \rangle \rangle \rangle \rangle \langle \langle \langle \langle \langle \langle \langle \langle \langle \rangle \rangle \rangle \rangle \rangle \rangle \rangle \langle \rangle \rangle \rangle \rangle \rangle \rangle \rangle \langle \rangle \rangle \rangle \rangle \rangle \rangle \rangle \rangle \langle \langle$ | // 99 | | ns | | 3 | ALE falling → A0 to A15 hold | $t_{LA}$ | 0.5 x -15 | | 10 | | ns | | 4 | ALE high pulse width | t <sub>LL</sub> | x –20 | | 30 | | ns | | 5 | ALE falling $\rightarrow \overline{\text{RD/WR}}$ falling | t <sub>LC</sub> | 0.5 x -20 | | 5 | | ns | | 6 | $\overline{RD}$ rising $\longrightarrow$ ALE rising | t <sub>CLR</sub> | 0.5 x -15 | | 10 | 7( // | ns | | 7 | $\overline{ m WR}$ rising $ ightarrow$ ALE rising | t <sub>CLW</sub> | x-15 | $\rightarrow$ | 35 | | ns | | 8 | A0 to A15 valid → RD/WR falling | t <sub>ACL</sub> | x –25 | ) < | 25 | | ns | | 9 | A0 to A21 valid → RD/WR falling | t <sub>ACH</sub> | 1.5 x -50 | | 25 | | ns | | 10 | $\overline{\text{RD}}$ rising $\rightarrow$ A0 to A21 hold | toar | 0.5 x -20 | ( | 5 | / | ns | | 11 | WR rising → A0 to A21 hold | tcaw | x -20 | | 30 | | ns | | 12 | A0 to A15 valid → D0 to D15 input | t <sub>ADL</sub> | | 3.0 x –45 | 5) | 105 | ns | | 13 | A0 to A21 valid → D0 to D15 input | t <sub>ADH</sub> | | 3.5 x -35 | | 140 | ns | | 14 | RD falling → D0 to D15 input | \t <sub>RD</sub> | | 2.0 x -40 | | 60 | ns | | 15 | RD low pulse width | t <sub>RR</sub> | 2.0x -20 | $\searrow$ | 80 | | ns | | 16 | $\overline{RD}$ rising $\rightarrow$ D0 to D15 hold | t <sub>HR</sub> | 0 | <b>&gt;</b> | 0 | | ns | | 17 | RD rising → A0 to A15 output | t <sub>RAE</sub> | x-15 | | 35 | | ns | | 18 | WR low pulse width | t <sub>WW</sub> | 1.5x -20 | | 55 | | ns | | 19 | D0 to D15 valid $\rightarrow$ WR rising | t <sub>DW</sub> | 1.5x -50 | | 25 | | ns | | 20 | WR rising → D0 to D15 hold | t <sub>WD</sub> | x -15 | | 35 | | ns | | 21 | A0 to A23 valid to WAIT input ((1+N) WAIT mode) | t <sub>AWH</sub> | | 3.5x - 90 | | 85 | ns | | 22 | A0 to A15 valid to WAIT input ((1+N) WAIT mode) | t <sub>AWL</sub> | | 3.0x - 80 | | 70 | ns | | 23 | WAIT hold after RD/WR asserted((1+N) WAIT mode) | t <sub>CW</sub> | 2.0x + 0 | | 100 | | ns | | 24 | A0 to A21 valid -> Port input | t <sub>APH</sub> | | 3.5x -120 | | 55 | ns | | 25 | A0 to A21 valid → Port hold | t <sub>APH2</sub> | 3.5x | | 175 | | ns | | 26 | A0 to A21 valid Port valid | t <sub>AP</sub> | | 3.5x + 100 | | 275 | ns | AC measuring conditions - Output level:High $0.7V_{CC}/Low \ 0.3V_{CC}$ , $CL = 50 \ pF$ - Input level:High $0.9V_{CC}/Low \ 0.1V_{CC}$ Note: Symbol "x" in the above table means the period of clock "f<sub>FPH</sub>", it's half period of the system clock "f<sub>SYS</sub>" for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-oscillator frequency. Page 208 2007-12-03 ## 14.3.2 Read cycle Note: Since the CPU accesses the internal area to read data from a port, the control signals of external pins such as $\overline{\text{RD}}$ and $\overline{\text{CS}}$ are not enabled. Therefore, the above waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative. Page 209 2007-12-03 ## 14.3.3 Write cycle Note: Since the CPU accesses the internal area to write data to a port, the control signals of external pins such as WA and CS are not enabled. Therefore, the waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative. Figure 14-2 Write cycle ## 14.4 AD Conversion Characteristics $\mathsf{AV}_\mathsf{CC} = \mathsf{V}_\mathsf{CC}, \, \mathsf{AV}_\mathsf{SS} = \mathsf{V}_\mathsf{SS}$ | Parameter | Symbol | Variable | Min | Typ. | Max | Unit | |-------------------------------------------------------------------|-------------------------------------------|--------------------------------|-------------------------|-----------------|-------------------------|------| | Analog reference voltage (+) | $V_{REFH}$ | | V <sub>CC</sub> – 1.5 V | V <sub>CC</sub> | V <sub>CC</sub> | V | | Analog reference voltage (-) | A <sub>VSS</sub> | | V <sub>SS</sub> | V <sub>SS</sub> | V <sub>SS</sub> + 0.2 V | V | | Analog input voltage range | V <sub>AIN</sub> | | A <sub>VSS</sub> | | ) V <sub>REFH</sub> | V | | Analog current for analog reference voltage <vrefon> = 1</vrefon> | I <sub>REF</sub> (A <sub>VSS</sub> = 0 V) | V <sub>CC</sub> = 4.5 to 5.5 V | | 1.44 | 2.00 | mA | | <vrefon> = 0</vrefon> | | | | 0.02 | 5.0 | μА | | Error (Not including quantizing errors) | = | | | ± 1.0 | ± 4.0 | LSB | Note 1: $1LSB = (V_{REFH} - A_{VSS})/1024 [V]$ Note 2: The operation above is guaranteed for $f_{\mbox{\scriptsize FPH}} \geq 4$ MHz. Note 3: The value for $I_{CC}$ includes the current which flows through the $A_{VCC}$ pin. Page 211 2007-12-03 ## 14.5 Serial Channel Timing (I/O internal mode) ## 14.5.1 SCLK input mode | Parameter | Symbol | Variable | 20 MHz 16 MHz | | | | Unit | | |------------------------------------------------------------------------|------------------|-----------------------------------------------------|----------------------|----------|-----|------|------|------| | | | Min | Max | Min ( | Max | Min | Max | Unit | | SCLK period | t <sub>SCY</sub> | 16x | | 800 | ) | 1000 | | ns | | Output data → SCLK rising/falling edge* | t <sub>oss</sub> | $t_{SCY}/2 - 4x - 85$<br>( $V_{CC} = 5V \pm 10\%$ ) | | 115 | 7 | 165 | | ns | | SCLK rising/falling edge* → Output data hold | t <sub>OHS</sub> | $t_{SCY}/2 + 2x + 0$ | | 500 | | 625 | | ns | | SCLK rising/falling edge* $\rightarrow$ Input data hold | t <sub>HSR</sub> | 3x + 10 | | 160 | | 198 | | ns | | SCLK rising/falling edge* $\rightarrow$ Valid data input* | t <sub>SRD</sub> | | t <sub>SCY</sub> = 0 | <b>/</b> | 800 | | 1000 | ns | | $\mbox{Valid data input} \rightarrow \mbox{SCLK rising/falling edge*}$ | t <sub>RDS</sub> | 0 | | 0 < | ) \ | | | ns | Note: Symbol "x" in the above table means the period of clock "f<sub>FPH</sub>", it's half period of the system clock "f<sub>SYS</sub>" for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-oscillator frequency. ## 14.5.2 SCLK output mode | Parameter | Symbol | Variable | | 20 MHz | | 16 MHz | | Unit | |----------------------------------------------|------------------|--------------------------|----------------------------|--------|-----|--------|-----|-------| | | | Mín | Max | Min | Max | Min | Max | Offic | | SCLK period | t <sub>SCY</sub> | ) 16x | 8192x | 0.8 | 410 | 1.0 | 512 | μS | | Output data → SCLK rising/falling edge* | toss | t <sub>SCY</sub> /2 - 40 | | 360 | | 460 | | ns | | SCLK rising/falling edge* → Output data hold | tons | t <sub>SCY</sub> /2 - 40 | 7/^ | 360 | | 460 | | ns | | SCLK rising/falling edge* → Input data hold | tHSR | Q (V) | | 0 | | 0 | | ns | | SCLK rising/falling edge* → Valid data input | t <sub>SRD</sub> | | t <sub>SCY</sub> – 1x – 90 | | 660 | | 847 | ns | | Valid data input → SCLK rising/falling edge* | t <sub>RDS</sub> | 1x + 90 | | 140 | | 153 | | ns | Note 1: \*: SCLK rising/falling edge:The rising edge is used in SCLK rising mode. The falling edge is used in SCLK falling mode. Note 2: 20 MHz and 16 MHz values are calculated from $t_{SCY}$ = 16x case. Note 3: Symbol "x" in the above table means the period of clock "f<sub>FPH</sub>", it's half period of the system clock "f<sub>SYS</sub>" for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-oscillator frequency. Page 212 2007-12-03 ## 14.6 Event Counter TA0IN, TA4IN, TB0IN0, TB0IN1, TB1IN0, TB1IN1, TB2IN0, TB2IN1, TB3IN0, TB3IN1, TB4IN0, TB4IN1 | Parameter | Symbol | Variable | | 20 MHz | | 16 MHz | Unit | |------------------------|-------------------|----------|-----|--------|-----|---------|-------| | | | Min | Max | Min | Max | Min Max | Offic | | Clock period | t <sub>VCK</sub> | 8x + 100 | | 500 | | 600 | ns | | Clock low-level width | t <sub>VCKL</sub> | 4x + 40 | | 240 | | 290 | ns | | Clock high-level width | t <sub>VCKH</sub> | 4x + 40 | | 240 | | 290 | ns | Note: Symbol "x" in the above table means the period of clock "f<sub>FPH</sub>", it's half period of the system clock "f<sub>SYS</sub>" for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-oscillator frequency. # 14.7 Interrupt and Capture # 14.7.1 NMI, INTO interrupts | Parameter Symbol | | Variable | | 20 MHz | | 16 MHz | Unit | |----------------------------|--------------------|----------|-----|--------|-----|---------|-------| | | | Min | Max | Min | Max | Min Max | Offic | | NMI, INT0 low-level width | t <sub>INTAL</sub> | 4x + 40 | | 240 | | 290 | ns | | NMI, INT0 high-level width | t <sub>INTAH</sub> | 4x + 40 | | 240 | (7/ | 290 | ns | Note: Symbol "x" in the above table means the period of clock "f<sub>FPH</sub>", it's half period of the system clock "f<sub>SYS</sub>" for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-oscillator frequency. # 14.7.2 INT1 to INT10 interrupts, capture INT1 to INT10 input pulse width depend on the system clock selection and clock selection for prescaler. Below table show pulse width of each operation clock. | System Clock<br>Selection | Clock Selection for | | TBL<br>v level pulse width) | t <sub>IN</sub><br>(INT1 to INT10 hig | 11.7 | | |---------------------------|-------------------------------------|-------------|-----------------------------|---------------------------------------|---------------------------|------| | SYSCR1 | Prescaler SYSCR0<br><prck1></prck1> | Variable | f <sub>FRH</sub> = 20MHz | Variable | f <sub>FPH</sub> = 20 MHz | Unit | | <sysck></sysck> | | Min | Min | Min | Min | | | 0 (fc) | 0 (f <sub>FPH</sub> ) | 8x + 100 | 500 | 8x + 100 | 500 | ns | | 0 (10) | 1 (fc/16) | 128xc + 0.1 | 6.5 | 128xc + 0.1 | 6.5 | us | | 1 (fc) | 0 (f <sub>FPH</sub> ) | 8x + 0.1 | 244.3 | 8x + 0.1 | 244.3 | us | Note 1: "xc" shows period of clock fc in high frequency oscillator. Note 2: Symbol "x" in the above table means the period of clock "f<sub>FRH</sub>", it's half period of the system clock "f<sub>SYS</sub>" for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-oscillator frequency. Page 214 2007-12-03 # 14.8 SCOUT Pin AC Characteristics | Parameter | Symbol | Variable | | 20 MHz | | 16 MHz | | Condition | Unit | |------------------|------------------|-----------|-----|--------|-----|--------|-----|------------------------|-------| | Farameter | Symbol | Min | Max | Min | Max | Min | Max | Condition | Offic | | Low-level width | t <sub>SCH</sub> | 0.5T – 15 | | 10 | | 16 | | V <sub>CC</sub> ≥ 4.5V | ns | | High-level width | t <sub>SCL</sub> | 0.5T – 15 | | 10 | | 16 | / | V <sub>CC</sub> ≥ 4.5V | ns | Note: T = Period of SCOUT Measuring conditions Output level: High = 0.7 $V_{CC}$ , Low = 0.3 $V_{CC}$ , CL = 10 pF # 14.9 Flash Characteristics # 14.9.1 Write/Retention Characteristics $(V_{SS} = 0 V)$ | Parameter | Condition | Min | Тур. | Max. | Unit | |---------------------------------------------|----------------------------------------------------------------------------------------|-----|------|------|-------| | Number of guaranteed writes to flash memory | $V_{SS} = 0 \text{ V}$ fc = 4 to 20 MHz $T_{OPR} = -10 \text{ to } 40^{\circ}\text{C}$ | - | - | 100 | Times | **TMP91CW60** # 14.10 Recommended Oscillating Conditions The TMP91CW60 has been evaluated by the oscillator vender below. Use this information when selecting external parts. - Note 1: To ensure stable oscillation, the resonator position, load capacitance, etc. must be appropriate. Because these factors are greatly affected by board patterns, please be sure to evaluate operation on the board on which the device will actually be mounted. - Note 2: When using the device (oscillator) in places exposed to high electric fields such as cathode-ray tubes, we recommend electrically shielding the package in order to maintain normal operating condition. - Note 3: The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following URL: http://www.murata.co.jp/search/index.html TOSHIBA TMP91CW60 # 15. Table of SFR's The special function registers (SFRs) include the I/O ports and peripheral control registers allocated to the 4-Kbyte address space from 000000H to 000FFFH. Page 217 2007-12-03 Table 15-1 SFR Address Map (PORT, INTC, CS/WAIT) | [1]PORT | | | | | | |-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------| | Address | Name | Address | Name | Address | Name | | 0000H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH<br>BH<br>CH<br>DH | P0<br>P1<br>P0CR<br>P1CR<br>P1FC<br>P2<br>P2CR<br>P2FC<br>P3<br>P3FC2<br>P3CR | 0010H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH<br>BH<br>CH<br>DH | P4 P4FC2 P4CR P4FC P5 P5CR P5FC P6 P6CR P6FC P7 P7CR | 0020H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH<br>BH<br>CH<br>DH | P8CR<br>P8FC<br>P9<br>P9CR<br>P9FC<br>PA<br>PACR<br>PAFC<br>PB<br>PBFC2 | | FH | P3FC | FH | 1 1 / / 1 | ) $\Diamond$ EH | | | | | | | [2]INTC | > | | Address | Name | Address | Name | Address | Name | | 0030H<br>1H<br>2H<br>3H<br>4H | | 0070H<br>1H<br>2H<br>3H<br>4H | | 0080H<br>1H<br>2H<br>3H<br>4H | DMA0V<br>DMA1V<br>DMA2V<br>DMA3V | | 5H<br>6H<br>7H<br>8H | | 5H<br>6H<br>7H<br>8H | | 5H<br>6H<br>7H<br>8H | INTCLR | | 9H<br>AH<br>BH<br>CH<br>DH | | 9H<br>AH<br>BH<br>CH | PZ | on<br>9H<br>AH<br>BH<br>CH<br>DH | DMAR<br>DMAB | | EH<br>FH | ODE | EH<br>EH | PZCR<br>PZFC | EH<br>FH | | | | 5/2 | | > | [3]CS/WAIT | | | Address | Name | Address | Name | Address | Name | | 0090H<br>1H<br>2H<br>3H<br>4H | INTE0AD<br>INTE12<br>INTE34<br>INTE56<br>INTE78 | 00A0H<br>1H<br>2H<br>3H<br>4H | INTETB4VRTC<br>INTES0<br>INTES1<br>INTES2<br>INTESBI01 | 00C0H<br>1H<br>2H<br>3H<br>4H | B0CS<br>B1CS<br>B2CS<br>B3CS | | 5H<br>6H<br>7H<br>8H<br>9H | INTE910<br>INTETA01<br>INTETA23<br>INTETA45<br>INTETB0 | 5H<br>6H<br>7H<br>8H<br>9H | INTETC01<br>INTETC23 | 5H<br>6H<br>7H<br>8H<br>9H | MSAR0<br>MAMR0 | | AH<br>BH<br>CH<br>DH<br>EH | INTETB1<br>INTETB2<br>INTETB3<br>INTETB4<br>INTETB01V<br>INTETB23V | AH<br>BH<br>CH<br>DH<br>EH | | AH<br>BH<br>CH<br>DH<br>EH | MSAR1<br>MAMR1<br>MSAR2<br>MAMR2<br>MSAR3<br>MAMR3 | | | | | | J | | Note: Do not access to the unnamed addresses (e.g., addresses to which no register has been allocated). 2007-12-03 Page 218 Table 15-2 SFR Address Map (CGEAR, TMRA, TMRB) | Address | Name | |---------|--------| | 00E0H | SYSCR0 | | 1H | SYSCR1 | | 2H | SYSCR2 | | 3H | EMCCR0 | | 4H | EMCCR1 | | 5H | | | 6H | | 7H 8H 9H AH BH СН DH EH FH [5] TMRA ess Name Addre | Address | Name | |---------|-----------| | 00F0H | | | 1H | | | 2H | | | 3H | | | 4H | | | 5H | | | 6H | | | 7H | | | 8H | | | 9H | | | AH | | | ВН | $\sim$ | | CH | | | DH | (O) | | EH | $(\vee/)$ | | FH | | | | | Address Name 0100H TA01RUN 2H TA0REG 3H) TA1REG 4H TA01MOD 5H TA1FFCR 6H 7H 8H TA23RUN 9H AHTA2REG ВН TA3REG TA23MOD CH TA3FFCR DH ÉΗ [6] TMRB | Address | Name | |---------|---------| | 0110H | TA45RUN | | 1H | | | 2H | TA4REG | | 3H | TA5REG | | 4H | TA45MOD | | 5H | TA5FFCR | | 6H | | | 7H | | | 8H | | | 9H | | | AH | | | BH | | | СН | | | DH | | | EH | | | FH | | | [ס] וווואס | (( ) | |------------|----------| | Address | Name | | 0180H | TB0RUN | | /(1H) | | | 2H | TB0MOD / | | 3H | TB0FFCR | | ( \ \4H | | | 5H | | | 6H | | | )) 7H | | | 8H | TB0RG0L | | 9H | TB0RG0H | | ) AH | TB0RG1L | | BH | TB0RG1H | | CH | TB0CP0L | | HQ | ТВ0СР0Н | | EH | TB0CP1L | | FH | ТВ0СР1Н | | | · | | Address | Name | |-------------|---------| | ( ) ) 0190H | TB1RUN | | 1H | | | 2H | TB1MOD | | 3H | TB1FFCR | | 4H | | | 5H | | | 6H | | | 7H | | | 8H | TB1RG0L | | 9H | TB1RG0H | | AH | TB1RG1L | | ВН | TB1RG1H | | CH | TB1CP0L | | DH | TB1CP0H | | EH | TB1CP1L | | FH | TB1CP1H | | Address | Name | |---------|-----------| | 01A0H | TB2RUN | | | | | 2H | TB2MOD | | 3H | TB2FFCR < | | 4H | | | 5H | | | 6H | | | 7H | | | 8H | TB2RG0L | | 9H | TB2RG0H | | AH | TB2RG1L | | ВН | TB2RG1H | | CH | TB2CP0L | | DH | TB2CP0H | | EH | TB2CP1L | | FH | TB2CP1H | | 4 | | |---------|---------| | Address | Name | | 01B0H | TB3RUN | | )) 1H | | | 2H | TB3MOD | | 3H | TB3FFCR | | 4H | | | 5H | | | 6H | | | 7H | | | 8H | TB3RG0L | | 9H | TB3RG0H | | AH | TB3RG1L | | ВН | TB3RG1H | | CH | TB3CP0L | | DH | TB3CP0H | | EH | TB3CP1L | | FH | TB3CP1H | | | | | Address | Name | |---------|---------| | 01C0H | TB4RUN | | 1H | | | 2H | TB4MOD | | 3H | TB4FFCR | | 4H | | | 5H | | | 6H | | | 7H | | | 8H | TB4RG0L | | 9H | TB4RG0H | | AH | TB4RG1L | | BH | TB4RG1H | | CH | TB4CP0L | | DH | TB4CP0H | | EH | TB4CP1L | | FH | TB4CP1H | Note: Do not access to the unnamed addresses (e.g., addresses to which no register has been allocated). Page 219 2007-12-03 Table 15-3 SFR Address Map (UART/SIO, I<sup>2</sup>C, ADC, WDT, RTC, ROMC) | [7] UART/SIO | | | | | [8] I <sup>2</sup> C | | |--------------|---------------|----------|----------------------|-------------|----------------------|----------------| | Address | Name | Address | Name | | Address | Name | | 0200H | SC0BUF | 0210H | SC2BUF | | 0240H | SBI0CR1 | | 1H | SC0CR | 1H | SC2CR | | <b>7H</b> | SBI0DBR | | 2H | SC0MOD0 | 2H | SC2MOD0 | | 2H | I2C0AR | | 3H | BR0CR | 3H | BR2CR | | 3H | SBI0CR2/SBI0SR | | 4H | BR0ADD | 4H | BR2ADD | | 4H | SBI0BR | | 5H | SC0MOD1 | 5H | SC2MOD1 | $\wedge$ | ((// \ 5H | | | 6H | | 6H | | | 6H | | | 7H | | 7H | | | 7H | SBI0CR0 | | 8H | SC1BUF | 8H | | | ) > 8H | SBI1CR1 | | 9H | SC1CR | 9H | | | 9H | SBI1DBR | | AH | SC1MOD0 | AH | ^(( | | AH | I2C1AR | | BH | BR1CR | BH | (1) | | / BH | SBI1CR2/SBI1SR | | CH | BR1ADD | СН | | | SH | SBIIBR | | DH | SC1MOD1 | DH | ((//< | \ ` | DH | | | EH | | EH | | / | C EH | | | FH | | FH | | | FA | SBI1CR0 | | | | • | 7() | | | <b>)</b> | | [9]10bit ADC | | [10] WDT | 4 | | [11] RTC | | | Address | Name | Address | Name | | Address | Name | | 02B0H | ADCCR1 | 0300H | WDMOD | | // 0310H | RTCCR | | 1H | ADCCR2 | (1H | WDCR | / / | 1H | TO OT | | 2H | ADCDRL | 2H | | | 2H | | | 3H | ADCDRH | 3H | | 1 | 3H | | | 4H | - | 4H | | | 4H | | | 5H | | 5H | | <b>\</b> // | 5H | | | 6H | | 6H | $\wedge$ | | 6H | | | 7H | | ( 7H | | | 7H | | | 8H | | 8H | | | 8H | | | 9H | / | 9H | | | 9H | | | AH | | (// AH | | | AH | | | BH | | ВН | $(\bigcap \bigwedge$ | | ВН | | | CH | (( ) _ | CH | $(\vee/))$ | | CH | | | DH | | DH | | | DH | | | EH | | EH | | | EH | | | FH | $\rightarrow$ | FH | | | FH | | | < | $\sim \gamma$ | | | | | | | [12] ROMC | | | /<br> | 1 1 | | | | Address | Name | Address | Name | | Address | Name | | 0400H | ROMCMP00 | 0410H | ROMCMP20 | | 0420H | ROMCMP40 | | 1H | ROMCMP01 | 1H | ROMCMP21 | | 1H | ROMCMP41 | | 2H | ROMCMP02 | 2H | ROMCMP22 | | 2H | ROMCMP42 | | 3H | | 3H | | | 3H | | | 4H | ROMSUB0L < | 4H | ROMSUB2L | | 4H | ROMSUB4L | | 5H | ROMSUB0H | 5H | ROMSUB2H | | 5H | ROMSUB4H | | 6H | | 6H | | | 6H | | | 7H | | 7H | | | 7H | | | 8H | ROMCMP10 | 8H | ROMCMP30 | | 8H | ROMCMP50 | | 9H | ROMCMP11 | 9H | ROMCMP31 | | 9H | ROMCMP51 | | AH | ROMCMP12 | AH | ROMCMP32 | | AH | ROMCMP52 | | BH | | BH | | | BH | | | CH | ROMSUB1L | CH | ROMSUB3L | | CH | ROMSUB5L | | DH | ROMSUB1H | DH | ROMSUB3H | | DH | ROMSUB5H | | EH | | EH | | | EH | | | FH | | FH | 1 | | FH | | Note: Do not access to the unnamed addresses (e.g., addresses to which no register has been allocated). Page 220 2007-12-03 ## (1) I/O Ports | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|----------|---------|--------------|-----------------|-----------------|--------------------------------------------|--------------------------------------------------------------|----------------------------------|--------| | | | | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | | P0 | Port 0 | 00H | | | ı | R | W | | | | | | | | | D | ata from exter | rnal port (Outp | out latch regist | er is undefined | (.b | | | | | | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | | P1 | Port 1 | 01H | | | | R | W | | <i>r</i> | | | | | | | Da | ta from externa | al port (Outpu | t latch registe | r is cleared to ' | "0".) | | | | | | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | | P2 | Port 2 | 06H | | | | R | W | | | | | | | | | [ | Data from exte | rnal port (Out | out latch regis | ter is set to "1" | ·.) | | | | | | _ | - | _ | -( | P33 | P32 | P31 | P30 | | P3 | Port 3 | 0CH | - | _ | - | 51 | | /R/ | w | | | FS | Poils | ОСП | _ | _ | _ | | > | | external port | | | | | | | | _ | $((// \land)$ | (0 | utput latch reg | ister is set to | "1".) | | | | | - | - | - | P44 | P43 | P42 | P41 | P40 | | | | | - | - | -( | | | R/W | | | | P4 | Port 4 | 10H | - | - | 4- | | | a from external tch register is | | | | | | | - | - ( | | | | register): Pull-<br>register): Pull | | | | | | | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | | P5 | Port 5 | 14H | | | $\rightarrow$ | // R | W | | | | | | | | | | ata from exte | rnal port (Out | out latch regis | ter is set to "1" | '.) | | | | | | P67 | P66 | P65 | P64 | P63 | P62 | P61 | P60 | | P6 | Port 6 | 18H | | , _ | | R | W | | | | | | | | | )) [ | Data from exte | rnal port (Out | out latch regis | ter is set to "1" | ·.) | | | | | | | ) - | P75 | P74 | P73 | P72 | P71 | P70 | | P7 | Port 7 | 1CH | (//- {) | - | | 7) | | _ | | | | | | | | - | (7) | Data from exte | rnal port (Out | out latch regist | ter is set to "1 | ".) | | | | | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | P8 | Port 8 | 20H | | | | R | /W | | | | | | | | Ŷ | 1 | | | _ | ter is set to "1" | ".) | | | | | > | P97 | P96 | P95 | P94 | P93 | P92 | P91 | P90 | | P9 | Port 9 | 24H | ^ | | <b>/</b> | R | /W | | | | | | | | Z | | Oata from exte | rnal port (Out | out latch regis | ter is set to "1" | '.) | | | ^ | | ) | - | | _ | _ | PA3 | PA2 | PA1 | PA0 | | PA | Port A | 28H/> | (-) | \ <u>\</u> - | - | - | | R/ | W | | | ( | | | 2 | ) - | - | - | (0 | Data from e<br>utput latch reg | external port<br>ister is set to | "1".) | | | | <b>✓</b> | 1/- | - | _ | _ | PB3 | PB2 | PB1 | PB0 | | DD | Dort D | 2011 | _ | - | _ | _ | | R/ | W | 1 | | PB | Port B | 2CH | | | | | | Data from e | external port | | | | | | - | - | - | - | (O | utput latch reg | ister is set to | "1".) | | | | | - | - | - | - | PZ3 | PZ2 | PZ1 | PZ0 | | | | | - | - | - | - | | R/ | W | _ | | PZ | Port Z | 7DH | - | - | _ | - | (Output late | external port<br>ch register is<br>o "1".) | 1 | 1 | | | | | | | | | 0 (Output la<br>Pull-up re<br>1 (Output la | tch register):<br>sistor OFF<br>tch register):<br>esistor ON | outpu | t mode | Page 221 2007-12-03 ## (2) I/O Port control | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----------------------------------------|---------------------------------|-------------|---------------|----------------|----------------------------------------------------------------------------------------------|-------------------|------------------------|---------------------|--------------------| | | | | P07C | P06C | P05C | P04C | P03C | P02C | P01C | P00C | | | Port 0 | 02H<br>(RMW instruc- | | | | , | W | | | | | P0CR | control | tions are pro- | 0 | 0 | 0 | 0 | 0 | Q | 0 | 0 | | | | hibited.) | 0: Input | 1: Output (WI | nen access to | external, bec | ome AD7 to Al | D0 and this re | gister is clear | ed to "0".) | | | | 0.411 | P17C | P16C | P15C | P14C | P13C | P12C | P11C | P10C | | | Port 1 | 04H<br>(RMW instruc- | | ı | | | w ( | 7 | ı | | | P1CR | control | tions are pro- | 0 | 0 | 0 | 0 | 0 | <u>)</u> 0 | 0 | 0 | | | | hibited.) | | I | < | <refer col<="" td="" to=""><td>umn of P1FC&gt;</td><td>·&gt;</td><td>I</td><td></td></refer> | umn of P1FC> | ·> | I | | | | | OELL | P17F | P16F | P15F | P14F | P13F) | P12F | P11F | P10F | | DATO | Port 1 | 05H<br>(RMW instruc- | | | | | W | | | | | P1FC | function | tions are pro- | 0 | 0 | 0 | 01/ | 0 | 0 ~ | 0 | 0 | | | | hibited.) | | P1FC/ | /P1CR = 00: Ir | nput, 01: Outp | out, 10: AD15 t | o AD8, 11; A1 | 5 to A8 | | | | | 08H | P27C | P26C | P25C | P24C | P23C | P22C | P21C | P20C | | DOCD | Port 2 | (RMW instruc- | | • | | | w | 170 | (/)) | | | P2CR | control | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ 0 | 0 | | | | hibited.) | | • | 400 | Refer to col | umn of P2FC> | | • | | | | | 09H | P27F | P26F | P25F | P24F | P23F | P22F | P21F | P20F | | P2FC | Port 2 | (RMW instruc- | | | | , | w ( <i>(</i> //< | | | | | FZIC | function | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | (O) | <i>)</i> 0 | 0 | 0 | | | | filbited.) | | P2F | C/P2CR = 00: | Input, 01: Ou | tput, 10: A7 to | A0, 11: A23 to | o A16 | | | | | | ı | | > - | | P33C | P32C | P31C | P30C | | | Port 3 | 0EH<br>(RMW instruc- | - | ((-)) | _ | - | $\checkmark/$ | \ | N | | | P3CR | control | tions are pro- | -0 | | - | _ | 0 | 0 | 0 | 0 | | | | hibited.) | 4( | ))- | - / | | | column of C>> | | column of C2>> | | | | | | | E | | P33F | P32F | P31F | P30F | | | | | ( ( / - ) ) | _ | | <u> </u> | | | N | | | | | | _ | /~ | (7/1) | _ | 0 | 0 | 0 | 0 | | | | 0EH | | | | | | P32F/ | | | | P3FC | Port 3 | (RMW instruc- | , | | | | P33F/<br>P33C= | P32C= | | | | . 0. 0 | function | tions are pro-<br>hibited.) | ` | | | | 00:input | 00:input | . Defer to | column of | | | | ) | - | -// | _ | _ | port | port<br>01:output | | C2>> | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | $\sim$ | | > | | | 01:output<br>port | port | | | | | | | d | | | | 11:TB3OUT1 | 10: WAIT<br>11:TB3OUT0 | | | | $\rightarrow$ | | ) | (= | <u></u> | _ | _ | _ | - | P31F2 | P30F2 | | | | $\wedge$ | | \ | _ | _ | _ | _ | | N | | < | | | ? <u>\</u> | | _ | _ | _ | _ | 0 | 0 | | | | 7 | | | | | | | P31F2/ | P30F2/ | | | | 0DH | | | | | | | P31F/ | P30F/ | | P3FC2 | Port 3 function 2 | (RMW instruc-<br>tions are pro- | | | | | | | P31C=<br>000:input | P30C=<br>000:input | | | TUTICUON Z | tions are pro-<br>hibited.) | | | | | | | port | port | | | | | _ | _ | _ | _ | _ | _ | 001:output | 001:output | | | | | | | | | | | port | port<br>010:TB3IN0 | | | | | | | | | | | 010:TB3IN1<br>/INT4 | /INT3 | | | | | | | ĺ | | | | 101: SCL0 | 101: SDA0 | Page 222 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------------|---------------------------------|------------|------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------| | -, | | | _ | _ | _ | P44C | P43C | P42C | P41C | P40C | | | Port 4 | 12H<br>(RMW instruc- | _ | _ | _ | | | W | | | | P4CR | control | tions are pro- | _ | _ | _ | 0 | 0 | 0 | 0 | 0 | | | | hibited.) | | _ | _ | | | to column of | | | | | | | _ | _ | _ | P44F | P43F | P42F | P41F | P40F | | | D | 13H | _ | _ | _ | | 1 101 | W | | 1 101 | | P4FC | Port 4 function | (RMW instruc-<br>tions are pro- | | | | 0 < | | 0 | 0 | 0 | | | | hibited.) | | _ | _ | 0 | 11.11 | to column of | - | U | | | | | | | | | P43F2 | _ | P41F2 | P40F2 | | | | | | | | | W W | | | V F40F2 | | | | | | | | -(( | | / | | | | | | 11H | _ | _ | _ | 4/ | 0 | - 4 | 0 | 0 | | P4FC2 | Port 4 | (RMW instruc- | | | | P44F,P44C=<br>00: input | P43F2,P43F<br>,P43C= | P42F,P42C=<br>00: input | P41F2,P41F<br>, P41C = | P40F2,P40F<br>, P40C = | | 1 41 02 | function 2 | tions are pro- | | | | port | 000 :input | port | 000: input | 000: input | | | | hibited.) | - | - | - | 01: output | port 001:output | 01: output | port | port<br>001:output | | | | | | | | prort<br>11:ALE | port | port | 001: output<br>port | port | | | | | | | | 11:ALE | 011:CS3<br>101:SCLK2 | 11: <u>CS2</u> | 011:CS1<br>101:TXD2 | 011: CS0<br>101: SCOUT | | | | | P57C | P56C | P55C | P54C | P53C | P52C | P51C | P50C | | | D . 5 | 16H | 10/0 | 1 000 | 1000 | | w (7/< | \ | 1010 | 1 000 | | P5CR | Port 5<br>control | (RMW instruc-<br>tions are pro- | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | | hibited.) | | | | | 1: Output | 0 | Ů | • | | | | | P57F | P56F | P55F | P54F | P53F | P52F | P51F | P50F | | | | 4711 | 1 3/1 | (130) | 1 331 | | W / 931 | 1 321 | 1311 | 1 301 | | | Port 5 | 17H<br>(RMW instruc- | 0/~ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | P5FC | function | tions are pro- | P57 input | P56 input | | | | | | | | | | hibited.) | 0: disable | 0: disable | P55 input<br>0: disable | P54 input<br>0: disable | P53 input<br>0: disable | P52 input<br>0: disable | P51 input<br>0: disable | P50 input<br>0: disable | | | | | 1: enable | | | | P67C | P66C | P65C | P64C | P63C | P62C | P61C | P60C | | D00D | Port 6 | 1AH<br>(RMW instruc- | | $\wedge$ | ((//3) | , | W | | | | | P6CR | control | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | hibited.) | | | 7/ | 0: Input | 1: Output | | | | | | | | P67F | P66F | P65F | P64F | P63F | P62F | P61F | P60F | | | | 1BH | | | > | | W | | | | | P6FC | Port 6 | (RMW instruc- | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | POPC | function | tions are pro- | P67 input | P66 input | P65 input | P64 input | P63 input | P62 input | P61 input | P60 input | | | | hibited.) | 0: disable | | | $\langle \rangle$ | 1: enable | (= | | 1EH | | ) – | P75C | P74C | P73C | P72C | P71C | P70C | | P7CR | Port 7 | (RMW instruc- | | - | | | 1 | N | | | | 17010 | control | tions are pro-<br>hibited.) | | - | 0 | 0 | 0 | 0 | 0 | 0 | | | | inblied.) | _ | _ | | | 0: Input | 1: Output | | | | | | | _ | - | P75F | P74F | - | P72F | P71F | _ | | | Dort 7 | 1FH | _ | - | 1 | N | - | 1 | N | - | | P7FC | Port 7 function | (RMW instruc-<br>tions are pro- | - | - | 0 | 0 | - | 0 | 0 | - | | | | hibited.) | _ | _ | 0: Port | 0: Port | _ | 0: Port | 0: Port | _ | | | | | _ | _ | 1: INT0 | 1: TA5OUT | _ | 1: TA3OUT | 1: TA1OUT | _ | Page 223 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------------|---------------------------------|-------------------------|-------------------------|--------------------|------------|-----------------------|----------------------------------------------------------------------------|-----------------------|----------------------| | -, | | | P87C | P86C | P85C | P84C | P83C | P82C | P81C | P80C | | | Port 8 | 22H<br>(RMW instruc- | | | | | N , | | 1 | | | P8CR | control | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | hibited.) | | | | | 1: Output | | | | | | | | P87F | P86F | P85F | P84F | P83F | P82F | P81F | P80F | | | | 23H | | | | | N ( | | | | | D0E0 | Port 8 | Z3FI<br>(RMW instruc- | 0 | 0 | 0 | 0 < | 0 | 0 | 0 | 0 | | P8FC | function | tions are pro- | | Ů | 0: port | 0: port | 7/1 | | 0: port | 0: port | | | | hibited.) | 0: port<br>1: TB1OUT1 | 0: port<br>1: TB1OUT0 | 1: TB1IN1, | 1: TB1IN0, | 0: port<br>1: TB00UT1 | 0: port<br>1: TB00UT0 | 1: TB0IN1, | 1: TB0IN0, | | | | | 1. 1510011 | 1. 1510010 | INT8 | INT7 | (III) | 1. 1500010 | INT6 | INT5 | | | | 26H | P97C | P96C | P95C | P94C | P93C | P92C | P91C | P90C | | P9CR | Port 9 | (RMW instruc- | | | | | N | | | | | 1 0011 | control | tions are pro-<br>hibited.) | 1 | 1 | 0 | 0 | <b>O</b> | 0/2 | 9 | 0 | | | | filbited.) | | | | 0: Input | 1: Output | | | | | | | | P97F | P96F | P95F | ) | P93F | P92F | (/)} | P90F | | | | 27H | | W | 2 | \ <u></u> | | M> | ) | W | | P9FC | Port 9 | (RMW instruc- | 0 | 0 | 40 | > - | 0 ( | 0 | - | 0 | | | function | tions are pro-<br>hibited.) | Port | Port | 0: port | | 0: port | 0: port | | 0: port | | | | | 0: disable<br>1: enable | 0: disable<br>1: enable | 1: SCLK1<br>output | - | 1: TXD1<br>output | 1: SCLK0<br>output | _ | 1: TXD0<br>output | | | | | 1. Chabic | 1. criabic | output | | PA3C | PA2C | PA1C | PA0C | | | 5 | 2AH | _ | | | / | YASC | | W | FAUC | | PACR | Port A control | (RMW instruc-<br>tions are pro- | _ | | <u> </u> | | )0 | 0 | 0 | 0 | | | | hibited.) | | $(\bigcirc)$ | | _ | \/\ <sup>0</sup> | | 1: Output | U | | | | | | \ \ - | | | PA3F | PA2F | PA1F | PA0F | | | | 0.011 | | ))_ | _ ( | | 17101 | | <i>N</i> | 17101 | | | Port A | 2BH<br>(RMW instruc- | | | | | 0 | 0 | 0 | 0 | | PAFC | function | tions are pro- | $(\sqrt{/})$ | <u> </u> | | | 0 | 0 | 0: port | 0: port | | | | hibited.) | | _ | $(0 \rightarrow )$ | _ | 0: port | 0:port<br>1: TB2OUT0 | 1: TB2IN1, | 1: TB2IN0, | | | | | | | ( | | 1: TB2OUT1 | 1: 1B2OU10 | INT2 | INT1 | | | | 2EH | _ | | )- | _ | PB3C | PB2C | PB1C | PB0C | | PBCR | Port B | (RMW instruc- | - | 1 | 1 | - | | 1 | W | | | 1 BOIL | control | tions are pro-<br>hibited.) | - | 1 | - | - | 0 | 0 | 0 | 0 | | | 7 | Tilbiteu.) | - ^ | - | - | _ | < | <refer colu<="" td="" to=""><td>ımn of PBFC2</td><td>&gt;&gt;</td></refer> | ımn of PBFC2 | >> | | | | 2FH | - ~ | - | - | - | PB3F | PB2F | PB1F | PB0F | | PBFC | Port B | (RMW instruc- | - ( | _ | - | - | | 1 | W | | | FBI C | function | tions are pro- | (- | \ \ \ - | - | - | 0 | 0 | 0 | 0 | | | | hibited.) | | ) - | _ | - | < | <refer colu<="" td="" to=""><td>mn of PBFC2</td><td>&gt;&gt;</td></refer> | mn of PBFC2 | >> | | | | 2 | <u></u> | - | - | - | - | - | PB1F2 | PB0F2 | | | | * | - | - | - | - | - | - | / | V | | | · | | _ | - | - | - | - | - | 0 | 0 | | | Port B | 2DH | | | | | DDGE DTT | DDCE DESC | PB1F2,PB1 | PB0F2,PB0 | | PBFC2 | function 2 | (RMW instruc-<br>tions are pro- | | | | | PB3F, PB3C<br>= | PB2F, PB2C<br>= | F, PB1C = 000: input | F, PB0C = 000: input | | | | hibited.) | _ | _ | _ | _ | 00: input<br>port | 00: input<br>port | port<br>001: output | port<br>001:output | | | | | _ | | _ | _ | 01: output | 01: output | port | port | | | | | | | | | port<br>11:TB4OUT1 | port<br>11:TB4OUT0 | 010: TB4IN1<br>/INT10 | 010: TB4IN0<br>/INT9 | | | | | | | | | | | 101: SCL1 | 101: SDA1 | Page 224 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------------------|---------------------------------|---|-------|-------|----------------|-------------------|-------------------|------------------|------------------| | | | 7EH | - | - | - | - | PZ3C | PZ2C | - | - | | PZCR | Port Z | (RMW instruc- | 1 | _ | ı | - | Ş | V | _ | - | | FZOR | control | tions are pro- | - | - | - | - | 0 | 0 | _ | - | | | | hibited.) | ı | - | ı | ı | 0:Input | 1:Output | _ | - | | | | | ı | _ | ı | - | PZ3F | PZ2F | PZ1F | PZ0F | | | Port Z | 7FH<br>(BMW instrue | - | _ | - | - | | | N | | | PZFC | function | (RMW instruc-<br>tions are pro- | ı | - | ı | - | 0 \ | ))0 | 0 | 0 | | | | hibited.) | - | - | - | - | 0: port<br>1:R/ W | 0: port<br>1: HWR | 0: port<br>1: WR | 0: port<br>1: RD | | | | | 1 | ODEB1 | ODEB0 | ODE93 | ODE90 | ODE41 | ODE31 | ODE30 | | ODE | Open-drain control | 3FH | - | | | $\mathcal{A}($ | R/W | . ( | | | | ODL | register | JIII | _ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | - | | | 0: CMOS or | itput 1:Open | drain output | | | ## (3) Interrupt control | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------------------|-----------|----------------------|---------------|----------------|--------|-----------|--------|----------------|--------| | | | | | IN | TAD | | | IN | IT0 | | | | Interrupt | | IADC | IADM2 | IADM1 | IADM0 | IOC / | I0M2 | IOM1 | IOMO | | INTE0AD | enable | 90H | R | | R/W | | R | 7/ | R/W | | | | 0 & AD | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTAD | | Interrput leve | l | 1: INT0 | | Interrput leve | I | | | | | | IN | IT2 | | (0 | Z/\ IN | IT1 | | | | Interrupt | | I2C | I2M2 | I2M1 | 12M0 | 110 | J1M2 | I1M1 | I1M0 | | INTE12 | enable | 91H | R | | R/W | | R | | R/W | | | | 2/1 | | 0 | 0 | 0 | 0 | ((0)) | 0 | 0 | 0 | | | | | 1: INT2 | | Interrput leve | | 1: INT1 | | Interrput leve | | | | | | | IN | IT4 | d | | TV | 113 | | | | Interrupt | | I4C | I4M2 | I4M1 | I4M0 | I3C | I3M2 | I3M1 | I3M0 | | INTE34 | enable | 92H | R | | R/W | ((// | R | | R/W | | | | 4/3 | | 0 | 0 | 0 | 0 | 0 | 1078 | ()) | 0 | | | | | 1: INT4 | | Interrput leve | | 1: INT3 | | Interrput leve | | | | | | | NI II | IT6 | | (( | /IN | IT5 | | | | Interrupt | | I6C | I6M2 | 16M1 | 16M0 | I5C | J5M2 | I5M1 | I5M0 | | INTE56 | enable | 93H | R | ( | R/W | | (R)/ | | R/W | | | | 6/5 | | 0 | 0 | 0 | 0 | (0) | ) 0 | 0 | 0 | | | | | 1: INT6 | 4 | Interrput leve | // | 1: INT5 | | Interrput leve | | | | | | | N N | 118 | | | IN | IT7 | | | | Interrupt | | I8C | [8M2] | I8M1 | 18M0 | //rc | I7M2 | I7M1 | I7M0 | | INTE78 | enable | 94H | R | | R/W | ^ | R | | R/W | | | | 8/7 | | <b>ø</b> ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INT8 | | Interrput leve | | 1: INT7 | | Interrput leve | I | | | | | $(7/\land$ | IN | T10 | 7/ | | IN | IT9 | | | | Interrupt | | 4100 | I10M2 | 110M1 | 110M0 | I9C | I9M2 | I9M1 | I9M0 | | INTE910 | enable | / (95H) L | R | | (R/W) | | R | | R/W | | | | 10 / 9 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INT10 < | | Interrput leve | I | 1: INT9 | | Interrput leve | Ī | | | ^/ | > | | INTTA1 | (TMRA1) | | | INTTA0 | (TMRA0) | | | | Interrupt | \ h | ITA1C | ITA1M2 | TA1M1 | ITA1M0 | ITA0C | ITA0M2 | ITA0M1 | ITA0M0 | | INTETA01 | enable<br>timer A | 96H | R | > | R/W | | R | | R/W | | | ^ | 1/0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1:/INTTA1 | $\rightarrow$ | Interrput leve | l | 1: INTTA0 | | Interrput leve | 1 | | | | | $\langle () \rangle$ | ) INTTA3 | (TMRA3) | | | INTTA2 | (TMRA2) | | | | Interrupt | | ITA3C | ITA3M2 | ITA3M1 | ITA3M0 | ITA2C | ITA2M2 | ITA2M1 | ITA2M0 | | INTETA23 | enable<br>timer A | 97H | R | | R/W | | R | | R/W | | | | 3/2 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTTA3 | | Interrput leve | I | 1: INTTA2 | | Interrput leve | İ | | | | | | INTTA5 | (TMRA5) | | | INTTA4 | (TMRA4) | | | | Interrupt<br>enable | | ITA5C | ITA5M2 | ITA5M1 | ITA5M0 | ITA4C | ITA4M2 | ITA4M1 | ITA4M0 | | INTETA45 | timer A | 98H | R | | R/W | | R | | R/W | | | | 5 / 4 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTTA5 | | Interrput leve | I | 1: INTTA4 | | Interrput leve | Í | Page 226 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|---------------------|----------|-------------|-------------|----------------|---------------|--------------|----------------|----------------------------------|-----------|--| | 5, | | 7.44.000 | • | | (TMRB0) | | | | (TMRB0) | | | | | lata | | ITB01C | ITB01M2 | ITB01M1 | ITB01M0 | ITB00C | ITB00M2 | ITB00M1 | ITB00M0 | | | INTETB0 | Interrupt<br>enable | 99H | R | | R/W | | R | | R/W | | | | | TMRB 0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 1: INTTB01 | | Interrput leve | | 1: INTTB00 | | Interrput leve | l | | | | | | | INTTB11 | (TMRB1) | | | INTTB10 | (TMRB1) | | | | | Interrupt | | ITB11C | ITB11M2 | ITB11M1 | ITB11M0 | ITB10C | ITB10M2 | ITB10M1 | ITB10M0 | | | INTETB1 | enable | 9AH | R | | R/W | | R | | R/W | L | | | | TMRB 1 | | 0 | 0 | 0 | 0 | ((0)) | 0 | 0 | 0 | | | | | | 1: INTTB11 | | Interrput leve | | 1: INTTB10 | | Interrput leve | | | | | | | | INTTB21 | (TMRB2) | 4 | | INTTB20 | (TMRB2) | | | | | Interrupt | | ITB21C | ITB21M2 | ITB21M1 | ITB21M0 | ITB20C | ITB20M2 | ITB20M1 | ITB20M0 | | | INTETB2 | enable | 9BH | R | | R/W | ((///) | R | | R/W | | | | | TMRB 2 | | 0 | 0 | 0 | | 0 | 1070 | $\langle \rangle \rangle$ | 0 | | | | | | 1: INTTB21 | | Interrput leve | | 1: INTTB20 | | Interrput leve | l | | | | | | | INTTB31 | (TMRB3) | | | INTTB30 | (TMRB3) | | | | | Interrupt | | ITB31C | ITB31M2 | ITB31M1 | ITB31M0 | ITB30C | ITB30M2 | ITB30M1 | ITB30M0 | | | INTETB3 | enable | 9CH | R | | R/W | | (R)/ | | R/W | | | | | TMRB 3 | | 0 | 0 | 0 | 0 | (0) | ) 0 | 0 | 0 | | | | | | 1: INTTB31 | | Interrput leve | 1 // | 1: INTTB30 | | Interrput level | | | | | | | | INTTB41 | (TMRB4) | | | INTTB40 | (TMRB4) | | | | | Interrupt | | ITB41C | ITB41M2 | ITB41M1 | ITB41M0 | ITB40C | ITB40M2 | ITB40M1 | ITB40M0 | | | INTETB4 | enable<br>TMRB 4 | 9DH | R | | R/W | ^ | ✓ R | | R/W | | | | | TIVIND 4 | | <b>Ø</b> ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 1: INTTB41 | | Interrput leve | $\rightarrow$ | 1: INTTB40 | | Interrput leve | | | | | | | + | | IRB1 over flow | 4 | | | IRB0 over flow | | | | | Interrupt<br>enable | | ITF10 | ITF1M2 | ITE1M1 | ITF1M0 | ITF0C | ITF0M2 | ITF0M1 | ITF0M0 | | | INTETB01V | TMRB 0/1 | 9EH) | R | | (R/W) | | R | | R/W | | | | | (Over flow) | /// | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | | | | | 1: INTTBOF1 | V | Interrput leve | | 1:INTTBOF0 | NITTO 0 50 (T. | Interrput leve | | | | | Interrupt | > | | | IRB3 over flow | 1 | | | IRB2 over flow | | | | INITETEOON/ | enable | | ITF3C | ITF3M2 | ITF3M1 | ITF3M0 | ITF2C | ITF2M2 | ITF2M1 | ITF2M0 | | | INTETB23V | TMRB 2/3 | 9FH | R | ^ | R/W | ٥ | R | 0 | R/W | 0 | | | $\wedge$ | (Over flow) | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | / | 1: INTTBOF3 | INIT | Interrput leve | I | 1:INTTBOF2 | NITTROE4/TN | Interrput leve<br>IRB4 over flow | | | | | Interrupt | | IRTCC | IRTCM2 | IRTCM1 | IRTCM0 | ITF4C | ITF4M2 | ITF4M1 | ITF4M0 | | | INTETB4VRTC | enable<br>TMRB4 | A0H | R | IIX I OIVIZ | R/W | IIX I CIVIO | R R | 111 41112 | R/W | TTT 4IVIU | | | "ALTIDANKIO | (Over flow)/ | AUII | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | INTRTC | | 1: INTRTC | 0 | Interrput leve | | 1:INTTBOF4 | 0 | Interrput leve | | | | | | | 1. 11411110 | | ciiput ieve | ! | 1.1141 10014 | | ciiput ieve | • | | Page 227 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|-----------|-----------|-------------|---------|----------------|---------------|------------|---------|----------------|---------| | | | | | INT | TX0 | | | INT | RX0 | | | | Interrupt | | ITX0C | ITX0M2 | ITX0M1 | ITX0M0 | IRX0C | IRX0M2 | IRX0M1 | IRX0M0 | | INTES0 | enable | A1H | R | | R/W | | R | | R/W | • | | | serial 0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTTX0 | | Interrput leve | <u> </u> | 1: INTRX0 | | Interrput leve | l | | | | | | INT | TX1 | | | INT | RX1 | | | | Interrupt | | ITX1C | ITX1M2 | ITX1M1 | ITX1M0 | IRX1C | IRX1M2 | IRX1M1 | IRX1M0 | | INTES1 | enable | A2H | R | | R/W | L | R | | R/W | | | | serial 1 | | 0 | 0 | 0 | 0 | ((0)) | 0 | 0 | 0 | | | | | 1: INTTX1 | | Interrput leve | | 1: INTRX1 | | Interrput leve | I | | | | | | INT | TX2 | 4 | | TMI | RX2 | | | | Interrupt | | ITX2C | ITX2M2 | ITX2M1 | ITX2M0 | IRX0C | IRX2M2 | IRX2M1 | IRX2M0 | | INTES2 | enable | АЗН | R | | R/W | $((// \land)$ | R | | R/W | | | | serial 2 | | 0 | 0 | 0 | | 0 | 100 | //) | 0 | | | | | 1: INTTX2 | | Interrput leve | | 1: INTRX2 | | Interrput leve | I | | | | | | INT | SBI1 | | | INT | SBI0 | | | | Interrupt | | ISBI1C | ISBI1M2 | ISBI1M1 | ISBI1M0 | ISBI0C | ISBI0M2 | ISBI0M1 | ISBI0M0 | | INTESBI01 | enable | A4H | R | ( | R/W | | (R)/ | | R/W | | | | SBI 0/1 | | 0 | 0 | 0 | 0 | (0) | ) 0 | 0 | 0 | | | | | 1: INTSBI1 | 4 | Interrput leve | | 1: INTSBIO | | Interrput leve | l | | | | | | INT | TC1 | | | INT | TC0 | | | | Interrupt | | ITC1C | ITC1M2 | ITC1M1 | ITC1M0 | /ITC0C | ITC0M2 | ITC0M1 | ITC0M0 | | INTETC01 | enable | A5H | R | | R/W | ^ | ✓ R | | R/W | | | | TC 0/1 | | ø ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTTC1 | | Interrput leve | 7/ | 1: INTTC0 | | Interrput leve | l | | | | | $(7/\wedge$ | INT | тсз < | 7/ | | INT | TC2 | | | | Interrupt | | TC3C | ITC3M2 | ITC3M1 | тСЗМ0 | ITC2C | ITC2M2 | ITC2M1 | ITC2M0 | | INTETC23 | enable | // A6H) \ | R | | (R/W) | | R | | R/W | | | | TC 2/3 | \\/\[\ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTTC3 < | | Interrput leve | | 1: INTTC2 | | Interrput leve | I | Page 228 2007-12-03 | Name DMA0 Start Vector | Address | 7 | 6 | 5<br>DMA0V5 | 4 | 3 | 2 | 1 | 0 | |--------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Start | 0011 | | | DIVIAUVS | DMA0V4 | DMA0V3 | DMA0V2 | DMA0V1 | DMA0V0 | | | | _ | _ | | | R. | w | | | | | 80H | _ | _ | 0 | 0 | 0 | 0 | 0 | 0 | | | | _ | _ | | | DMA0 st | art vector | > | | | | | _ | _ | DMA1V5 | DMA1V4 | DMA1V3 | DMA1V2 | DMA1V1 | DMA1V0 | | DMA1 | 0411 | - | _ | | | R | W | • | | | Vector | 81H | _ | _ | 0 | 0 | 0 | <i>)</i> 0 | 0 | 0 | | | | _ | _ | | | DMA1 st | art vector | ı | | | | | _ | _ | DMA2V5 | DMA2V4 | DMA2V3 | DMA2V2 | DMA2V1 | DMA2V0 | | DMA2 | 02H | - | - | | ^(( | R | w | | | | Vector | 02П | _ | _ | 0 | 0 | 0 | 0 | 0 | 0 | | | | _ | _ | | (7) | DMA2 st | art vector | | | | | | - | _ | DMA3V5 | DMA3V4 | DMA3V3 | DMA3V2 | DMA3V1 | DMA3V0 | | DMA3 | 02LI | _ | _ | | | R | W | | | | Vector | оэп | _ | _ | 0 | 0 | 0 ( | 0 | 0 | 0 | | | | - | _ | (1) | $\rightarrow$ | DMA3 st | art vector | | | | | 0011 | - | - ( | CLRV5 | CLRV4 | CLRV3 | CLRV2 | CLRV1 | CLRV0 | | Interrupt | 88H<br>(RMW instruc- | _ | - | | | | N | | | | Control | tions are pro- | _ | 5 | 0 | /0 | 0 | 0 | 0 | 0 | | | nibited.) | - | | | | Interrup | ot vector | | | | DMA | 0011 | _ | ((-)) | _ | -// | DMAR3 | DMAR2 | DMAR1 | DMAR0 | | Software | (RMW instruc- | -( | | _ | _ | <b>\</b> | R | /W | | | Request | tions are pro- | +( | 5)- | - ~ | //- | 0 | 0 | 0 | 0 | | Register | nibited.) | | <u> </u> | - /5 | | | 1: DMA soft | ware request | | | | | (///) | _ | 7 | - [2 | DMAB3 | DMAB2 | DMAB1 | DMAB0 | | DMA<br>Buret | 9,44 | | _ | (77) | _ | | R | /W | | | Register | OAH | | <i>\( \)</i> | (E) | _ | 0 | 0 | 0 | 0 | | | /// | - | | | _ | | 1: DMA bu | ırst request | | | | | > - | | | _ | _ | I0EDGE | IOLE | NMIREE | | | > | | | | 1 | N | | | | | Interrupt | 8CH | 0 / | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | input<br>mode<br>control | (RMW instructions are prohibited.) | Always<br>write "0". | >_ | _ | _ | _ | INT0<br>EDGE<br>0: Rising<br>1: Falling | INT0<br>mode<br>0: Edge<br>1: Level | 1:Operates even on rising/falling edge of NMI | | | Start Vector DMA2 Start Vector DMA3 Start Vector Interrupt Clear Control DMA Software Request Register DMA Burst Register | Start Vector DMA2 Start Vector DMA3 Start Vector Interrupt Clear Control DMA 89H Software (RMW instructions are prohibited.) DMA 89H Software (RMW instructions are prohibited.) DMA 89H Software (RMW instructions are prohibited.) | Start Vector 81H Vector | Start Vector Start Vector Start Star | Start Vector Start Vector Start Vector Start Vector Start Vector Start Vector Start Start Vector Start | Start Vector Start Vector Start Vector Start S | Start Vector Start Vector Start Vector Start Start Vector Start Start Vector Start Start Vector Start | Start Vector Start Vector Start Start Start Vector Start Start Start Vector Start Start Start Start Start Vector Start | Start Vector Vector Vector Start Vector | Page 229 2007-12-03 ## (4) Chip select / wait control | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------------------------------|----------------------------------------------|-------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------------------------------------|-------------------------------------------------------------------------|------------------------------|----------------------------------------| | | | | B0E | _ | B0OM1 | В0ОМ0 | B0BUS | B0W2 | B0W1 | B0W0 | | | | | W | - | | | ζ | V | | | | | Block 0 | C0H | 0 | - | 0 | 0 | 0 | 0 | 0 | 0 | | BOCS | CS/WAIT<br>control<br>register | (RMW instruc-<br>tions are pro-<br>hibited.) | 0: Disable<br>1: Enable | - | Chip selection form selection on: For ROM on: Don't can selection on: Don't can selection on the of | //SRAM<br>re<br>re | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | 000: 2 WAIT<br>001: 1 WAIT<br>010: 1 WAIT<br>011: 0 WAIT | Γ 100:<br>Γ 101:<br>Γ+N 110: | Reserved<br>3 WAIT<br>4 WAIT<br>8 WAIT | | | | | B1E | _ | B1OM1 | B1OM0 | B1BUS | B1W2 | B1W1 | B1W0 | | | | | W | _ | | | | V | | | | | Block 1 | C1H | 0 | - | 0 | 0 | 9 | 0 | 0 | 0 | | B1CS | CS/WAIT<br>control<br>register | (RMW instruc-<br>tions are pro-<br>hibited.) | 0: Disable<br>1: Enable | 1 | Chip select of form selection on: For ROM on: Don't can to: to | WSRAM<br>re<br>re | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | 000: 2 WAIT<br>001: 1 WAIT<br>010: 1 WAIT<br>011: 0 WAIT | 100:<br>101:<br>1+N 110: | Reserved<br>3 WAIT<br>4 WAIT<br>8 WAIT | | | | | B2E | B2M | B2OM1 | B2OM0 | B2BU\$ | B2W2 | B2W1 | B2W0 | | | | | | | | | W \ | | , | T | | | Block 2<br>CS/WAIT | C2H | 1 | 0 | 0 | 0 | (0// | 0 | 0 | 0 | | B2CS | control<br>register | (RMW instruc-<br>tions are pro-<br>hibited.) | 0: Disable<br>1: Enable | CS2 area<br>selection<br>0:16Mbyte<br>area<br>1: CS area | form selection form selection form selection for the selection for the selection form selection for the th | RAM<br>re<br>re | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | 000: 2 WAIT<br>001: 1 WAIT<br>010: 1 WAIT<br>011: 0 WAIT | Γ 100:<br>Γ 101:<br>Γ+N 110: | Reserved<br>3 WAIT<br>4 WAIT<br>8 WAIT | | | | | ВЗЕ | <u> </u> | B3OM1 | В3ОМ0 | B3BUS | B3W2 | B3W1 | B3W0 | | | | | W | IJ- | 1 | (2) | ١ | V | | | | | Block 3 | СЗН | (//0 < | ı | 0 | 0 | 0 | 0 | 0 | 0 | | B3CS | CS/WAIT<br>control<br>register | (RMW-instruc-<br>tions are pro-<br>hibited.) | 0: Disable<br>1: Enable | | Chip selection form selection (1) For ROM (1) Don't call (1) Don't call (1) Don't call (1) Chip selection (1 | //SRAM<br>re<br>re | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | Number of v<br>000: 2 WAIT<br>001: 1 WAIT<br>010: 1 WAIT<br>011: 0 WAIT | Γ 100:<br>Γ 101:<br>Γ+N 110: | Reserved<br>3 WAIT<br>4 WAIT<br>8 WAIT | | | | | _ | - | > - | _ | BEXBUS | BEXW2 | BEXW1 | BEXW0 | | | | $\sim$ | ( | <u> </u> | _ | | | <u> </u> | W | | | ^ | External | С7Н | - (1 | _ | - | _ | 0 | 0 | 0 | 0 | | BEXCS | CS/WAIT<br>control<br>register | (RMW instructions are pro-<br>hibited.) | | ) | - | - | Data bus<br>width<br>0: 16 bits<br>1: 8 bits | Number of v<br>000: 2 WAIT<br>001: 1 WAIT<br>010: 1 WAIT<br>011: 0 WAIT | Γ 100:<br>Γ 101:<br>Γ+N 110: | Reserved<br>3 WAIT<br>4 WAIT<br>8 WAIT | Page 230 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------------------|---------|------------------------------------------------------------------------|-----|---------------|--------------|-----------------|------------------|-----------|------| | | | | S23 | S22 | S21 | S20 | S19 | S18 | S17 | S16 | | MOADO | Memory | 0011 | | | | R | w | | | | | MSAR0 | address<br>register 0 | C8H | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | Dete | rmine A23 to | A16 of start ac | dress | | | | | Memory | | V20 | V19 | V18 | V17 | V16 | V15 | V14~V9 | V8 | | MAMR0 | address | C9H | | | | R | W ( | 7/ | | | | WAWKO | mask | Cerr | 1 | 1 | 1 | 1 < | 1 | ))1 | 1 | 1 | | | register 0 | | | | Set size of C | S0 area 0 | : Used for add | lress compare | ! | | | | | | S23 | S22 | S21 | S20 | S19 | <sup>)</sup> S18 | S17 | S16 | | MSAR1 | Memory<br>address | CAH | | | | R | W | | | | | WO TICE | register 1 | 07.11 | 1 | 1 | 1 | 1 | <b>\</b> | 1 | | 1 | | | | | | _ | Dete | rmine A23 to | A16 of start ac | ddress | | | | | Memory | | V21 | V20 | V19 | V18 | V17 | V16 | V15~V9 | V8 | | MAMR1 | address | СВН | | • | | R | /W \ | 7 | (/)) | | | | mask<br>register 1 | | 1 | 1 | 1 | 1 | 1 | | <u></u> 1 | 1 | | | | | | _ | Set size of C | | : Used for add | | | | | | Mamani | | S23 | S22 | S21 | S20 | S19 | \$18 | S17 | S16 | | MSAR2 | Memory address | ССН | | | $\overline{}$ | | M(Q) | | 1 | | | | register 2 | | 1 | 1 | 17 | 1 | (1) | ) 1 | 1 | 1 | | | | | | | | // | A16 of start ac | Т | I I | | | | Memory | | V22 | V21 | V20 | V19 | V18 | V17 | V16 | V15 | | MAMR2 | address<br>mask | CDH | | | | | W// | | | | | | register 2 | | 1 | , 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | S23 | S22 | Set size of C | S2 area 0 | : Used for add | | | 040 | | | Memory | | 523 | 522 | S21 | | ./W | S18 | S17 | S16 | | MSAR3 | address | CEH | $\left( \left\langle \left\langle \right\rangle \right\rangle \right)$ | 1 | | 1 | 1 1 | 1 | 1 | 1 | | | register 3 | | | ^ | Data | | A16 of start a | | ' | · · | | | | | V22 | V21 | V20 | V19 | V18 | V17 | V16 | V15 | | | Memory | 1 | V Z Z | VZI | V20 | | /W | V 17 | V 10 | V 13 | | MAMR3 | address<br>mask | CFH | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | register 3 | > | ' | | Set size of C | | : Used for add | | | | | | | 1 | | > | 001 3120 01 0 | oo area 0 | . Coca ioi auc | noos compare | | | Page 231 2007-12-03 ## (5) Clock control | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|------------------------------------------|---------|------------------------------------------------------------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | | | | XEN | XTEN | RXEN | RXTEN | RSYSCK | WUEF | PRCK1 | - | | | | | | • | • | R/W | | | • | - | | | | | 1 | 0 | 1 | 0 | 0 | 0 | 0 | - | | SYSCRO | System<br>clock<br>control<br>register 0 | ЕОН | High-<br>frequency<br>oscillator<br>0:Stop<br>1:Oscilla-<br>tion | Low-<br>frequency<br>oscillator<br>0:Stop<br>1:Oscilla-<br>tion | High-<br>frequency<br>oscillator<br>(fc) after<br>release of<br>STOP<br>mode<br>0:Stop<br>1:Oscilla-<br>tion | Low- frequency oscillator (fs) after release of STOP mode 0:Stop 1:Oscilla- tion | Selects clock after release of STOP mode 0:fc 1:fs | Warm-up timer control 0 Write: Don't care 1 Write: Start warm-up 0 Read: End warm-up 1 Read: Do not end warm-up | Select<br>prescaler<br>clock<br>0:f <sub>FPH</sub><br>1:fc/16 | _ | | | | | - | _ | - | = | SYSCK | GEAR2 | GEAR2 | GEAR2 | | | | | - | _ | -1 | | | ~ ~ ~ | W | 1 | | | | | - | - | 4-/ | <u> </u> | 0 (( | 0 | 0 | 0 | | SYSCR1 | SYSCR1 System clock control register 1 | E1H | - | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | ( <del>-</del> | Select system clock 0; fc 1: fs | 000:fc<br>001:fc/2<br>010:fc/4<br>011:fc/8<br>100:fc/16<br>101:reserve<br>110:reserve | d | requency (rc) | | | | | +( | SCOSEL | WUPTM1 | WUPTM0 | HALTM1 | HALTM0 | _ | DRVE | | | | | <u></u> | | ( | R/W | • | | _ | R/W | | | | | (77) | 0 | 4 | 0 | 1 | 1 | _ | 0 | | SYSCR2 | System clock control register 1 | E2H | | Select<br>SCOUT<br>0:fs<br>1:f <sub>SYS</sub> | Select warm<br>oscillator<br>00:2 <sup>18</sup> /input<br>quency<br>01:2 <sup>8</sup> /inputto<br>10:2 <sup>14</sup> /input<br>quency<br>11:2 <sup>16</sup> /input<br>quency | ted fre-<br>ed frequency<br>ted fre- | HALT mode<br>00:reserved<br>01:STOP m<br>10:IDLE1 m<br>11:IDLE2 m | ode<br>ode | ı | Pin state<br>control in<br>STOP<br>mode<br>0: I/O off<br>1:Remains<br>the state<br>before<br>HALT | | \ | | | PROTECT | - | _ | ı | _ | 1 | _ | _ | | | | | R | | | | R/W | | | | | EMCCR0 | EMC<br>control | E3H | | ) 0 | 1 | 0 | 0 | 0 | 1 | 1 | | LIVIOORU | register 0 | 2017 | Protect<br>flag<br>0:OFF<br>1:ON | Write "0". | Write "1". | Write "0". | Write "0". | Write "0". | Write "1". | Write "1". | | EMCCR1 | EMC<br>control<br>register 1 | E4H | | | | | y writing "1FH<br>iting except "1 | | | | Page 232 2007-12-03 ## (6) 8-bit timer | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|-------------------------------|---------------------------------|----------------------------------------------------------------------------------|-------------------------------|--------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------|--|--| | | | | TA0RDE | - | - | - | I2TA01 | TA01PRUN | TA1RUN | TA0RUN | | | | | | | R/W | - | _ | _ | | R | /W | | | | | | 8-bit | | 0 | 1 | 1 | - | 0 | 0 | 0 | 0 | | | | TA01RUN | timer<br>RUN | 100H | Double<br>buffer<br>0: Disable<br>1: Enable | - | 1 | - | IDLE2<br>0: Stop<br>1: Operate | TMRA01<br>prescaler<br>0: Stop and<br>1: Run (cour | | Up counter<br>(UC0) | | | | | 8-bit | 102H | | | | | -7//3 | | | | | | | TA0REG | timer | (RMW instruc-<br>tions are pro- | | | | , | W | > | | | | | | | register 0 | hibited.) | | | | | 0 | | | | | | | | 8-bit | 103H | | | | ^(( | 1/ | ( | | | | | | TA1REG | timer | (RMW instruc-<br>tions are pro- | | | | | w | | | | | | | | register 1 | hibited.) | | 0 | | | | | | | | | | | | | TA01M1 | TA01M0 | PWM01 | PWM00 | TA1CLK1 | TA1CLK0 | TA0CLK1 | TA0CLK0 | | | | | | | | | | R | /W | 17 | | | | | | | 8-bit<br>timer | | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | | TA01MOD | source<br>CLK &<br>mode | 104H | Operation m<br>00: 8-bit time<br>01: 16-bit tim<br>10: 8-bit PP0<br>11: 8-bit PW | er mode<br>ner mode<br>G mode | PWM cycle<br>00: Reserve<br>01: 2 <sup>6</sup><br>10: 2 <sup>7</sup><br>11: 2 <sup>8</sup> | d | Input clock f<br>00: TA0TRG<br>01: \phiT1<br>10: \phiT16<br>11: \phiT256 | - // | Input clock f<br>00: TA0IN p<br>01: φT1<br>10: φT4<br>11: φT16 | | | | | | | | - | | > - | <- | TA1FFC1 | TA1FFC0 | TA1FFIE | TA1FFIS | | | | | | | - | ((-)) | - | 7// | | R | /W | | | | | | 8-bit | | - ( | ) | 1 | _ | 1 | 1 | 0 | 0 | | | | TA1FFCR | timer<br>frip-flop<br>control | 105H | | <u>)</u> _ | | | 00: Invert TA<br>01: Set TA1<br>10: Clear TA<br>11: Don't ca | FF<br>\1FF | TA1FF control for inversion 0: Disable 1: Enable | TA1FF<br>inversion<br>select<br>0: TMRA0<br>1: TMRA1 | | | Page 233 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |---------|--------------------------------------|---------------------------------|----------------------------------------------------------------------------------|-------------------------------|--------------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------|--|--|--|--| | | | | TA2RDE | - | - | - | I2TA23 | TA23PRUN | TA3RUN | TA2RUN | | | | | | | | | R/W | - | - | - | / | R. | /W | | | | | | | | 8-bit | | 0 | 1 | _ | I | 0 | 0 | 0 | 0 | | | | | | TA23RUN | timer<br>RUN | 108H | Double<br>buffer<br>0: Disable<br>1: Enable | I | ı | - | IDLE2<br>0: Stop<br>1: Operate | TMRA23<br>prescaler<br>0: Stop and<br>1: Run (cour | | Up counter<br>(UC2) | | | | | | | 8-bit | 10AH | | | | | -//// | | | | | | | | | TA2REG | timer | (RMW instruc-<br>tions are pro- | | | | | W | > | | | | | | | | | register 0 | hibited.) | | 0 | | | | | | | | | | | | | 8-bit | 10BH | | | | | | | | | | | | | | TA3REG | timer | (RMW instruc-<br>tions are pro- | | | | () | w | 2 | | | | | | | | | register 1 | hibited.) | | 0 | | | | | | | | | | | | | | | TA23M1 | TA23M0 | PWM21 | PWM20 | TA3CLK1 | TA3CLK0 | TA2CLK1 | TA2CLK0 | | | | | | | 0 6 14 | | | | | F | R/W | 7 | | | | | | | | | 8-bit<br>timer | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | TA23MOD | source<br>CLK &<br>mode | 10CH | Operation m<br>00: 8-bit time<br>01: 16-bit tin<br>10: 8-bit PPC<br>11: 8-bit PW | er mode<br>ner mode<br>G mode | PWM cycle<br>00: Reserve<br>01: 2 <sup>6</sup><br>10: 2 <sup>7</sup><br>11: 2 <sup>8</sup> | | Input clock f<br>00: TA2TRG<br>01: \phiT1<br>10: \phiT16<br>11: \phiT256 | | Input clock f<br>00: Reserve<br>01: \phiT1<br>10: \phiT4<br>11: \phiT16 | | | | | | | | | | _ | | > - | <u> </u> | TA3FFC1 | TA3FFC0 | TA3FFIE | TA3FFIS | | | | | | | | | _ | | _ | 1 | | R | /W | | | | | | | | 8-bit | | - ( | | - | _ | 1 | 1 | 0 | 0 | | | | | | TA3FFCR | TA3FFCR timer frip-flop control 10DH | | | <u>)</u> _ | | | 00: Invert TA<br>01: Set TA3<br>10: Clear TA<br>11: Don't ca | FF<br>\3FF | TA3FF control for inversion 0: Disable 1: Enable | TA3FF<br>inversion<br>select<br>0: TMRA2<br>1: TMRA3 | | | | | Page 234 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------------------------------|---------------------------------|----------------------------------------------------------------------------------|-------------------------------|--------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------|----------------------------|----------------------------------------------------------------|------------------------------------------------------| | | | | TA4RDE | - | - | - | I2TA45 | TA45PRUN | TA5RUN | TA4RUN | | | | | R/W | - | - | - | / | R | /W | | | | 8-bit | | 0 | - | - | - | 0 | 0 | 0 | 0 | | TA45RUN | timer<br>RUN | 110H | Double<br>buffer | _ | _ | _ | IDLE2<br>0: Stop | TMRA45<br>prescaler | Up counter<br>(UC5) | Up counter<br>(UC4) | | | | | 0: Disable<br>1: Enable | | | 4 | 1: Operate | 0: Stop and<br>1: Run (cou | | | | | 8-bit | 112H | | | | | -7// | | | | | TA4REG | timer | (RMW instruc-<br>tions are pro- | | | | | W \ | > | | | | | register 0 | hibited.) | | | | | 0 | | | | | | 8-bit | 113H | | | | (( | | ( | | | | TA5REG | timer | (RMW instruc-<br>tions are pro- | | | | (,( | w | | | | | | register 1 | hibited.) | | | | (7/1) | 0 | | | | | | | | TA45M1 | TA45M0 | PWM41 | PWM40 | TA5CLK1 | TA5CLK0 | TA4CLK1 | TA4CLK0 | | | | | | | | F | R/W | 17 | | | | | 8-bit<br>timer | | 0 | 0 | 0 | 8 | 0 | 0 | 0 | 0 | | TA45MOD | source<br>CLK &<br>mode | 114H | Operation m<br>00: 8-bit time<br>01: 16-bit tin<br>10: 8-bit PPO<br>11: 8-bit PW | er mode<br>ner mode<br>G mode | PWM cycle<br>00: Reserve<br>01: 2 <sup>6</sup><br>10: 2 <sup>7</sup><br>11: 2 <sup>8</sup> | | Input clock f<br>00: TA4TRG<br>01: \$T1<br>10: \$T16<br>11: \$T256 | _ // | Input clock f<br>00: TA4IN p<br>01: φT1<br>10: φT4<br>11: φT16 | | | | | | _ | | _ | | TA5FFC1 | TA5FFC0 | TA5FFIE | TA5FFIS | | | | | _ | ((-)) | _ | 1 | | R | /W | | | | 8-bit | | - ( | | - | _ | 1 | 1 | 0 | 0 | | TA5FFCR | TA5FFCR timer frip-flop control | | | <u></u> | | | 00: Invert TA<br>01: Set TA5<br>10: Clear TA<br>11: Don't ca | FF<br>\5FF | TA5FF control for inversion 0: Disable 1: Enable | TA5FF<br>inversion<br>select<br>0: TMRA4<br>1: TMRA5 | Page 235 2007-12-03 ## (7) 16-bit timer | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------| | | | | TB0RDE | - | _ | - | I2TB0 | TB0PRUN | - | TB0RUN | | | | | R | /W | _ | - | R | w | _ | R/W | | | 16-bit | | 0 | 0 | _ | _ | 0 | 0 | _ | 0 | | TB0RUN | timer<br>control | 180H | Double<br>Buffer<br>0: Disable<br>1: Enable | Always<br>write 0. | - | - | IDLE2<br>0: Stop<br>1: Operate | TMRB0<br>prescaler<br>0: Stop and | | Up counter<br>(UC0) | | | | | TB0CT1 | TB0ET1 | TB0CP0I | TB0CPM1 | TB0CPM0 | 1: Run (cou | TB0CLK1 | TB0CLK0 | | | | | | /W | W* | TBOOT WIT | 1BOOT NO | R/W | IBOOLKI | TBOCERO | | | | | 0 | 0 | 1 | 0 | | 0 | 0 | 0 | | TB0MOD | 16-bit<br>timer<br>source<br>CLK &<br>mode | 182H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | TB0FF1 involutions of the control | | Software capture control 0: Software capture 1: Undefined | 01: TB0IN01<br>INT5 occur<br>10: TB0IN01<br>INT5 occurs<br>11: TA1OUT1 | s at rising edge TB0IN1↑ s at rising edge TB0IN0↓ s at falling edge | Up counter<br>control<br>0: Clear<br>disable<br>1: Clear<br>enable | TMRB0 inpuselect 00: TB0IN0 01: \$T1 10: \$T4 11: \$T16 | | | | | | TB0FF1C1 | TB0FF1C0 | TB0C1T1 | TB0C0T1 | TB0E1T1 | TB0E0T1 | TB0FF0C1 | TB0FF0C0 | | | | | V | V* | | R | W | ~)) | V | V* | | | 16-bit | 183H | 1 | 1 ( | 0 | 0 | $(0)/\langle$ | 0 | 1 | 1 | | TB0FFCR | timer<br>frip-flop<br>control | (RMW instructions are prohibited.) | TB0FF1 cor<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't ca<br>Note: Alway | | TB0FF0 inv. 0: Disable 1: Enable Invert when UC0 is loaded into TB0CP1H/L. | Invert when UC0 is loaded into TB0CP0H/L. | Invert when UC0 matches TB0RG1H/L. | Invert when UC0 matches TB0RG0H/L. | TB0FF0 cor<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't ca<br>Note: Alway | | | | 16-bit | 188H | | | | | _ | | | | | TB0RG0L | timer | (RMW instruc-<br>tions are pro- | | | 1 | | W | | | | | | register 0L | hibited.) | | | | Und | efined | | | | | TB0RG0H | 16-bit<br>timer<br>register 0H | 189H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | | | | , | -<br>W<br>efined | | | | | | 16-bit | 18AH | > | | | | _ | | | | | TB0RG1L | timer register 1L | (RMW instruc-<br>tions are pro- | | | | , | W | | | | | | register it | hibited.) | | > | <u> </u> | Und | efined | | | | | | 16-bit | 18BH<br>(RMW instruc- | 4 | | | | _ | | | | | TB0RG1H | timer<br>register 1H | tions are pro- | | | | | W | | | | | | .59.500 117 | hibited.) | | ) , | | | efined | | | | | TD0000 | Capture | 10011 | | | | | | | | | | TB0CP0L | register 0L | 18CH 🗸 | | | | | R | | | | | | $\searrow$ | | | | | | efined<br>– | | | | | TDOCDOLL | Capture | 18DH | | | | | | | | | | ТВ0СР0Н | register 0H | חסטו | | | | | R<br>efined | | | | | | | | | | | | - | | | | | TB0CP1L | Capture | 18EH | | | | | <br>R | | | | | 15001 15 | register 1L | 10211 | | | | | efined | | | | | | | | | | | | _ | | | | | TB0CP1H | Capture | 18FH | | | | | R | | | | | | register 1H | | | | | | efined | | | | | | | I | <u> </u> | | | | • | | | | Page 236 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------| | | | | TB1RDE | _ | _ | _ | I2TB1 | TB1PRUN | _ | TB1RUN | | | | | R | /W | _ | _ | R. | W | _ | R/W | | | 16-bit | | 0 | 0 | - | _ | 0 | 0 | - | 0 | | TB1RUN | timer<br>control | 190H | Double<br>Buffer | Always | | | IDLE2 | TMRB1 prescaler | > - | Up counter<br>(UC1) | | | | | 0: Disable<br>1: Enable | write 0. | _ | _ | 0: Stop<br>1: Operate | 0: Stop and<br>1: Run (cour | | | | | | | TB1CT1 | TB1ET1 | TB1CP0I | TB1CPM1 | TB1CPM0 | TB1CLE | TB1CLK1 | TB1CLK0 | | | | | R | /W | W* | | | R/W | | | | | 16-bit | | 0 | 0 | 1 | 0 | | 0 | 0 | 0 | | TB1MOD | timer<br>source<br>CLK &<br>mode | 192H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | TB1FF1 inve<br>0: Trigger di<br>1: Trigger er<br>Invert when<br>UC1 is<br>loaded into<br>TB1CP1H/L | | Software capture control 0: Software capture 1: Undefined | 01: TB1IN0↑ INT7 occurs 10: TB1IN0↑ INT7 occurs 11: TA1OUT↑ | s at rising edge IB1IN1↑ s at rising edge IB1IN0↓ s at falling edge | Up counter<br>control<br>0: Clear<br>disable<br>1: Clear<br>enable | TMRB1 inpu<br>select<br>00: TB1IN0<br>01: φT1<br>10: φT4<br>11: φT16 | | | | | | TB1FF1C1 | TB1FF1C0 | TB1C1T1 | TB1C0T1 | TB1E171 | TB1E0T1 | TB1FF0C1 | TB1FF0C0 | | | | | V | V* | | R | w | | V | V* | | | 16-bit | 193H | 1 | 1 ( | 0 | 0 | (0)/ | 0 | 1 | 1 | | TB1FFCR | timer<br>frip-flop<br>control | (RMW instruc-<br>tions are pro-<br>hibited.) | TB1FF1 con<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't cal<br>Note: Alway | ne O | TB1FF0 inve<br>0: Disable<br>1: Enable<br>Invert when<br>UC1 is<br>loaded into<br>TB1CP1H/L. | Invert when UC1 is loaded into TB1CP0H/L. | Invert when UC1 matches TB1RG1H/L. | Invert when<br>UC1<br>matches<br>TB1RG0H/L. | TB1FF0 cor<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't ca<br>Note: Alway | re | | | 16-bit | 198H<br>(RMW instruc- | | ) | <u> </u> | | - | | | | | TB1RG0L | timer<br>register 0L | tions are pro- | | | | | N . | | | | | | | hibited.) | (//) | | | - | efined | | | | | TB1RG0H | 16-bit<br>timer<br>register 0H | 199H<br>(RMW instruc-<br>tions are pro- | | | | ١ | N | | | | | | | hibited.) | | | | | | | | | | , | | | < | | 7/ | | efined | | | | | TD4DC4L | 16-bit | 19AH<br>(RMW instruc- | > | | | | _ | | | | | TB1RG1L | 16-bit<br>timer<br>register 1L | 19AH<br>(RMW instruc-<br>tions are pro- | > | | | | -<br>N | | | | | TB1RG1L | timer<br>register 1L | 19AH<br>(RMW instruc-<br>tions are pro-<br>hibited.) | 7 | | | \<br>Unde | -<br>W<br>efined | | | | | | timer register 1L | 19AH<br>(RMW instruc-<br>tions are pro- | | | | Unde | N<br>Pfined | | | | | TB1RG1L | timer<br>register 1L | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are pro- | | | | Unde | -<br>W<br>efined<br>-<br>W | | | | | | timer register 1L 16-bit timer | 19AH<br>(RMW instruc-<br>tions are pro-<br>hibited.)<br>19BH<br>(RMW instruc- | | | | Unde | | | | | | TB1RG1H | timer register 1L 16-bit timer register 1H Capture | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) | | | | Unde | | | | | | | timer register 1L 16-bit timer register 1H | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are pro- | | | | Unde | - N efined - N efined - R | | | | | TB1RG1H | timer register 1L 16-bit timer register 1H Capture | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) | | | | Unde<br>Unde<br>Unde | | | | | | TB1RG1H | timer register 1L 16-bit timer register 1H Capture register 0L | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) | | | | Unde | - W efined - W efined - R | | | | | TB1RG1H<br>TB1CP0L | timer register 1L 16-bit timer register 1H Capture register 0L | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) 19CH | | | | Unde<br>Unde<br>Unde | - W efined - W efined - R efined - R | | | | | TB1RG1H<br>TB1CP0L | timer register 1L 16-bit timer register 1H Capture register 0L | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) 19CH | | | | Unde | - W Defined - W Defined - R Defined - R Defined - R | | | | | TB1RG1H<br>TB1CP0L | timer register 1L 16-bit timer register 1H Capture register 0L Capture register 0H | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) 19CH | | | | Unde<br>Unde<br>Unde | | | | | | TB1CP0L | timer register 1L 16-bit timer register 1H Capture register 0L Capture register 0H | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) 19CH | | | | Unde<br>Unde<br>Unde | - N efined - N efined - R efined - R efined - R | | | | | TB1CP0L | timer register 1L 16-bit timer register 1H Capture register 0L Capture register 0H | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) 19CH | | | | Unde<br>Unde<br>Unde<br>Unde | - W Defined - W Defined - R Defined - R Defined - R Defined - R Defined - R | | | | | TB1CP0L | timer register 1L 16-bit timer register 1H Capture register 0L Capture register 0H | 19AH (RMW instructions are prohibited.) 19BH (RMW instructions are prohibited.) 19CH | | | | Unde<br>Unde<br>Unde | W efined W efined R efined R efined R R efined R | | | | Page 237 2007-12-03 | -<br>-<br>-<br>-<br>2CLK1 | TB2RUN R/W 0 Up counter (UC2) | |--------------------------------------------------------------|----------------------------------------------------------------------| | - | 0<br>Up counter | | - | Up counter | | | | | | | | 2CLK1 | | | | TB2CLK0 | | | | | 0 | 0 | | RB2 inpurect<br>TB2IN0 p | | | 2FF0C1 | TB2FF0C0 | | W | V* | | 1 | 1 | | PF0 conf<br>Invert<br>Set<br>Clear<br>Don't car<br>e: Always | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 5 0 | FF0C1 W Trice W Trice FF0 connect Set Clear Clear Con't can | Page 238 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----------------------------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------| | - | | | TB3RDE | _ | _ | _ | I2TB3 | TB3PRUN | _ | TB3RUN | | | | | R | /W | _ | _ | Ŗ | /W | _ | R/W | | | 16-bit | | 0 | 0 | _ | _ | 0 | 0 | _ | 0 | | TB3RUN | timer<br>control | 1B0H | Double<br>Buffer<br>0: Disable | Always<br>write 0. | - | - | IDLE2<br>0: Stop<br>1: Operate | TMRB3<br>prescaler<br>0: Stop and | > -<br>Clear | Up counter<br>(UC3) | | | | | 1: Enable | | | | 1. Operate | 1: Run (cou | nt up) | | | | | | TB3CT1 | TB3ET1 | TB3CP0I | TB3CPM1 | ТВЗСРМ0 | TB3CLE | TB3CLK1 | TB3CLK0 | | | | | R | /W | W* | | | R/W | | T | | | 16-bit | | 0 | 0 | 1 | 0 | | 0 | 0 | 0 | | ТВЗМОО | timer<br>source<br>CLK &<br>mode | 1B2H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | TB3FF1 invo<br>0: Trigger di<br>1: Trigger er<br>Invert when<br>UC3 is<br>loaded into<br>TB3CP1H/L | | Software capture control 0: Software capture 1: Undefined | 01: TB3IN0↑ INT3 occur 10: TB3IN0↑ INT3 occurs 11: TA3OUT↑ | s at rising edge TB3IN1↑ s at rising edge TB3IN0↓ s at falling edge | Up counter<br>control<br>0: Clear<br>disable<br>1: Clear<br>enable | TMRB3 inpuselect 00: TB3IN0 01: \$\phi\$T1 10: \$\phi\$T4 11: \$\phi\$T16 | | | | | | TB3FF1C1 | TB3FF1C0 | TB3C1T1 | TB3C0T1 | TB3E1T1 | TB3E0T1 | TB3FF0C1 | TB3FF0C0 | | | | | V | V* | | R | W | | V | V* | | | 16-bit | 1B3H | 1 | 1 | 0 | 0 | ((9// < | 0 | 1 | 1 | | TB3FFCR | timer<br>frip-flop<br>control | (RMW instruc-<br>tions are pro-<br>hibited.) | TB3FF1 cor<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't ca<br>Note: Alway | | TB3FF0 involution of the control | Invert when UC3 is loaded into TB3CP0H/L. | Invert when UC3 matches TB3RG1H/L. | Invert when<br>UC3<br>matches<br>TB3RG0H/L. | TB3FF0 cor<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't ca<br>Note: Alway | | | | 16-bit | 1B8H | | )) | _ | | _ | | | | | TB3RG0L | timer | (RMW instruc-<br>tions are pro- | | | | | N | | | | | | register 0L | hibited.) | (// | | | Und | efined | | | | | TB3RG0H | 16-bit<br>timer<br>register 0H | 1B9H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | | | | , | <br>W<br>efined | | | | | | 16-bit | 1BAH | > | | | | _ | | | | | TB3RG1L | timer (\) | (RMW instruc-<br>tions are pro- | | | | , | N | | | | | | register 1L | hibited.) | $\wedge$ | > | / | Unde | efined | | | | | | 16-bit | 1BBH | d | \ | | | _ | | | | | TB3RG1H | timer | (RMW instruc-<br>tions are pro- | | | | , | N | | | | | | register 1H | hibited.) | | ) , | | Und | efined | | | | | 1 | Continu | | 2 | | | | _ | | | | | TB3CP0L | Capture<br>register 0L | 1BCH 🗸 | | | | | R | | | | | | | | | | | Und | efined | | | | | | Capture | | | | | | _ | | | | | TB3CP0H | register 0H | 1BDH | | | | | R | | | | | | | | | | | | efined | | | | | | Capture | | | | | | _ | | | | | TB3CP1L | register 1L | 1BEH | | | | | R | | | | | | | | | | | | efined | | | | | <b>TD</b> 065 | Capture | | | | | | | | | | | TB3CP1H | register 1H | 1BFH | | | | | R | | | | | | | | | | | Und | efined | | | | Page 239 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|--------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------| | , | | | TB4RDE | _ | _ | _ | I2TB4 | TB4PRUN | _ | TB4RUN | | | | | R | /W | - | _ | Ŗ | /W | _ | R/W | | | 16-bit | | 0 | 0 | - | _ | 0 | 0 | _ | 0 | | TB4RUN | timer<br>control | 1C0H | Double<br>Buffer | Always | | | IDLE2 | TMRB4<br>prescaler | > - | Up counter<br>(UC4) | | | | | 0: Disable<br>1: Enable | write 0. | _ | - | 0: Stop<br>1: Operate | 0: Stop and<br>1: Run (cou | | | | | | | TB4CT1 | TB4ET1 | TB4CP0I | TB4CPM1 | TB4CPM0 | TB4CLE | TB4CLK1 | TB4CLK0 | | | | | R | /W | W* | | | R/W | | | | | 40 54 | | 0 | 0 | 1 | 0 | | 0 | 0 | 0 | | TB4MOD | 16-bit<br>timer<br>source<br>CLK &<br>mode | 1C2H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | TB4FF1 involution of the Trigger | | Software capture control 0: Software capture 1: Undefined | 01: TB4IN0↑ INT9 occur<br>10: TB4IN0↑ INT9 occurs<br>11: TA5OUT↑ | s at rising edge<br>TB4IN1↑<br>s at rising edge<br>TB4IN0↓<br>s at falling edge | Up counter<br>control<br>0: Clear<br>disable<br>1: Clear<br>enable | TMRB4 inpuselect 00: TB4IN0 01: \phiT1 10: \phiT4 11: \phiT16 | | | | | | TB4FF1C1 | TB4FF1C0 | TB4C1T1 | TB4C0T1 | TB4E1T1 | TB4E0T1 | TB4FF0C1 | TB4FF0C0 | | | | | V | V* | | R | w | (2) | V | V* | | | 16-bit | 1C3H | 1 | 1 ( | | 0 | (9)/ | 0 | 1 | 1 | | TB4FFCR | timer<br>frip-flop<br>control | (RMW instruc-<br>tions are pro-<br>hibited.) | TB4FF1 cor<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't ca<br>Note: Alway | | TB4FF0 involution of the control | Invert when UC4 is loaded into TB4CP0H/L. | Invert when UC4 matches TB4RG1H/L. | Invert when<br>UC4<br>matches<br>TB4RG0H/L. | TB4FF0 cor<br>00: Invert<br>01: Set<br>10: Clear<br>11: Don't ca<br>Note: Alway | | | | 16-bit | 1C8H<br>(RMW instruc- | | | | | | | | | | TB4RG0L | timer<br>register 0L | tions are pro- | | | | | <u> </u> | | | | | | | hibited.) | (//) | | | <u> </u> | efined<br> | | | | | TB4RG0H | 16-bit<br>timer | 1C9H<br>(RMW instruc-<br>tions are pro- | | | ( | | | | | | | | register 0H | hibited.) | | | | Unde | efined | | | | | | 16-bit | 1CAH<br>(RMW instruc- | > | | | | _ | | | | | TB4RG1L | timer<br>register 1L | tions are pro- | | | 7 | | <i>N</i> | | | | | | | hibited.)<br>1CBH | | } | ~ | | efined<br> | | | | | TB4RG1H | 16-bit<br>timer | (RMW instruc- | 4 | | | | | | | | | 15 110 111 | register 1H | tions are pro-<br>hibited.) | | <del>\</del> | | | efined | | | | | | | | $\langle () \rangle$ | ) | | | _ | | | | | TB4CP0L | Capture | 1CCH | | / | | | R | | | | | | register 0L | | | | | Unde | efined | | | | | | · · · · · | | | | | | _ | | | | | TB4CP0H | Capture<br>register 0H | 1CDH | | | | | R | | | | | | | | | | | Unde | efined | | | | | | Capture | | | | | | _ | | | | | TB4CP1L | register 1L | 1CEH | | | | | R | | | | | | | | | | | | efined | | | | | | 1 | ı | | | | | _ | | | | | TD 40 D411 | Capture | 40511 | | | | | | | | | | TB4CP1H | Capture register 1H | 1CFH | | | | | R | | | | Page 240 2007-12-03 ## (8) UART / Serial channel | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------------------------------|------------------------------------------------------|--------------------------------|-------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------| | | Serial | 200H | RB7 / TB7 | RB6 / TB6 | RB5 / TB5 | RB4 / TB4 | RB3 / TB3 | RB2 / TB2 | RB1 / TB1 | RB0 / TB0 | | SC0BUF | channel 0 | (RMW instruc- | | | R | (Receiving) / \ | N (Transmissi | on) | | I. | | | buffer | tions are pro-<br>hibited.) | | | | Unde | efined | 7 | | | | | | | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC | | | | | R | R | /W | R (Clea | ared to "0" who | en read) | R | /W | | | | | Undefined | 0 | 0 | 0 | 0 | /\ 0 | 0 | 0 | | SCOCR | SCOCR Serial (RM) | 201H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | Received<br>data bit8 | Parity<br>0: Odd<br>1: Even | Parity<br>addition<br>0: Disable<br>1: Enable | Overrun<br>error flag<br>0: Unde-<br>tect error<br>1: Detect<br>error | Parity error<br>flag<br>0: Unde-<br>tect error<br>1: Detect<br>error | Framing error flag 0: Undetect error 1: Detect error | Edge<br>selection<br>for SCLK<br>pin (I/O<br>mode)<br>0: SCLK1<br>1: SCLK4 | I/O inter-<br>face input<br>clock<br>selection<br>0: Baud<br>rate gener-<br>ator<br>1: SCLK<br>pin input | | | | | TB8 | CTSE | RXE | (WU) | SM1 | SMO | \$C1 | SC0 | | | | | | | | R | W | | | | | | | | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | 0 | | SC0MOD0 | Serial<br>channel 0<br>mode 0 | nel 0 202H | Transmis-<br>sion data<br>bit8 | Hand-<br>shake<br>function<br>0: Disable<br>1: Enable | Receive<br>function<br>0: Disable<br>1: Enable | Wakeup<br>function<br>0: Disable<br>1: Enable | Serial transi<br>mode<br>00: VO inter<br>01: 7-bit UA<br>10: 8-bit UA<br>11: 9-bit UA | face mode<br>RT mode<br>RT mode | (UART)<br>00: Timer T | te generator<br>clock f <sub>SYS</sub><br>clock | | | | | - | BROADDE | BR0CK1 | BR0CK0 | BR0S3 | BR0S2 | BR0S1 | BR0S0 | | | | | | , _ | | R | W | | | | | | | | 0 | ))0 | 0 _ | 0 | 0 | 0 | 0 | 0 | | BR0CR | Baud ratel<br>control | 203H | Always<br>write 0. | + (16 - K)/<br>16 division<br>0: Disable<br>1: Enable | Input clock s<br>baud rate ge<br>00: ∳T0<br>01: ∳T2<br>10: ∳T8<br>11: ∳T32 | | Set | ting of the divi | ided frequenc | y "N" | | | | | - < | | / | - | BR0K3 | BR0K2 | BR0K1 | BR0K0 | | | Serial channel 0 | | - | 1 | | _ | | R | /W | | | BR0ADD | K setting | 204H | - | - | > - | - | 0 | 0 | 0 | 0 | | | register | | - ( | - | - | - | | | ncy divisor "K"<br>I + (16 - K)/16 | ) | | $\wedge$ | | | I2S0 | FDPX0 | - | - | - | - | - | - | | | | | R | W | - | - | - | - | _ | - | | SC0MOD1 | Serial channel 0 | 205H | 70 | 0 | - | _ | - | - | _ | - | | | mode 1 | 7 | IDLE2<br>0: Stop<br>1: Run | Duplex<br>0: Half<br>1: Full | - | - | - | - | - | - | Page 241 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------------------------|--------------------------------------------|--------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------| | 5, | | 208H | RB7 / TB7 | RB6 / TB6 | RB5 / TB5 | RB4 / TB4 | RB3 / TB3 | RB2 / TB2 | RB1 / TB1 | RB0 / TB0 | | SC1BUF | Serial<br>channel 1 | (RMW instruc- | | | R | | W (Transmissi | | | | | 00.20. | buffer | tions are pro-<br>hibited.) | | | | | efined | | | | | | | | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC | | | | | R | | /W | | ared to "0" who | | > | /W | | | | | Undefined | 0 | 0 | 0 | 0/ | 7 0 | 0 | 0 | | SC1CR | Serial<br>channel 1<br>control | 209H<br>(RMW instructions are prohibited.) | Received data bit8 | Parity<br>0: Odd<br>1: Even | Parity<br>addition<br>0: Disable<br>1: Enable | Overrun<br>error flag<br>0: Unde-<br>tect error<br>1: Detect<br>error | Parity error flag 0: Undetect error 1: Detect error | Framing<br>error flag<br>0: Unde-<br>tect error<br>1: Detect<br>error | Edge selection for SCLK pin (I/O mode) 0: SCLK11: SCLK1 | I/O inter-<br>face input<br>clock<br>selection<br>0: Baud<br>rate gener-<br>ator<br>1: SCLK<br>pin input | | | | | TB8 | CTSE | RXE | (WU) | SM1 | SMO | \$C1 | SC0 | | | | | | | | R | /W | 116 | 0) | | | | | | 0 | 0 | 0 | 0 | 0 ( | 700 | 0 | 0 | | SC1MOD0 | Serial<br>channel 1<br>mode 0 | annel 1 20AH | Transmis-<br>sion data<br>bit8 | Hand-<br>shake<br>function<br>0: Disable<br>1: Enable | Receive function 0: Disable 1: Enable | Wakeup<br>function<br>0: Disable<br>1: Enable | Serial transi<br>mode<br>00: I/O inter<br>01: 7-bit UA<br>10: 8-bit UA<br>11: 9-bit UA | face mode<br>RT mode<br>RT mode | (UART)<br>00: Timer TA | te generator<br>clock f <sub>SYS</sub><br>clock | | | | | - | BR1ADDE | BR1CK1 | BR1CK0 | BR1S3 | BR1S2 | BR1S1 | BR1S0 | | | | | | , , | | R | W | | | | | | | | <b>(</b> ( | <b>5</b> ) 0 | 0 ~ | 0 | 0 | 0 | 0 | 0 | | BR1CR | Baud ratel<br>control | 20BH | Always<br>write "0". | + (16 - K)/<br>16 division<br>0: Disable<br>1: Enable | Input clock s<br>baud rate ge<br>00: \$T0<br>01: \$T2<br>10: \$T8<br>11: \$T32 | | Set | ting of the divi | ded frequenc | y "N" | | | | | - / | | 7/- | _ | BR1K3 | BR1K2 | BR1K1 | BR1K0 | | | Serial | | 7 <u> </u> | 17 | | - | | R | /W | | | BR1ADD | channel 1<br>K setting | 20CH | - | -// | > - | - | 0 | 0 | 0 | 0 | | | register | $\searrow$ | - ( | _ | _ | - | | Sets frequent<br>(Divided by N | ncy divisor "K"<br>I + (16 - K)/16 | ) | | $\wedge$ | | | I2S1 | FDPX1 | - | - | - | - | - | - | | | Serial | | R | w | - | - | - | - | - | - | | SC1MOD1 | channel 1 | 20DH | 70 | ) о | - | - | - | - | - | - | | | mode 1 | \\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | IDLE2<br>0: Stop<br>1: Run | Duplex<br>0: Half<br>1: Full | - | - | - | - | - | - | Page 242 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------------------------------------|------------------------------------------------------|----------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------| | | Serial | 210H | RB7 / TB7 | RB6 / TB6 | RB5 / TB5 | RB4 / TB4 | RB3 / TB3 | RB2 / TB2 | RB1 / TB1 | RB0 / TB0 | | SC2BUF | channel 2 | (RMW instruc- | | | R | (Receiving) / \ | N (Transmissi | ion) | | | | | buffer | tions are pro-<br>hibited.) | | | | Unde | efined | | | | | | | | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC | | | | | R | R | /W | W R (Clea | | en read) | R | /W | | | | | Undefined | 0 | 0 | 0 | 0 | 70 | 0 | 0 | | SC2CR | Serial<br>channel 2<br>control | 211H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | Received data bit8 | Parity<br>0: Odd<br>1: Even | Parity<br>addition<br>0: Disable<br>1: Enable | Overrun<br>error flag<br>0: Unde-<br>tect error<br>1: Detect<br>error | Parity error<br>flag<br>0: Unde-<br>tect error<br>1: Detect<br>error | Framing error flag 0: Undetect error 1: Detect error | Edge<br>selection<br>for SCLK<br>pin (I/O<br>mode)<br>0: SCLK1<br>1: SCLK4 | I/O inter-<br>face input<br>clock<br>selection<br>0: Baud<br>rate gener-<br>ator<br>1: SCLK<br>pin input | | | | | TB8 | CTSE | RXE | (WU) | SM1 | SMO | SC1 | SC0 | | | | | | | | R | W | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | SC2MOD0 | Serial<br>channel 2<br>mode 0 | 212H | Transmission data | Hand-<br>shake<br>function<br>0: Disable<br>1: Enable | Receive function 0: Disable 1: Enable | Wakeup<br>function<br>0: Disable<br>1: Enable | Serial transi<br>mode<br>00: I/O inter<br>01: 7-bit UA<br>10: 8-bit UA<br>11: 9-bit UA | face mode<br>RT mode<br>RT mode | Serial transmission clo (UART) 00: Timer TA0TRG 01: Baud rate generate 10: Internal clock f <sub>SYS</sub> 11: External clock (SCLK input) | | | | | | _ | BR2ADDE | BR2CK1 | BR2CK0 | BR2S3 | BR2S2 | BR2S1 | BR2S0 | | | | | | R/W | | | | | | | | | | | <b>ø</b> ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | BR2CR | Baud ratel<br>control | 213H | Always<br>write "0". | + (16 - K)/<br>16 division<br>0: Disable<br>1: Enable | Input clock s<br>baud rate ge<br>00: \$T0<br>01: \$T2<br>10: \$T8<br>11: \$T32 | | Set | ting of the divi | ided frequenc | y "N" | | | | | - < | | <u> </u> | - | BR2K3 | BR2K2 | BR2K1 | BR2K0 | | | Serial channel 2 | | - | | | _ | | R | /W | | | BR2ADD | K setting | 214H | - | - | > - | - | 0 | 0 | 0 | 0 | | | register | $\sim$ | - ( | _ | - | - | | Sets frequent<br>(Divided by N | ncy divisor "K"<br>I + (16 - K)/16 | ) | | $\wedge$ | | | I2S2 | FDPX2 | ı | - | - | - | _ | - | | | Serial<br>SC2MOD1 channel 2<br>mode 1 | | R | W | - | - | - | - | - | - | | SC2MOD1 | | 215H | $\nearrow \bigcirc$ | ) 0 | - | - | - | _ | - | - | | | | 7 | IDLE2<br>0: Stop<br>1: Run | Duplex<br>0: Half<br>1: Full | - | - | _ | _ | - | - | Page 243 2007-12-03 # (9) I<sup>2</sup>C bus interface | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------------------|-------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------|--| | | | | BC2 | BC1 | BC0 | ACK | - | SCK2 | SCK1 | SWRMON<br>/SCK0 | | | | | | | W | | R/W | - | | W | R/W | | | | Serial bus | 240H | 0 | 0 | 0 | 0 | - | 0 | 0 | 0/1 | | | SBIOCR1 | control tions are pro- register 1 hibited.) | | Number of transferred bits<br>000: 8 001: 1 010: 2 011: 3<br>100: 4 101: 5 110: 6 111: 7 | | | Acknowl-<br>edge clock<br>0: Disable<br>1: Enable | <u>-</u> (7 | ware reset r<br>000: 4 001<br>100: 8 101<br><swrmon< td=""><td>al clock select<br/>monitor<br/>: 5 010: 6 0<br/>: 9 110: 10 1</td><td>11: 7</td></swrmon<> | al clock select<br>monitor<br>: 5 010: 6 0<br>: 9 110: 10 1 | 11: 7 | | | | SBI | 241H | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | | SBI0DBR | buffer | (RMW instruc-<br>tions are pro- | | | R | (Receiving) / \ | W (Transmissi | on) | | | | | | register | hibited.) | | | | Unde | efined | 2 | | | | | | | | SA6 | SA5 | SA4 | SA3 | SA2 | \$A1 | SA0 | ALS | | | | | 0.401.1 | | L | | | N | 170 | (/)) | | | | | I <sup>2</sup> C bus | 242H<br>(RMW instruc- | 0 | 0 | 0 | 9 | 0 | 0 | 0 | 0 | | | I2C0AR | address<br>register | tions are pro-<br>hibited.) | | Slave address selection for when device is operating as slave device | | | | | | | | | | | MST | TRX | ВВ | PIN | AL/<br>SBIM1 | AAS/<br>SBIM0 | AD0/<br>SWRST1 | LRB/<br>SWRST0 | | | | | Serial bus | | | | $\rightarrow$ | | /W ) ) | | 1 | | | | When read<br>SBI0SR | interface<br>status<br>register | 243H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | 0 | | Bus status<br>monitor<br>0: Free<br>1: Busy[ | INTSBI request monitor 0: Request 1: Cancel | Arbitration lost detection monitor 1: Detect | O Slave address match detection monitor 1:Detect | GENERAL<br>CALL<br>detection<br>1: Detect | Last receive bit monitor 0: "0" 1: "1" | | | When write<br>SBI0CR2 | Serial bus<br>interface<br>control<br>register 2 | | 0: Slave<br>1: Master | 0:Receiver<br>1:Transmit | Start/stop<br>condition<br>0: Start<br>condition<br>1: Stop<br>condition | Cancel<br>INTSBI<br>interrupt<br>request<br>0: –<br>1: Cancel | Serial bus ir operating m tion 00: Port modul: Reserve 10: I <sup>2</sup> C bus 11: Reserve | ode selec-<br>de<br>d<br>mode | Write "10" a | set generate<br>nd "01", then<br>eset signal is | | | | | | - ( | I2SBI0 | _ | _ | _ | _ | _ | - | | | $\wedge$ | Serial bus | 24411 | W | R/W | - | - | - | - | _ | R/W | | | CDIODD | interface | 244H<br>(RMW instruc- | 0 | 0 | _ | - | - | - | _ | 0 | | | SPIORK | SBIOBR baud rate tions are pro- register hibited.) | Always<br>write "0" | Operation<br>in IDLE2<br>mode<br>0: Stop<br>1: Operate | - | - | - | - | - | Always<br>write "0" | | | | | | | | - | - | - | - | - | _ | - | | | | Serial bus | 247H | R/W | | | | R | | | | | | SBIOCEO | interface | 247H<br>(RMW instruc- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | SDIUCKU | IOCR0 interface control control register 0 (RMW instructions are prohibited.) | | | | Always read "0". | | | | | | | Page 244 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------------------|-----------------------------------------|------------------------------------------------------|---------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--| | | | | BC2 | BC1 | BC0 | ACK | - | SCK2 | SCK1 | SCK0/<br>SWRMON | | | | | | | W | | R/W | _ < | , | N | R/W | | | | Serial bus | 248H | 0 | 0 | 0 | 0 | _ | 0 | 0 | 0/1 | | | SBI1CR1 | interface<br>control<br>register 1 | (RMW instruc-<br>tions are pro-<br>hibited.) | 000: 8 001 | ransferred bits<br>: 1 010: 2 0<br>: 5 110: 6 1 | 11: 3 | Acknowl-<br>edge clock<br>0: Disable<br>1: Enable | <u>-</u> | ware reset r<br>000: 4 001<br>100: 8 101<br><swrmon< td=""><td>W O at write ial clock select monitor : 5 010: 6 0 : 9 110: 10 1 &gt; at read oftware reset DB1 SA0 O GENERAL CALL detection 1: Detect Software res Write "10" at</td><td>11: 7</td></swrmon<> | W O at write ial clock select monitor : 5 010: 6 0 : 9 110: 10 1 > at read oftware reset DB1 SA0 O GENERAL CALL detection 1: Detect Software res Write "10" at | 11: 7 | | | | SBI | 249H | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | | SBI1DBR | buffer | (RMW instruc-<br>tions are pro- | | | R | (Receiving) / \ | V (Transmissi | on) | | | | | | register | hibited.) | | | | ΪS | íË | | | | | | | | | SA6 | SA5 | SA4 | SA3 | SA2 | \$A1 | SA0 | ALS | | | | | | | L | | | v 🔷 | 7 | $(/ \cap)$ | | | | | I <sup>2</sup> C bus | 24AH<br>(RMW instruc- | 0 | 0 | 0 | 0 | 0 | 0 | 90 | 0 | | | I2C1AR | address<br>register | tions are pro-<br>hibited.) | | Slave addres | s selection for | when device | (7) | | ı | Address<br>recognition<br>0: Enable<br>1: Disable | | | | | | MST | TRX | BB | PIN | SBIM1 | AAS/<br>SBIM0 | | LRB/<br>SWRST0 | | | | | | | RW | | | | | | | | | When read | Serial bus<br>interface | | 0 | 0 | 0 | 1 | //0 | 0 | 0 | 0 | | | SBI1SR | status<br>register | 24BH<br>(RMW instruc-<br>tions are pro-<br>hibited.) | | | Bus status<br>monitor<br>0: Free<br>1: Busy[ | INTSBI<br>request<br>monitor<br>0: Request<br>1: Cancel | Arbitration<br>lost<br>detection<br>monitor<br>1: Detect | Slave<br>address<br>match<br>detection<br>monitor<br>1:Detect | CALL<br>detection | Last receive bit monitor 0: "0" 1: "1" | | | When write<br>SBI1CR2 | Serial bus interface control register 2 | | 0: Slave<br>1: Master | 0:Receiver<br>1:Transmit | Start/stop<br>condition<br>0: Start<br>condition<br>1: Stop<br>condition | Cancel<br>INTSBI<br>interrupt<br>request<br>0: –<br>1: Cancel | Serial bus ir operating m tion 00: Port mod 01: Reserve 10: I <sup>2</sup> C bus 11: Reserve | ode selec-<br>de<br>d<br>mode | Write "10" an<br>an internal re | set generate<br>nd "01", then<br>eset signal is | | | | | | - ( | l2SBI1 | - | - | - | - | - | - | | | _ | | | w | R/W | - | - | - | - | - | R/W | | | | Serial bus interface | 24CH<br>(RMW instruc- | 0 | 0 | - | - | _ | - | _ | 0 | | | SBI1BR | baud rate<br>register | tions are pro-<br>hibited.) | Always<br>write "0" | Operation<br>in IDLE2<br>mode<br>0: Stop<br>1: Operate | - | - | - | - | - | Always<br>write "0" | | | | | | SBI1EN | - | _ | _ | _ | _ | - | - | | | | | | | | | 1 | R | | 1 | | | | | Serial bus<br>interface | 24FH<br>(RMW instruc- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | SBI1CR0 | control<br>register 0 | tions are pro-<br>hibited.) | SBI<br>operation<br>0: disable<br>1: enable | | | F | Nways read "C | n . | | | | Page 245 2007-12-03 ## (10) AD converter | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-----------------------|-----------------------------|------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------|-----------------------------|----------------------------------------------------------------------------|------|--|--|--|--| | | | | ADRS | ΑN | MD | AINEN | | S | AIN | | | | | | | | | | | | | R | W | | | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | ADCCR1 | AD<br>control<br>register 1 | 2B0H | AD conversion start 0: - 1: AD conversion start | AD operatin<br>00: AD ope<br>disable<br>01: single n<br>10: Reserve<br>11: Repeat | ration<br>node<br>ed | Analog input control 0: disable 1: enable | 0000: AN0<br>0001: AN1<br>0010: AN2 | 0110: AN6 | 1000: AN8<br>1001: AN9<br>1010: AN10<br>1011: AN11 | | | | | | | | | | EOCF | ADBF | RSEL | I2AD | | A | CK | | | | | | | | | | ı | ₹ | | | R | R/W | | | | | | | | | | | 0 | 0 | 0 | 0// | $\searrow$ 1 | 1 | (0) | 0 | | | | | | ADCCR2 | AD<br>control<br>register 2 | 2B1H | AD conversion end flag 0:Before or during conversion 1: Conversion completed | AD conversion BUSY flag 0: During stop of AD conversion 1: During AD conversion | Storing of<br>an AD<br>conver-<br>sion result<br>0: 10bit<br>mode<br>1: 8bit<br>mode | IDLE2<br>control<br>0:Stop<br>1:Opera-<br>tion | | 1010:<br>1011: 1<br>1100: 3 | 78 / fc [s]<br>56 / fc [s]<br>112 / fc [s]<br>124 / fc [s]<br>148 / fc [s] | t | | | | | | | AD | | AD07 | AD06 | AD05 | AD04 | AD03 | AD02 | AD01 | AD00 | | | | | | ADCDRL | result | 2B2H | | (1) | | | R | | | | | | | | | | register L | | 0 | 0 | <b>)</b> 0 | 0 | ) 0 | 0 | 0 | 0 | | | | | | ADCDRH<br>When 10-bit | | | - | ((-)) | - | -// | \// <del>-</del> | - | AD09 | AD08 | | | | | | storing | | | | | | ì | Ř√ | | | | | | | | | mode | ٠ ١٨٥ | <b>ø</b> ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | ADCDRH | register H | 20011 | AD09 | AD08 | AD07 | AD06 | AD05 | AD04 | AD03 | AD02 | | | | | | When 8-bit storing | | | (7/s) | | | 4/ | R | | | | | | | | | mode | | | • | 0 | (°) | 0 | 0 | 0 | 0 | 0 | | | | | Page 246 2007-12-03 # (11) Watchdog timer | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------------------------|------------------------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----|----------|--------------------------------|-----------------------------------------------------------------|----------------------| | | | | WDTE | WDTP1 | WDTP0 | _ | _ | I2WDT | RESCR | _ | | | | | | R/W | | _ | _ < | R/W | | | | WDT | | | 0 | 0 | 0 | - | - | 0 | 0 | 0 | | WDMOD | WDT<br>mode<br>register | 300H | WDT<br>control<br>1: Enable | Select detect<br>00: 2 <sup>15</sup> /f <sub>SYS</sub><br>01: 2 <sup>17</sup> /f <sub>SYS</sub><br>10: 2 <sup>19</sup> /f <sub>SYS</sub><br>11: 2 <sup>21</sup> /f <sub>SYS</sub> | ŭ | - < | | IDLE2<br>0: Stop<br>1: Operate | 1: Inter-<br>mally con-<br>nects WDT<br>out to the<br>reset pin | Always<br>write "0". | | WDCR | WDT<br>control | 301H<br>(RMW instruc-<br>tions are pro-<br>hibited.) | | | B1H: WD1 | | 4EH: WDT | clear code | | | ## (12) Special timer for CLOCK | | | | | | | Ť | | $\overline{}$ | | | |--------|---------------------|---------|----------------------|---|--------------|---|---------|----------------------------------------------------------------------------------------------------------|--------|-----------------------------| | Symbol | Name | Address | 7 | 6 | 4(5 | 4 | 3 | 2 | 1 | 0 | | | | - | - / | | - | | RTCSEL1 | RTCSEL0 | RTCRUN | | | | | | R/W | | | - | ((+// 5 | | R/W | | | | RTC | | 0 | 7 | \ <u>\</u> - | - | | 0 | 0 | 0 | | RTCCR | control<br>register | 310H | Always<br>write "0". | | > <u>-</u> | | <u></u> | 00: 2 <sup>14</sup> /fs<br>01: 2 <sup>13</sup> /fs<br>10: 2 <sup>12</sup> /fs<br>11: 2 <sup>11</sup> /fs | | 0: Stop & clear<br>1: Count | Page 247 2007-12-03 # (13) Program patch logic | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------|-----------------------------|---------------------------------|--------|----------|-----------|-------------------------|----------------|--------------|---------------------------------|--------|--| | <b>O</b> y20. | | 71441000 | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | _ | | | | Address | 400H<br>(RMW instruc- | | | | W | | | | _ | | | ROMCMP00 | compare<br>register 00 | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | | | | rogiotor oo | hibited.) | | | Target RO | M address (Lo | ower 7 bits) | | | _ | | | | | 40411 | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | | DOMOMBOA | Address | 401H<br>(RMW instruc- | w (7) | | | | | | | | | | ROMCMP01 | compare<br>register 01 | tions are pro- | 0 | 0 | 0 | 0 | 0 | <u>)</u> ) o | 0 | 0 | | | | · · | hibited.) | | | Tarç | get ROM addr | ess (Middle 8 | bits) | • | | | | | | 402H | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | ROMCMP02 | Address<br>compare | (RMW instruc- | | | | | M | | | | | | NOWOW 02 | register 02 | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | 9 | 0 | 0 | 0 | | | | | Tilbited.) | | | Tar | get ROM addi | ess (Upper 8 | bits) | | | | | ı | | 404H | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | | ROMSUB0L | Address<br>substitution | (RMW instruc- | | | | | N ~ | 7 | (/)) | | | | | register 0L | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | 0 | 0 | <b>/</b> 0 | 0 | | | | | ····bitodi) | | | | | (Lower 8 bits) | | T | | | | | | 405H | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | ROMSUB0H | Address substitution | (RMW instruc- | | ( | | | N (7) | \ | T | | | | | register 0H | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | (0) | ) 0 | 0 | 0 | | | | | | | | | / { | (Upper 8 bits) | ī | 0 ROMC09 0 ROMC17 0 ROMS01 | | | | | Address | 408H | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | _ | | | ROMCMP10 | compare | (RMW instruc-<br>tions are pro- | _ | | _ | W | <b>//</b> | | 1 . | - | | | | register 10 | hibited.) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | | | | | | ROMC15 | ROMC14 | ROMC13 | M address (Lo<br>ROMC12 | ROMC11 | ROMC10 | POMCOO | ROMC08 | | | | Address | 409H | KOWG13 | KOWIC 14 | KOWCIS | | N KOWCTI | KOWCTO | KOWCOS | KOWCOO | | | ROMCMP11 | compare | (RMW instruc-<br>tions are pro- | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | register 11 | hibited.) | | ^ | 1/7/A | · | ess (Middle 8 | | Ů | · | | | | | | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | | Address | 40AH<br>(RMW instruc- | | | 7/ | | N | | 1 | | | | ROMCMP12 | compare | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | register 12 | hibited.) | | | Tar | get ROM addı | ess (Upper 8 | bits) | <u> </u> | | | | | <b>←</b> | | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | | | Address | 40CH<br>(RMW instruc- | 4 | | | \ | N | | | | | | ROMSUB1L | ROMSUBILL substitution I | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | .59.0.01 | hibited.) | (() | ) | | Patch code | (Lower 8 bits) | | 1 | 1 | | | | | 40511 | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | DOMOUDAL | Address | 40DH (RMW instruc- | | | | , | N | | | | | | ROMSUB1H | substitution<br>register 1H | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | hibited.) | | | | Patch code | (Upper 8 bits) | | | | | Page 248 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----------|-------------------------------|---------------------------------|--------------|--------|-----------|---------------|----------------|--------|--------|--------|--|--| | | | 44011 | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | _ | | | | DOLLOUBOS | Address | 410H<br>(RMW instruc- | | | | W | | | | _ | | | | ROMCMP20 | compare<br>register 20 | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | Ü | hibited.) | | | Target RO | M address (Lo | ower 7 bits) | | | - | | | | | | 44411 | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | | | ROMCMP21 | Address | 411H<br>(RMW instruc- | | w (7/A | | | | | | | | | | KOMCIMF21 | compare register 21 | tions are pro- | 0 | 0 | 0 | 0 | 0 | ))0 | 0 | 0 | | | | | _ | hibited.) | | | Tarç | get ROM addr | ess (Middle 8 | bits) | | | | | | | | 412H | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | | ROMCMP22 | Address<br>compare | (RMW instruc- | | | | | W | | | | | | | KOWGWF22 | register 22 | tions are pro- | 0 | 0 | 0 | 0/ | 0 | 0 | 0 | 0 | | | | | | hibited.) | | | Tar | get ROM addr | ess (Upper 8 | bits) | | | | | | | | 414H | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | | | ROMSUB2L | Address<br>substitution | (RMW instruc- | | | | | N 💙 | 77 | //) | | | | | KOWOODZE | register 2L | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | filbited.) | | | | Patch code | (Lower 8 bits) | | | | | | | | | 415H | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | | ROMSUB2H | Address<br>substitution | (RMW instruc- | | ( | | ١ | N (7) | | | | | | | | register 2H | tions are pro-<br>hibited.) | 0 | 0 | 9 | 0 | (0) | ) 0 | 0 | 0 | | | | | | Tilbitod.) | | 4 | | Patch code | (Upper 8 bits) | | | | | | | | | 418H | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | - | | | | ROMCMP30 | Address<br>compare | (RMW instruc- | | (()) | | Ŵ | <u> </u> | | | 1 | | | | | register 30 | tions are pro-<br>hibited.) | 0 | | 0 | 0 | √ o | 0 | 0 | ı | | | | | | · montoui, | (( | | Target RO | M address (Lo | ower 7 bits) | | | 1 | | | | | A -I -I | 419H | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | | | ROMCMP31 | Address<br>compare | (RMW instruc- | $(7/\Delta)$ | | | 7 / | N | | 1 | | | | | | register 31 | tions are pro-<br>hibited.) | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | (( )- | | | // | -<br> | ess (Middle 8 | | 1 | | | | | | Address | 41AH | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | | ROMCMP32 | compare | (RMW instruc- | > | | | | N | 1 | 1 | | | | | | register 32 | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 1 | | | V | _ | ress (Upper 8 | · · | 1 | | | | | | Address | 41CH | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | | | ROMSUB3L | Address ROMSUB3L substitution | (RMW instruc- | | | | | N | ī | 1 | | | | | | register 3L | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | POLICIE | ) | DOMOSS | | (Lower 8 bits) | DOMOSS | DOMOSS | DOM: | | | | | Address | 41DH | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | | ROMSUB3H | substitution | (RMW instruc-<br>tions are pro- | | | | | N o | _ | | • | | | | | register 3H | hibited.) | Ő | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | Patch code ( | (Upper 8 bits) | | | | | | Page 249 2007-12-03 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------|-------------------------|---------------------------------|-----------|-----------------------------------------|-----------|---------------|-------------------------------------------|-------------|-------------|-----------|--| | | | | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | _ | | | | Address | 420H<br>(RMW instruc- | | <u> </u> | <u> </u> | W | | | | _ | | | ROMCMP40 | compare<br>register 40 | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | | | | | hibited.) | | | Target RO | M address (Lo | ower 7 bits) | | | _ | | | | | 40411 | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11 | ROMC10 | ROMC09 | ROMC08 | | | DOMOND44 | Address | 421H<br>(RMW instruc- | W | | | | | | | | | | ROMCMP41 | compare<br>register 41 | tions are pro- | 0 | 0 | 0 | 0 | 0 | <u>)</u> )o | 0 | 0 | | | | · · | hibited.) | | | Tarç | get ROM addr | ess (Middle 8 | bits) | | | | | | | 422H | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | ROMCMP42 | Address<br>compare | (RMW instruc- | | | | | M | | | | | | KOMOWF 42 | register 22 | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0/ | 9 | 0 | 0 | 0 | | | | | filbited.) | | | Tar | get ROM addr | ess (Upper 8 | bits) | | | | | | | 424H | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | | ROMSUB4L | Address<br>substitution | (RMW instruc- | | | | | N V | 7 72 | (/) | | | | | register 4L | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | 0 | 0 | <u></u> 0 | 0 | | | | | Tilbitod.) | | | | Patch code | (Lower 8 bits) | | | | | | | | 425H | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | ROMSUB4H | Address substitution | (RMW instruc- | | | | ı | $N \left( O \right) \left\langle \right.$ | | | | | | | register 4H | tions are pro-<br>hibited.) | 0 | 0 | 0 | 0 | (0) | ) 0 | 0 | 0 | | | | | , | | | | / { | (Upper 8 bits) | 1 | | | | | | Address | 428H | ROMC07 | ROMC06 | ROMC05 | ROMC04 | ROMC03 | ROMC02 | ROMC01 | _ | | | ROMCMP50 | compare | (RMW instruc-<br>tions are pro- | _ | | _ | Ŵ | <u> </u> | _ | _ | _ | | | | register 50 | hibited.) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | | | | | | DOMOAS | DOMOAA | | M address (Lo | , | DOMOAO | DOMOSS | - POMOSS | | | | Address | 429H | ROMC15 | ROMC14 | ROMC13 | ROMC12 | ROMC11<br>N | ROMC10 | ROMC09 | ROMC08 | | | ROMCMP51 | compare | (RMW instruc-<br>tions are pro- | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | register 51 | híbited.) | | ^ | 1770 | - | ess (Middle 8 | | U | U | | | | | | ROMC23 | ROMC22 | ROMC21 | ROMC20 | ROMC19 | ROMC18 | ROMC17 | ROMC16 | | | | Address | 42AH | INDIVIDZ3 | KONOZZ | INOWIGE! | | N KOWIC 19 | IXOIVIO 10 | IXOIVIO I I | IXONIO 10 | | | ROMCMP52 | compare | (RMW instruc-<br>tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | register 52 | hibited.) | - | | | | ess (Upper 8 | | ŭ | 0 | | | | <u></u> | | ROMS07 | ROMS06 | ROMS05 | ROMS04 | ROMS03 | ROMS02 | ROMS01 | ROMS00 | | | | Address | 42CH | TOWIGO! | TOMOGO | ROWGOO | | N | ROWGOZ | TOMOGT | Remede | | | ROMSUB5L | substitution | (RMW instruc-<br>tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | register 5L | hibited.) | | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | (Lower 8 bits) | | ŭ | ŭ | | | (= | | | ROMS15 | ROMS14 | ROMS13 | ROMS12 | ROMS11 | ROMS10 | ROMS09 | ROMS08 | | | | Address | 42DH<br>(RMW instruc- | | 1 | | | N | | | | | | ROMSUB5H | substitution | tions are pro- | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | register 5H | hibited.) | - | | | | (Upper 8 bits) | - | - | | | Page 250 2007-12-03 **TMP91CW60** # 16. I/O Port Equivalent-circuit Diagrams • How to read circuit diagrams The circuit diagrams in this chapter are drawn using the same gate symbols as for the 74HCxx series standard CMOS logic ICs. The signal named STOP has a unique function. This signal goes active-high if the CPU sets the HALT bit when the HALTM[1:0] field in the SYSCR2 register is programmed to 01 (e.g., STOP mode) and the drive enable (DRVE) bit in the same register is cleared. If the DRVE bit is set, the STOP signal remains inactive (at logic 0). • The input protection circuit has a resistor in the range of several tens to several hundreds of ohms. 1. P0 (AD0 to AD7), P1 (AD8 to AD15, A8 to A15), P2 (A16 to A23, A0 to A7) 2. PZ0 ( $\overline{RD}$ ), PZ1 ( $\overline{WR}$ ) 3. P5 (AN0 to AN7), P6 (AN8 to AN15) Page 251 2007-12-03 4. $PZ2 (\overline{HWR}), PZ3 (R/\overline{W}), P44(ALE)$ 5. P40(\overline{\colon}\scout), P41(\overline{\colon}\scit{TXD2}), P42(\overline{\colon}\scit{ZS2}/RXD2), P43(\overline{\colon}\scit{ZS3}/SCLK2/\overline{\colon}\scit{CTS2}) 6. P75 (INT0) 7. P32(WAIT/TB3OUT0), P33(TB3OUT1), P70(TA0IN), P71(TA1OUT), P72(TA3OUT), P73(TA4IN), P74(TA5OUT), P80 to P87, P91(RXD0), P92(SCLK0/CTS0), P94(RXD1), P95(SCLK1/CTS1), PA0 to PA3, PB2(TB4OUT0), PB3(TB4OUT1) Page 252 2007-12-03 8. P30(TB3IN0/INT3/SDA0), P31(TB3IN1/INT4/SCL0), P90(TXD0), P93(TXD1), PB0(TB4IN0/INT9/SDA1), PB1(TB4IN1/INT10/SCL1) Page 253 2007-12-03 #### 13. X1, X2 Page 254 2007-12-03 TOSHIBA TMP91CW60 # 17. Points to Note and Restrictions #### 17.1 Notation - a. The notation for built-in I/O registers is as follows register symbol <Bit symbol> - e.g.) TA01RUN<TA0RUN> denotes bit TA0RUN of register TA01RUN. - b. Read-modify-write instructions An instruction in which the CPU reads data from memory and writes the data to the same memory location in one instruction. ``` Example 1: SET 3, (TA01RUN) ... Set bit3 of TA01RUN ``` • Examples of read-modify-write instructions on the TLCS-900 Exchange instruction Arithmetic operations Logic operations Bit manipulation operations Rotate and shift operations c. $$f_{OSCH}$$ , fc, fs, $f_{FPH}$ , $f_{SYS}$ and one state The clock frequency input on pins X1 and 2 is called f<sub>OSCH</sub> or fc. The clock selected by SYSCR1<SYSCK> is called $f_{FPH}$ . The clock frequency give by $f_{FPH}$ divided by 2 is called $f_{SYS}$ . One cycle of f<sub>SYS</sub> is referred to as one state. Page 255 2007-12-03 #### 17.2 Points of note a. AM0 and AM1 pins This pin is connected to the DVcc pin. Do not alter the level when the pin is active. b. EMU0 and EMU1 pins Open pins. c. HALT mode (IDLE1) When IDLE1 mode (in which oscillator operation only occurs) is used, set RTCCR<RTCRUN> to 0 stop the Special timer for CLOCK before the HALT instructions is executed. #### d. Warm-up counter The warm-up counter operates when STOP mode is released, even if the system is using an external oscillator. As a result a time equivalent to the warm-up time elapses between input of the release request and output of the system clock. e. Programmable pull-up/pull-down resistances The programmable pull-up/pull-down resistor can be turned ON/OFF by a program when the ports are set for use as input ports. When the ports are set for use as output ports, they cannot be turned ON/OFF by a program. The data registers (e.g., P4) are used to turn the pull-up/pull-down resistors ON/OFF. Consequently read-modify-write instructions are prohibited. #### f. Watchdog timer The watchdog timer starts operation immediately after a reset is released. When the watchdog timer is not to be used, disable it. When the bus is released, neither internal memory nor internal I/O can be accessed. However, the internal I/O continues to operate. Hence the watchdog timer continues to run. Therefore be careful about the bus releasing time and set the detection timer of watchdog timer. g. CPU (Micro DMA) Only the LDC cr, r and LDC r, cr instructions can be used to access the control registers in the CPU (e.g., the transfer source address register (DMASn)). #### h. Undefined SFR The value of an undefined bit in an SFR is undefined when read. #### i. POP SR instruction Please execute the POP SR instruction during DI condition. #### j. Clocks for serial channels (SIO) As for the serial channels SIO0, SIO1 and SIO2, a baud rate generator is unavailable as an input clock of an I/O interface and a clock for a serial transfer if a prescaler clock is set to fc/16 when SYSCR0<PRCK1> is "1". Page 256 2007-12-03 # 18. Package Dimension Page 257 2007-12-03 QFP100-P-1420-0.65A Unit: mm Page 258 2007-12-03 ## **Postscript** This is a technical document that describes the operating functions and electrical specifications of the 16-bit microcontroller series TLCS-900/L1 (LSI). Toshiba provides a variety of development tools and basic software to enable efficient software development. These development tools have specifications that support advances in microcomputer hardware (LSI) and can be used extensively. Both the hardware and software are supported continuously with version updates. The recent advances in CMOS LSI production technology have been phenomenal and microcomputer systems for LSI design are constantly being improved. The products described in this document may also be revised in the future. Be sure to check the latest specifications before using. Toshiba is developing highly integrated, high-performance microcomputers using advanced MOS production technology and especially well proven CMOS technology. We are prepared to meet the requests for custom packaging for a variety of application areas. We are confident that our products can satisfy your application needs now and in the future.