Data Book 16bit Micro controller TLCS-900/L1 series **TMP91C824F** REV2.3 October. 26, 2001 TOSHIBA contents # **Table of Contents** ## TLCS-900/L1 Devices ## **TMP91C824F** | 1. OU | JTLINE A | ND DEVICE CHARACTERISTICS | | 91C824-1 | |--------|------------|-------------------------------------------|--------|------------| | 2. PII | N ASSIGN | IMENT AND PIN FUNCTIONS | | 91C824-4 | | 3. OF | ERATIO | N | | 91C824-9 | | 3.1 | 1 CPU | | | 91C824-9 | | 3.2 | 2 Memor | y Map | | 91C824-11 | | 3.3 | 3 Triple | clock, Stand-by function, Noise reduction | n | 91C824-12 | | 3.4 | 4 Interru | pts | | 91C824-36 | | 3.5 | 5 Functio | ons of Ports | | 91C824-51 | | | 3.5.1 | Port 1 | | 91C824-55 | | | 3.5.2 | Port 2 | | 91C824-56 | | | 3.5.3 | Port 5 | | 91C824-58 | | | 3.5.4 | Port 6 | | 91C824-61 | | | 3.5.5 | Port 7 | | 91C824-62 | | | 3.5.6 | Port 8 | | 91C824-66 | | | 3.5.7 | Port B | | 91C824-67 | | | 3.5.8 | Port C | | 91C824-70 | | | 3.5.9 | Port D | | 91C824-73 | | 3.0 | 6 Chip S | elect / Wait Controller | | 91C824-78 | | 3.7 | 7 8-bit Ti | mers(TMRA) | | 91C824-88 | | 3.8 | 8 Memor | y Management Unit | | 91C824-108 | | | | Channel | | 91C824-119 | | 3. | 10Serial l | Bus Interface | | 91C824-151 | | 3. | 11 Analog | g / Digital Converter | | 91C824-179 | | 3. | 12 Watch | Dog Timer | | 91C824-189 | | | | | | 91C824-195 | | | | y / Alarm Generator | | 91C824-209 | | 4. E | ELECTRI | CAL CHARACTERISTICS(TENTATIVI | E) | 91C824-215 | | | TABLE O | • | ······ | 91C824-227 | | 3. P. | ACKAGE | s | | PKG-1 | ## **TOSHIBA** | Rev./Date | page | Modification item | Reason | |-------------------------|-------------------------------------------|-----------------------------------------|--------| | | 109 | Bank Operation S/W Example in MMU | | | Rev12/Mar-15-2001 | 218 | Recommended Crystal oscillation Circuit | | | | 165 | Stop condition generation | | | | 166 | Timing diagram for TMP91C824 Restart | | | Rev14/July-16-2001 | 12-24 | DFM(triple cock modify) | | | Rev14/July-26-2001 | 17,240 | EMCCR3 | | | | 159,168 | Add ed the sentence and diagram at SBI | | | | 155 | Modify bit6(TRX) | | | | 114 Added the diagram and sentence of MMU | | | | Rev21/August-21-2001 | 14 | CPU: modify the figure | | | Rev22/September-21-2001 | 222 | Electric Specification | | | Rev22/September-7-2001 | 226 | Murata factory URL added | | | Rev23/October-26-2001 | 217 | 33MHZ AC added | | | | | | | ## CMOS 16-Bit Microcontrollers TMP91C824F ### 1. OUTLINE AND FEATURES TMP91C824F is a high-speed 16-bit microcontroller designed for the control of various mid- to large-scale equipment. TMP91C824F comes in a 100-pin flat package and a 100-pad Dice form. Listed below are the features. - (1) High-speed 16-bit CPU (900/L1 CPU) - Instruction mnemonics are upward-compatible with TLCS-90 - 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 (1.0 µs/2 bytes at 16 MHz) - (2) Minimum instruction execution time: 121 ns (at 33 MHz) - (3) Built-in RAM: 8 Kbytes Built-in ROM: None - (4) External memory expansion - Expandable up to 106M bytes (shared program/data area) - Can simultaneously support 8-/16-bit width external data bus - ... Dynamic data bus syzing - Separate bus system - (5) 8-bit timers: 4 channels - (6) General-purpose serial interface: 2 channels - UART/Synchronous mode: 2 channels - IrDA Ver.1.0 (115.2kbps) mode selectable: 1 channel - (7) Serial bus interface: 1 channel - I2C bus mode/clock synchronous mode selectable 980508TBA1 - For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance / Handling Precautions. - TOSHIBA is continually working to improve the quality and the reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to observe standards of safety, and to avoid situations in which a malfunction or failure of a TOSHIBA product could cause loss of human life, bodily injury or damage to property. In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent products specifications. Also, please keep in mind the precautions and conditions set forth in the TOSHIBA Semiconductor Reliability Handbook. - The products described in this document are subject to foreign exchange and foreign trade laws. - The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA CORPORATION for any infringements of intellectual property or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any intellectual property or other rights of TOSHIBA CORPORATION or others. - The information contained herein is subject to change without notice. Purchase of TOSHIBA $I^2C$ components conveys a license under the Philips $I^2C$ Patent Rights to use these components in an $I^2C$ system, provided that the system conforms to the $I^2C$ Standard Specification as defined by Philips. - (8) Timer for real-time clock (RTC) - Based on TC8521A - (9) 10-bit A/D converter: 8 channels - (10) Watch dog timer - (11) Melody/Alarm generator - Melody: Output of clock 4 to 5461Hz - Alarm: Output of the 8 kinds of alarm pattern - Output of the 5 kinds of interval interrupt - (12) Chip select/Wait controller: 4 channels - (13) Memory Management Unit - Expandable up to 106M bytes (4 local area/8bank method) - (14) Interrupts: 37 interrupts - 9 CPU interrupts: Software interrupt instruction and illegal instruction - 23 internal interrupts: 7 priority levels are selectable - 5 external interrupts: 7 priority levels are selectable (among 4 interrupts are selectable edge mode) - (15) Input/output ports: 35 pins (@External 16-bit data bus memory) - (16) Stand-by function Three Halt modes: Idle2 (programmable), Idle1 and Stop - (17) Triple-clock controller - Clock doubler (DFM) circuit is inside - Clock gear function: Select a High-frequency clock fc/1 to fc/16 - RTC (fs=32.768kHz) - (18) Operating voltage - VCC = 2.7 V to 3.6 V (fc max = 33 MHz) - VCC = 1.8 V to 3.6 V (fc max = 10 MHz) - (19) Package - 100-pin QFP: LQFP100 P -1414 0.5D - 100-pad Dice form TOSHIBA Figure 1.1 TMP91C824F Block Diagram ## 2. PIN ASSIGNMENT AND PIN FUNCTIONS The assignment of input/output pins for the TMP91C824F, their names and functions are as follows: ## 2.1 Pin Assignment Diagram Figure 2.1.1 shows the pin assignment of the TMP91C824F. Figure 2.1.1 Pin assignment diagram (100-pin QFP) ## 2.2 Pad Layout (Chip size 4.37mm $\times 4.37$ mm) unit (µm) | PIN | Name | X | Y | PIN | Name | X | Y | PIN | Name | X | Y | |-----|---------|-------|-------|-----|---------|-------|-------|-----|---------|-------|-------| | no | Ivallie | point | point | No | Ivaille | point | point | No | Ivaille | point | point | | 1 | VREFL | -2050 | 1721 | 35 | PC0 | -140 | -2050 | 69 | P21 | 2045 | 939 | | 2 | AVSS | -2050 | 1596 | 36 | PC1 | -14 | -2050 | 70 | P20 | 2045 | 1075 | | 3 | AVCC | -2050 | 1470 | 37 | PC2 | 112 | -2050 | 71 | A15 | 2045 | 1207 | | 4 | P80 | -2050 | 1337 | 38 | PC3 | 238 | -2050 | 72 | A14 | 2045 | 1337 | | 5 | P81 | -2050 | 1209 | 39 | PC4 | 365 | -2050 | 73 | A13 | 2045 | 1464 | | 6 | P82 | -2050 | 1076 | 40 | PC5 | 491 | -2050 | 74 | A12 | 2045 | 1592 | | 7 | P83 | -2050 | 943 | 41 | PD5 | 618 | -2050 | 75 | A11 | 2045 | 1721 | | 8 | P84 | -2050 | 810 | 42 | PD6 | 744 | -2050 | 76 | A10 | 1720 | 2045 | | 9 | P85 | -2050 | 677 | 43 | PD7 | 871 | -2050 | 77 | A9 | 1591 | 2045 | | 10 | P86 | -2050 | 544 | 44 | D0 | 998 | -2050 | 78 | A8 | 1464 | 2045 | | 11 | P87 | -2050 | 416 | 45 | D1 | 1124 | -2050 | 79 | A7 | 1337 | 2045 | | 12 | P70 | -2050 | 148 | 46 | D2 | 1251 | -2050 | 80 | A6 | 1197 | 2045 | | 13 | P71 | -2050 | 15 | 47 | D3 | 1377 | -2050 | 81 | A5 | 1058 | 2045 | | 14 | P72 | -2050 | -118 | 48 | D4 | 1504 | -2050 | 82 | A4 | 918 | 2045 | | 15 | PB0 | -2050 | -251 | 49 | D5 | 1630 | -2050 | 83 | A3 | 778 | 2045 | | 16 | PB1 | -2050 | -384 | 50 | D6 | 1757 | -2050 | 84 | A2 | 639 | 2045 | | 17 | PB2 | -2050 | -517 | 51 | D7 | 2045 | -1750 | 85 | A1 | 499 | 2045 | | 18 | PB3 | -2050 | -650 | 52 | P10 | 2045 | -1614 | 86 | A0 | 359 | 2045 | | 19 | PB4 | -2050 | -783 | 53 | P11 | 2045 | -1478 | 87 | /RD | 219 | 2045 | | 20 | PB5 | -2050 | -916 | 54 | P12 | 2045 | -1341 | 88 | /WR | 80 | 2045 | | 21 | PB6 | -2050 | -1049 | 55 | P13 | 2045 | -1205 | 89 | PZ2 | -59 | 2045 | | 22 | P54 | -2050 | -1182 | 56 | P14 | 2045 | -1069 | 90 | PZ3 | -199 | 2045 | | 23 | P55 | -2050 | -1315 | 57 | P15 | 2045 | -933 | 91 | P56 | -338 | 2045 | | 24 | AM0 | -2050 | -1448 | 58 | P16 | 2045 | -796 | 92 | P60 | -478 | 2045 | | 25 | VCC | -2050 | -1581 | 59 | P17 | 2045 | -660 | 93 | P61 | -618 | 2045 | | 26 | X2 | -1551 | -2050 | 60 | P27 | 2045 | -524 | 94 | P62 | -757 | 2045 | | 27 | VSS | -1330 | -2050 | 61 | P26 | 2045 | -388 | 95 | P63 | -897 | 2045 | | 28 | X1 | -1205 | -2050 | 62 | VSS | 2045 | -234 | 96 | P64 | -1037 | 2045 | | 29 | AM1 | -1075 | -2050 | 63 | /NMI | 2045 | -80 | 97 | P65 | -1176 | 2045 | | 30 | /RESET | -948 | -2050 | 64 | VCC | 2045 | 240 | 98 | P66 | -1316 | 2045 | | 31 | XT1 | -822 | -2050 | 65 | P25 | 2045 | 394 | 99 | P67 | -1456 | 2045 | | 32 | XT2 | -520 | -2050 | 66 | P24 | 2045 | 530 | 100 | VREFH | -1725 | 2045 | | 33 | EMU0 | -394 | -2050 | 67 | P23 | 2045 | 666 | | | | | | 34 | EMU1 | -267 | -2050 | 68 | P22 | 2045 | 803 | | | | | ## 2.3 Pin Names and Functions The names of the input/output pins and their functions are described below. Table 2.2 Pin names and functions. | Pin Name | Number of Pins | I/O | Functions | |------------------|----------------|--------|-------------------------------------------------------------------------------------| | D0 to D7 | 8 | I/O | Data (lower): bits 0 to 7 of data bus | | P10 to P17 | 8 | I/O | Port 1: I/O port that allows I/O to be selected at the bit level | | | | | (When used to the external 8bit bus) | | D8 to D15 | | I/O | Data (upper): bits 8 to 15 of data bus | | P20 to P27 | 8 | Output | Port 2: Output port | | A16 to A23 | | Output | Address: bits 16 to 23 of address bus | | A8 to A15 | 8 | Output | Address: bits 8 to 15 of address bus | | A0 to A7 | 8 | Output | Address: bits 0 to 7 of address bus | | /RD | 1 | Output | Read: strobe signal for reading external memory | | /WR | 1 | Output | Write: strobe signal for writing data to pins D0 to D7 | | PZ2 | 1 | I/O | Port Z2: I/O port (with pull-up resistor) | | /HWR | | Output | High Write: strobe signal for writing data to pins D8 to D15 | | PZ3 | 1 | I/O | Port Z3: I/O port (with pull-up resistor) | | $\overline{R/W}$ | | Output | | | P54 | 1 | I/O | Port 54: I/O port (with pull-up resistor) | | /BUSRQ | | Input | Bus Request: High-Impedance used to request Bus Release | | - | | • | Read/Write: 1 represents Read or Dummy cycle; 0 represents write cycle. | | P55 | 1 | I/O | Port 55: I/O port (with pull-up resistor) | | /BUSAK | | Output | Bus Acknowledge: signal used to acknowledge Bus Release | | P56 | 1 | I/O | Port 56: I/O port (with pull-up resistor) | | /WAIT | | Input | Wait: pin used to request CPU bus wait | | P60 | 1 | Output | Port 60:Output port | | /CS0 | | Output | Chip select 0: Outputs "0" when address is within specified address area. | | P61 | 1 | Output | Port 61:Output port | | /CS1 | | Output | Chip Select 1: outputs "0" when address is within specified address area | | P62 | 1 | Output | Port 62: Output port | | /CS2 | | Output | Chip Select 2: outputs "0" when address is within specified address area | | /CS2A | | Output | Expand Chip Select: 2A: outputs 0 when address is within specified address area | | P63 | 1 | Output | Port 63:Output port | | /CS3 | | Output | Chip Select 3: outputs "0" when address is within specified address area | | P64 | 1 | Output | Port 64: Output port | | EA24 | | Output | (Address 24: Expand address) | | /CS2B | | Output | (Expand Chip Select: 2B: outputs "0" when address is within specified address area) | | P65 | 1 | Output | Port 65: Output port | | EA25 | | Output | (Address 25: Expand address) | | /CS2C | | Output | (Expand Chip Select: 2B: outputs "0" when address is within specified address area) | | P66 | 1 | Output | Port 66: Output port | | /CS2D | | Output | (Expand Chip Select: 2D: outputs "0" when address is within specified address area) | | P67 | 1 | Output | Port 67: Output port | | /CS2E | | Output | (Expand Chip Select: 2E: outputs "0" when address is within specified address area) | . | Pin Name | Number<br>of Pins | I/O | Functions | | |--------------|-------------------|--------|-------------------------------------------------------------------------------------|--| | P70 | | I/O | Port 70: I/O port | | | SCK | 1 | I/O | Serial bus interface clock I/O data at SIO mode | | | OPTRX0 | | Input | Serial recive data "0" | | | P71 | 1 | I/O | Port 71: I/O port | | | S0 | | Output | Serial bus interface send data at SIO mode | | | SDA | | I/O | Serial bus interface send/recive data at I2C mode | | | | | | Open drain output mode by programmable (with pull up) | | | OPTTX0 | | Output | Serial send data "0" | | | P72 | 1 | I/O | Port 72I/O port | | | SI | | Input | Serial bus interface recive data at SIO mode | | | SCL | | I/O | Serial bus interface clock I/O data at I2C mode | | | | | | Open drain output mode by programmable (with pull up) | | | P80 to P87 | 8 | Input | Port 80 to 87 port: Pin used to input ports | | | AN0 to AN7 | | Input | Analog input 0 to 7: Pin used to Input to A/D conveter | | | /ADTRG | | Input | A/D trigger: Signal used to request A/D start (with used to P83) | | | PB0 | 1 | I/O | Port B0: I/O port | | | TA0IN | | Input | 8bit timer 0 input: Timer 0 input | | | PB1 | 1 | I/O | Port B1: I/O port | | | TA1OUT | | Output | 8bit timer 1 output: Timer 0 input or Timer 1 output | | | PB2 | 1 | I/O | Port B2: I/O port | | | TA3OUT | | Output | 8bit timer 3 output: Timer 2 input or Timer 3 output | | | PB3 | 1 | I/O | Port B0: I/O port | | | INT0 | | input | Interrupt request pin0: Interrupt request pin with programmable level / rising / | | | | | | falling edge | | | PB4 to PB6 | 3 | I/O | Port B4 to B6: I/O port | | | INT1 to INT3 | | input | Interrupt request pin1 to 3: Interrupt request pin with programmable level / rising | | | | | | /falling edge | | | PC0 | 1 | I/O | Port C0: I/O port | | | TXD0 | | Output | Serial 0 send data: Open drain output pin by programmable | | | PC1 | 1 | I/O | Port C1: I/O port | | | RXD0 | | Input | Serial 0 recive data | | | Pin Name | Number of Pins | I/O | Functions | |----------|----------------|--------|-----------------------------------------------------------------------------| | PC2 | 1 | I/O | Port C2: I/O port | | SCLK0 | | I/O | Serial clock I/O 0 | | /CTS0 | | Input | Serial data send enable 0 (Clear to Send) | | PC3 | 1 | I/O | Port C3: I/O port | | TXD1 | | Output | Serial send data 1 | | | | | Open drain output pin by programmable | | PC4 | 1 | I/O | Port C4: I/O port | | RXD1 | | Input | Serial recive data 1 | | PC5 | 1 | I/O | Port C5: I/O port | | SCLK1 | | I/O | Serial clock I/O 1 | | /CTS1 | | Input | Serial data send enable 1 (Clear to Send) | | XT1 | 1 | Input | Low Frequency Oscillator connecting pin | | XT2 | 1 | Output | Low Frequency Oscillator connecting pin | | PD5 | 1 | Output | Port D5: Output port | | SCOUT | | Output | System clock output: f <sub>SYS</sub> or f <sub>S</sub> output | | PD6 | 1 | Output | Port D6: Output port | | /ALARM | | Output | RTC alarm output pin | | /MLDALM | | Output | | | PD7 | 1 | Output | Port D7: Output port | | MLDALM | | Output | Melody / Alarm output pin | | /NMI | 1 | Input | Non-Maskable Interrupt Request Pin: interrupt request pin with programmable | | | | | falling edge level or with both edge levels programmable | | AM0 to 1 | 2 | Input | Operation mode: | | | | | Fixed to AM1="0",AM0="1" 16-bit external bus or 8/16-bit dynamic sizing. | | | | | Fixed to AM1="0",AM0="0" 8-bit external bus fixed. | | EMU0 | 1 | Output | Open pin | | EMU1 | 1 | Output | Open pin | | /RESET | 1 | Input | Reset: initializes TMP91C824. (With pull-up resistor) | | VREFH | 1 | Input | Pin for reference voltage input to AD converter (H) | | VREFL | 1 | Input | Pin for reference voltage input to AD converter (L) | | AVCC | 1 | I/O | High-frequency oscillator connection pins | | AVSS | 1 | | Power supply pin for AD converter | | X1/X2 | 2 | | GND pin for AD converter (0 V) | | DVCC | 3 | | Power supply pins (All Vcc pins should be connecyed with the power | | | | | Supply pin). | | DVSS | 3 | | GND pins (0 V) (All pins shuold be connected with GND(0V). | #### 3. OPERATION This following describes block by block the functions and operation of the TMP91C824F. Notes and restrictions for eatch book are outlined in "7, Precautions and Restrictions at the end of this manual. #### 3.1 CPU The TMP91C824 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 TMP91C824; these functions are not covered in the TLCS-900/L1 CPU section. #### 3.1.1 Reset When resetting the TMP91C824 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 (ten states: 80 µs at 4 MHz). After Reset, Clock doubler circuit is set to x1 mode, and also Clock gear is set to x1/16 mode. It means that the initial clock mode starts x1/64 speed mode against the maximum speed of TMP91C824. When the reset is accept, the CPU: • Sets as follows the program counter (PC) in accordance with the reset vector stored at address FFFF00H to FFFF02H: ``` PC<0 to 7> ← value at FFFF00H address PC<15 to 8> ← value at FFFF01H address PC<23 to 16>←value at FFFF02H address ``` - Sets the stack pointer (XSP) to 100H. - Sets bits <IFF2:0> of the status register(SR) to 111 (sets the interrupt level mask register to level 7). - Sets the <MAX> bit of the status register(SR) to 1 (MAX mode). (Note: As this product does not support MIN mode, do not write a 0 to the <MAX>) - 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. - Initializes the internal I/O registers. - Sets the port pins, including the pins that also act as internal I/O, to general-purpose input or output port mode. (Note1) The CPU internal register (except to PC,SR,XSP) and internal RAM data do not change by resetting. Figure 3.1.1 is a reset timing chart of the TMP91C824. Figure 3.1.1 TMP91C824 Reset Timing Chart TOSHIBA ## 3.2 Memory Map Figure 3.2.1 is a memory map of the TMP91C824. Figure 3.2 1 Memory Map Note: Address 000FE0H – 00FFFH is assigned for the TOSHIBA reserve area, user can't use. ## 3.3 Triple Clock Function and Standby Function TMP91C824 contains (1) a clock gear, (2) clock doubler (DFM), (3) stand-by controller and (4) noise-reduction circuit. It is used for low-power, low-noise systems. This chapter is organized as follows: - 3.3.1 Block diagram of system clock - 3.3.2 SFRs - 3.3.3 System clock controller - 3.3.4 Prescaler clock controller - 3.3.5 Clock doubler (DFM) - 3.3.6 Noise-reducing circuit - 3.3.7 Stand-by controller The clock operating modes are as follows: (a) Single Clock Mode (X1, X2 pins only), (b) Dual Clock Mode (X1, X2, XT1 and XT2 pins) and (c) Triple Clock Mode (the X1, X2, XT1 and XT2 pins and DFM). Figure 3.3.1 shows a transition figure. (c) Triple clock mode trasision Figure #### \*NOTE) - It's prohibited to control DFM in SLOW mode when shifting from SLOW mode to NORMAL mode with use of DFM. ( DFM Start up/Stop/Change Write to DFMCR0<ACT1:0> resister ) - If you shift from NORMAL mode with use of DFM to NORMAL mode, the instruction should be separated into two procedures as below. Change CPU clock ->Stop DFM circuit - It's prohibited to shift from NORMAL mode with use of DFM to STOP mode directly. You should set NORMAL mode once, and then shift to STOP mode. (You should stop high frequency oscillator after you stop DFM.) Figure 3.3.1 System clock block diagram The clock frequency input from the X1 and X2 pins is called fc and the clock frequency input from the XT1 and XT2 pins is called fs. The clock frequency selected by SYSCR1<SYSCK> is called the system clock $f_{FPH}$ . The system clock $f_{SYS}$ is defined as the divided clock of $f_{FPH}$ , and one cycle of $f_{SYS}$ is regred to as one state. ## 3.3.1 Block diagram of system clock Figure 3.3.2 Block Diagram of System clock ## 3.3.2 SFR | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|-------------|---------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------| | SYSCR0 | bit Symbol | XEN | XTEN | RXEN | RXTEN | RSYSCK | WUEF | PRCK1 | PRCK0 | | (00E0H) | Read/Write | | | | R/ | W | | | | | | After reset | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | | Function | 0: Stop | Low-<br>frequency<br>oscillator (fs)<br>0: Stop<br>1: Oscillation | after release | after release<br>of Stop<br>Mode<br>0: Stop | Selects clock<br>after release<br>of Stop<br>Mode<br>0: fc<br>1: fs | Warm-up Timer 0: Write Don't care 1: Write start timer 0: Read end warm-up 1: Read do not end warm-up | Select presca<br>00: f <sub>FPH</sub><br>01: reserved<br>10: fc/16<br>11: reserved | ler clock | | 0\/0004 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SYSCR1<br>(00E1H) | bit Symbol | | | | | SYSCK | GEAR2 | GEAR1 | GEAR0 | | (002111) | Read/Write | | | | | | R/ | W | | | | After reset | | | | | 0 | 1 | 0 | 0 | | | Function | | | | | Select<br>system clock<br>0: fc<br>1: fs | U | d) | quency (fc) | | SYSCR2 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | (00E2H) | bit Symbol | | SCOSEL | WUPTM1 | WUPTM0 | HALTM1 | HALTM0 | SELDRV | DRVE | | | Read/Write | | R/W | | After reset | | 0 | 1 | 0 | 1 | 1 | 0 | 0 | | | Function | | 0: fs<br>1: f <sub>sys</sub> | Warm-Up Tim<br>00: reserved<br>01: 2 <sup>8</sup> /inputted<br>10:2 <sup>14</sup><br>11:2 <sup>16</sup> | | HALT mode<br>00: reserved<br>01: STOP mo<br>10: IDLE1 mo<br>11: IDLE2 mo | de | <drve><br/>mode<br/>select<br/>0: STOP<br/>1: IDLE1</drve> | Pin state control in STOP mode 0: I/O off 1: Remains the state before HALT | (note1) By Reset, low-frequency oscillator is enable. (note2) In case of using built-in SBI circuit, it must set SYSCR0<PRCK1:0> to '00'. Figure 3.3.3 SFR for system clock Symbol Name Address 7 3 0 ACT1 ACT0 DLUPFG DLUPTM R/W R/W R/W R 0 0 0 0 DFM Lock-up Time select fFPH Lock up DFM Control E8H DFMCR0 0: 212/f<sub>OSCH</sub> Status Flag STOP $f_{OSCH}$ Register 0 1: 210/f<sub>OSCH</sub> 01 RUN RUN **fOSCH** 1: not end 10 RUN STOP $f_{DFM}$ DFM R/W R/W R/W R/W R/W R/W R/W R/W DFMCR1 Е9Н Control 0 0 0 0 0 1 Register 1 DFM revision Input frequency 4~6.75MHz(@2.7V~3.6V): write "0BH" Input frequency $1\sim2.5$ MHz(@ $2.0\pm10\%$ ): write "1BH" Figure 3.3.4 SFR for DFM ### Limitation point on the use of DFM - 1. It's prohibited to execute DFM enable/disable control in the SLOW mode(fs) (write to DFMCR0<ACT1:0>="10"). You should control DFM in the NORMAL mode. - 2. If you stop DFM operation during using DFM(DFMCR0<ACT1:0>="10"), you shouldn't execute that change the clock $f_{DFM}$ to $f_{OSCH}$ and stop the DFM at the same time. Therefore the above executions should be separated into two procedures as showing below. LD (DFMCR0), C0H; change the clock $f_{DFM}$ to $f_{OSCH}$ LD (DFMCR0),00H ; DFM stop 3. If you stop high frequency oscillator during using DFM (DFMCR0<ACT1:0>="10"), you should stop DFM before you stop high frequency oscillator. Please refer to 3.3.5 Clock Doubler (DFM) for the details. | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |----------|-------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|-----------|------------------|----------------|----------------|--|--|--|--| | | bit Symbol | PROTECT | TA3LCDE | - | - | - | EXTIN | DRVOSCH | DRVOSCL | | | | | | EMCCR0 | Read/Write | R | R/W | | | | | (00E3H) | After reset | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | | | | | | , , | | Protect flag | LCDC source | Write "1" | Write "0" | Write "0" | 1: External | fc oscillator | fs oscillator | | | | | | | Function | 0: OFF | CLK | | | | clock | driver ability | driver ability | | | | | | | runction | 1: ON | 0: 32KHz | | | | | 1: NORMAL | 1: NORMAL | | | | | | | | | 1: TA3OUT | | | | | 0: WEAK | 0: WEAK | | | | | | | bit Symbol | | | | | | | | | | | | | | EMCCR1 | Read/Write | | | | | | | | | | | | | | (00E4H) | After reset | | Switching the protect ON/OFF by write to following 1 <sup>st</sup> -KEY,2 <sup>nd</sup> -KEY 1 <sup>st</sup> -KEY: EMCCR1=5AH,EMCCR2=A5H in succession write 2 <sup>nd</sup> -KEY: EMCCR1=A5H,EMCCR2=5AH in succession write | | | | | | | | | | | | | Function | | | | | | | | | | | | | | | bit Symbol | 2 -REY: EMCCRT=ASH, EMCCR2=SAH IN Succession write | | | | | | | | | | | | | EMCCR2 | Read/Write | | | | | | | | | | | | | | (00E5H) | After reset | | | | | | | | | | | | | | (******) | Function | | | | | | | | | | | | | | | bit Symbol | | ENFROM | ENDROM | ENPROM | | FFLAG | DFLAG | PFLAG | | | | | | | Read/Write | | R/W | R/W | R/W | | R/W | R/W | R/W | | | | | | EMCCR3 | After reset | | 0 | 0 | 0 | | 0 | 0 | 0 | | | | | | (00E6H) | | | CS1A area | CS2B-2G | CS2A area | | CS1A write | CS2B-2G | CS2A write | | | | | | | | | detect control | area detect | detect control | | Operation flag | write | Operation | | | | | | | | | 0: disable | control | 0: disable | | | operation | Flag | | | | | | | | ļ | 1: enable | 0: disable | 1: enable | | | Flag | | | | | | | | Function | | | 1: enable | | | When reading | | | | | | | | | | | | | | | "0": not written | | | | | | | | | | | | | | | "1" : written | | | | | | | | | | | | | | | When writing | | | | | | | | | | | | | | | "0" : clear flag | | | | | | | (note) In case of $Vcc=2V \pm 10\%$ use, fixed to EMCCR0<DRV0SCH>='1'. Figure 3.3.5 SFR for noise-reduction ## 3.3.3 System clock controller The system clock controller generates the system clock signal (f<sub>SYS</sub>) 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<GEAR0 to GEAR2> 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 GEAR0 \rangle GEAR2 \rangle = 100$ will cause the system clock (f<sub>SYS</sub>) to be set to fc/32 (fc/16 × 1/2) after a Reset. For example, f<sub>SYS</sub> is set to 0.5 MHz when the 16-MHz oscillator is 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<WUPTM0,WUPTM1>. This warm-up timer can be programmed to start and stop as shown in the following examples 1 and 2. Table 3.3.1 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. | | 8 T | | |--------------------------------------------------------------|--------------------------|------------------------| | Warming-up Time<br>SYSCR2<br><wuptm1,wuptm0></wuptm1,wuptm0> | Change to<br>Normal Mode | Change to<br>Slow Mode | | 01 (2 <sup>8</sup> / frequency) | 16 (μs) | 7.8 (ms) | | 10 (2 <sup>14</sup> / frequency) | 1.024 (ms) | 500 (ms) | | 11 (2 <sup>16</sup> / frequency) | 4.096 (ms) | 2000 (ms) | Table 3.3.1 Warming-up times at $f_{OSCH} = 16 \text{ MHz}$ , fs = 32.768 kHz ## Example 1-Setting the clock Changing from high frequency (fc) to low frequency (fs). | SYSCR0 | EQU | 00E0H | | |--------|-----|-------------------|---------------------------------------------| | SYSCR1 | EQU | 00E1H | | | SYSCR2 | EQU | 00E2H | | | | LD | (SYSCR2), X-11X-B | ; Sets warm-up time to 2 <sup>16</sup> /fs. | | | SET | 6, (SYSCR0) | ; Enables low-frequency oscillation. | | | SET | 2, (SYSCR0) | ; Clears and starts warm-up timer. | | WUP: | BIT | 2, (SYSCR0) | ; Detects stopping of warm-up timer. | | | JR | NZ, WUP | ; J Detects stopping of warm-up timer. | | | SET | 3, (SYSCR1) | ; Changes f <sub>SYS</sub> from fc to fs. | | | RES | 7, (SYSCR0) | ; Disables high-frequency oscillation | | | | | | (note) "x" means don't care "-" means no change Example 2-Setting the clock 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 | ; J Detects stopping of warm-up timer. | | | RES | 3, (SYSCR1) | ; Changes $f_{SYS}$ from fs to fc. | | | RES | 6, (SYSCR0) | ; Disables low-frequency oscillation. | (note) "x" means don't care "-" means no change TOSHIBA #### (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<GEAR0 to GEAR2> 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. #### Example 3 Changing to a high-frequency gear SYSCR1 EQU 00E1H X: Don't care #### (High-speed clock gear changing) To change the clock gear, write the register value to the SYSCR1<GEAR2-0> register. It is necessary the warmming 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). ``` (Example) SYSCR1 EQU 00E1H LD (SYSCR1), XXXX0001B ; Changes f<sub>SYS</sub> to fc/4. LD (DUMMY), 00H ; Dummy instruction Instruction to be executed after clock gear has changed ``` ### (3) Internal clock terminal out function It can out internal $clock(f_{SYS} \text{ or } f_S)$ from PD5/SCOUT. PD5 pin function is set to SCOUT output by the following bit setting. ``` : PDFC<PD5F>='1' ``` Output clock select :Refer to SYSCR2<SCOSEL> bit setting | HALT mode | NORMAL | HALT mode | | | | | |-----------------------|----------------------|--------------------------|-------|-----------|--|--| | SCOUT select | SLOW | IDLE2 | IDEL1 | STOP | | | | <scosel>='0'</scosel> | | f <sub>s</sub> clock out | | | | | | <scosel>='1'</scosel> | f <sub>SYS</sub> clo | ock out '0' or ' | | ' fix out | | | #### 3.3.4 Prescaler clock controller For the internal I/O (TMRA01 to 23, SIO0 to 1) 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 4 or the clock fc/16 divided by 4. The setting of the SYSCR0 < PRCK0 to PRCK1> register determines which clock signal is input. #### 3.3.5 Clock doubler (DFM) DFM outputs the $f_{DFM}$ clock signal, which is four times as fast as $f_{OSCH}$ . It can use the low-frequency oscillator, even though the internal clock is high-frequency. A Reset initializes DFM to Stop status, setting to DFMCR0-register is needed before use. Like an oscillator, this circuit requires time to stabilize. This is called the lock-up time. The following example shows how DFM is used. X: Don't care (note) Input frequency limitation and correction for DFM Recommend to use Input frequency(High speed oscillation) for DFM in the following condition. $f_{OSCH}=4\sim6.75$ MHz (Vcc = 2.7~ 3.6V) : write 0BH to DFMCR1 $f_{OSCH}=2\sim2.5$ MHz (Vcc = 2.0V ±10%) : write 1BH to DFMCR1 #### Limitation point on the use of DFM - 1. It's prohibited to execute DFM enable/disable control in the SLOW mode(fs) (write to DFMCR0<ACT1:0>="10"). You should control DFM in the NORMAL mode. - 2. If you stop DFM operation during using DFM (DFMCR0<ACT1:0>="10"), you shouldn't execute the commands that change the clock f<sub>DFM</sub> to f<sub>OSCH</sub> and stop the DFM at the same time. Therefore the above execution should be separated into two procedures as showing below. LD (DFMCR0),C0H ; Change the clock $f_{DFM}$ to $f_{OSCH}$ LD (DFMCR0),00H; DFM stop 3. If you stop high frequency oscillator during using DFM(DFMCR0<ACT1:0>="10"), you should stop DFM before you stop high frequency oscillator. Examples of settings are below. - (1) Start Up / Change Control - (OK) Low frequency oscillator operation mode(f<sub>s</sub>) (high frequency oscillator STOP) High frequency oscillator start up $\,$ High frequency oscillator $\,$ operation $\,$ mode( $f_{OSCH}$ ) $\,$ DFM start up $\,$ DFM use mode ( $f_{DFM}$ ) ``` ; High frequency oscillator start up/ Warming up start LD (SYSCR0), 11---1--B WUP: BIT 2,(SYSCR0) Check for the flag of warming up end JR NZ,WUP LD ; Change the system clock fs to f<sub>OSCH</sub> (SYSCR1), ----0---B LD (DFMCR0),01-0----B ; DFM start up / lock up start LUP: BIT 5, (DFMCR0) Check for the flag of lock up end JR NZ,LUP Change the system clock f<sub>OSCH</sub> to f<sub>DFM</sub> LD (DFMCR0),10-0----B ``` $(OK) \quad Low \ frequency \ oscillator \ operation \ mode(f_s) \ (high \ frequency \ oscillator \ Operate)$ High frequency oscillator operation $mode(f_{OSCH})$ DFM start up DFM use $mode(f_{DFM})$ $(NG) \quad Low \ frequency \ oscillator \ operation \ mode(f_s) \ (high \ frequency \ oscillator \ STOP)$ $\label{eq:def-high-frequency-def} \mbox{High frequency oscillator start up} \qquad \mbox{DFM start up} \qquad \mbox{DFM use mode } (f_{\mbox{DFM}})$ ``` (SYSCR0),11---1--B; High frequency oscillator start up/ Warming up start LD WUP: BIT 2,(SYSCR0) Check for the flag of warming up end JR NZ,WUP DFM start up / lock up start LD (DFMCR0),01-0----B LUP: BIT 5, (DFMCR0) Check for the flag of lock up end JR NZ.LUP (DFMCR0),10-0----B Change the internal clock f<sub>OSCH</sub> to f<sub>DEM</sub> LD (SYSCR1), -----0---B ; Change the system clock fs to f<sub>DFM</sub> LD ``` ``` (2) Change / Stop Control ``` (OK) DFM use mode $(f_{DFM})$ High frequency oscillator operation mode $(f_{OSCH})$ DFM Stop Low frequency oscillator operation mode $(f_s)$ High frequency oscillator stop ``` LD \qquad \text{(DFMCR0),} 11\text{-----B} \qquad \quad ; \text{Change the system clock } f_{\text{DFM}} \text{ to } f_{\text{OSCH}} ``` LD (DFMCR0),00-----B ; DFM stop LD (SYSCR1), ----1B ; Change the system clock f<sub>OSCH</sub> to fs LD (SYSCR0), 0------B ; High frequency oscillator stop (NG) DFM use mode $(f_{DFM})$ Low frequency oscillator operation mode $(f_s)$ DFM stop High frequency oscillator stop ``` \begin{array}{lll} LD & (SYSCR1), \text{ ----1---B} & ; \text{ Change the system clock } f_{DFM} \text{ to } f_S \\ LD & (DFMCR0), 11------B & ; \text{ Change the internal clock } (f_C) f_{DFM \text{ to }} f_{OSCH} \\ \end{array} ``` LD (DFMCR0),00-----B ; DFM stop LD (SYSCR0), 0-----B ; High frequency oscillator stop (OK) DFM use mode ( $f_{DFM}$ ) Set the STOP mode High frequency oscillator operation mode ( $f_{OSCH}$ ) DFM stop HALT(High frequency oscillator stop) ``` LD (SYSCR2), ----01--B ; Set the STOP mode ``` (This command can execute before use of DFM) LD (DFMCR0),11-----B ; Change the system clock $f_{DFM}$ to $f_{OSCH}$ LD (DFMCR0),00-----B ; DFM stop HALT ; Shift to STOP mode (NG) DFM use mode (f<sub>DFM</sub>) Set the STOP mode HALT(High frequency oscillator stop) LD (SYSCR2), ----01--B ; Set the STOP mode (This command can execute before use of DFM) HALT ; Shift to STOP mode #### Noise reduction circuits Noise reduction circuits are built in, allowing implementation of the following features. - (1) Reduced drivability for high-frequency oscillator - (2) Reduced drivability for low-frequency oscillator - (3) Single drive for high-frequency oscillator - (4) SFR protection of register contents - (5) ROM protection of register contents - (6) Release from hard protection The above functions are performed by making the appropriate settings in the EMCCR0 to EMCCR3 registers. (1) Reduced drivability for high-frequency oscillator #### (Purpose) Reduces noise and power for oscillator when a resonator is used. #### (Block diagram) (Setting method) The drivability of the oscillator is reduced by writing"0" to EMCCR0<DRVOSCH> register. By reset, <DRVOSCH> is initialized to "1" and the oscillator starts oscillation by normal-drivability when the power-supply is on. Don't set $\langle DRVOSCH \rangle$ to "0" at $Vcc=2V \pm 10\%$ . ### (2) Reduced drivability for low-frequency oscillator ### (Purpose) Reduces noise and power for oscillator when a resonator is used. (Block diagram) (Setting method) The drivability of the oscillator is reduced by writing 0 to the EMCCR0<DRVOSCL> register. By Reset, <DRVOSCL> is initialized to "1". ## (3) Single drive for high-frequency oscillator #### (Purpose) Not need twin-drive and protect mistake-operation by inputted noise to X2 pin when the external-oscillator is used. ## (Block diagram) (Setting method) The oscillator is disabled and starts operation as buffer by writing "1" to EMCCR0<EXTIN> register.X2-pin is always outputted"1". By reset, <EXTIN> is initialized to "0". TMP91C824 #### (4) 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, MMU) is changed. And error handling in runaway becomes easy by INTP0 interruption. #### Specified SFR list 1. CS/WAIT controller B0CS, B1CS, B2CS, B3CS, BEXCS, MSAR0, MSAR1, MSAR2, MSAR3, MAMR0, MAMR1, MAMR2, MAMR3 2. MMU LOCAL0/1/2/3 3. Clock gear SYSCR0, SYSCR1, SYSCR2, EMCCR0, EMCCR3 4. DFM DFMCR0, DFMCR1 #### (Operation explanation) Execute and release of protection (write operation to specified SFR) become possible by setting up a double key to EMCCR1 and EMCCR2 register. #### ( Double key) 1<sup>st</sup>-KEY : Succession writes in 5AH at EMCCR1 and A5H at EMCCR2 2<sup>nd</sup>-KEY : Succession writes in A5H at EMCCR1 and 5AH at EMCCR2 A state of protection can be confirmed by reading EMCCR0<PROTECT>. By reset, protection becomes OFF. And INTP0 interruption occurs when write operation to specified SFR was executed with protection ON state. (5) Runaway provision with ROM protection register (Purpose) Provision in runaway of program by noise mixing. (Operation explanation) When write operation was executed for external three kinds of ROM by runaway of program, INTP1 is occurred and detects runaway function. Three kinds of ROM is fixed as for Flash-ROM(Option-Program ROM), Data-ROM, Program-ROM are as follows on the logical address memory map. Flash-ROM : Address 400000H-7FFFFFH Data-ROM : Address 800000H-BFFFFFH Program-ROM : Address C00000H-FFFFFFH For these address, admission / prohibition of detection of write operation sets it up with EMCCR3<ENFROM,ENDROM,ENPROM>. And INTP1 interruption occurred within which ROM can confirm each with EMCCR3<FFLAG,DFLAG,PFLAG>. This flag is cleared when write in "0". ### 3.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,HALTM0> register. The subsequent actions performed in each mode are as follows: ① IDLE2: Only the CPU halts. The internal I/O is available to select operation during IDLE2 mode.by setting the following register. Table 3.3 2 Shows the registers of setting operation during IDLE2 mode. Table 3.3.2 SFR seting operation during IDLE2 mode | Internal I/O | SFR | |---------------|---------------------------| | TMRA01 | TA01RUN <i2ta01></i2ta01> | | TMRA23 | TA23RUN <i2ta23></i2ta23> | | SIO0 | SC0MOD1 <i2s0></i2s0> | | SIO1 | SC1MOD1 <i2s1></i2s1> | | A/D converter | ADMOD1 <i2ad></i2ad> | | WDT | WDMOD <i2wdt></i2wdt> | | SBI | SBI0BR1 <i2sbi0></i2sbi0> | - ② Idle1: Only the oscillator and the RTC (real-time clock) continue to operate. - ③ Stop: All internal circuits stop operating. The operation of each of the different Halt Modes is described in Table 3.3.3. Table 3.3.3 I/O operation during Halt Modes | Halt Mode | | IDLE2 | IDLE1 | STOP | | | |------------------------------|---------------|--------------------------------------------------------|---------------------|------|--|--| | SYSCR2 <haltm1:0></haltm1:0> | | 11 | 10 | 01 | | | | | CPU | Stop | | | | | | Block | I/O ports | Keep the state when the HALT instruction was executed. | See table 3.3.6 | | | | | | TMRA | | | | | | | | SIO, SBI | Available to select | Stop | | | | | | A/D converter | operation block | | | | | | | WDT | operation block | | | | | | | RTC,MLD | | Possible to operate | | | | #### (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 3.3 4. #### • 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~INT4 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". #### • Releasing by resetting Releasing all halt status is executed by resetting. When the Stop mode is released by RESET, it is necessry enough resetting time (see table 3.3.5) 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.) **TOSHIBA** | Status of Received Interrupt | | atus of Received Interrupt | Interrupt Enabled (interrupt level) ≥ (interrupt mask) | | Interrupt Disabled (interrupt level) < (interrupt mask) | | | | |--------------------------------|-----------|----------------------------|--------------------------------------------------------|----------|---------------------------------------------------------|-------|-------|------| | Halt mode | | Halt mode | Idle2 | Idle1 | Stop | Idle2 | Idle1 | Stop | | Source of Halt state clearance | | NMI | <b>©</b> | @ | ⊚ <sup>*1</sup> | _ | | | | | Interrupt | INTWDT | <b>©</b> | × | × | | | | | | | INT0 □ □ 3 (Note1) | <u> </u> | <b>©</b> | *T | 0 | 0 | 0*1 | | | | INTALM0 to 4 | <u> </u> | <b>©</b> | × | 0 | 0 | × | | | | INTTA0 to 3 | <u> </u> | × | × | × | × | × | | | | INTRX0 to 1,TX0 to 1 | <u> </u> | × | × | × | × | × | | | | INTAD | <u> </u> | × | × | × | × | × | | | | INTKEY | <u> </u> | <b>©</b> | *T | 0 | 0 | 0*1 | | | | INTRTC | <u> </u> | <u></u> | × | 0 | 0 | × | | | | INTSBI | <b>©</b> | × | × | × | × | × | | S | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | Table 3.3.4 Source of Halt state clearance and Halt clearance operation - **③**: After clearing the Halt mode, CPU starts interrupt processing. (RESET initializes the microcont.) - O: After clearing the Halt mode, CPU resumes executing starting from instruction following the HALT instruction. - ×: 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 warmming-up time. - Note 1: When the Halt mode is cleared by an INT0 interrupt of the level mode in the interrupt enabled status, hold level H until starting interrupt processing. If level L is set before holding level L, interrupt processing is correctly started. (Example - clearing Idle1 Mode) An INT0 interrupt clears the Halt state when the device is in Idle1 Mode. #### (3) Operation #### 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 3.3 6 illustrates an example of the timing for clearance of the Idle2 Mode Halt state by an interrupt. Figure 3.3.6 Timing chart for Idle2 Mode Halt state cleared by interrupt #### Idle1 Mode In Idle1 Mode, only the internal oscillator and the RTC,MLD continue to operate. The system clock in the MCU stops. The pin status in the IDLE1 mode is depended on setting the register SYSCR2<SELDRV,DRVE>. Table 3.3 6 summarizes the state of these pins in the IDLE mode1. In the Halt state, the interrupt request is sampled asynchronously with the system clock; however, clearance of the Halt state (i.e. restart of operation) is synchronous with it. Figure 3.3 7 illustrates the timing for clearance of the Idle1 Mode Halt state by an interrupt. Figure 3.3.7 Timing chart for Idle1 Mode Halt state cleared by interrup 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 3.3.6 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 SYSCR0<RSYSCK> register. Therefore, <RSYSCK>, <RXEN> and <RXTEN> must be set See the sample warm-up times in Table 3.3.5. Figure 3.3.8 illustrates the timing for clearance of the Stop Mode Halt state by an interrupt. Figure 3.3.8 Timing chart for Stop Mode Halt state cleared by interrupt Table 3.3.5 Sample warm-up times after clearance of Stop Mode @f<sub>OSCH</sub> =16 MHz, fs =32.768 kHz | SYSCR0 | SYSCR2 <wuptm1,wuptm0></wuptm1,wuptm0> | | | | | |-------------------|----------------------------------------|-----------------------|-----------------------|--|--| | <rsysck></rsysck> | 01 (28) | 10 (2 <sup>14</sup> ) | 11 (2 <sup>16</sup> ) | | | | 0 (fc) | 16 □s | 1.024 ms | 4.096 ms | | | | 1 (fs) | 7.8 ms | 500 ms | 2000 ms | | | (Setting 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 8 state). In the system which accepts the interrupts during execution "HALT" instruction, set the same operation mode before and after the STOP mode. Table 3.3.6 Pin states in IDLE1/Stop Mode | Pin name | Inpu | t/Output | $\langle DRVE \rangle = 0$ | <drve> = 1</drve> | | |-------------------------------|-------------|----------|----------------------------|-------------------|--| | D0~7 | I/O | | _ | _ | | | P10~17(D8~15 | Input mode | | _ | _ | | | | Output mode | | _ | Output | | | | I/O | | _ | - | | | P20~27(A16~23),A0~15,P | Output pin | | - | Output | | | D0~PD7 | | | | | | | $\overline{RD},\overline{WR}$ | Output pin | | _ | '1' output | | | P52~56 | Input mode | | _ | Input | | | | Output mode | | _ | Output | | | P60~P64 | Output pin | | _ | Output | | | P70-71 | Input mode | | _ | Input | | | | Output mode | | _ | Output | | | P72 | Input mode | | Input | Input | | | | Output mode | | _ | Output | | | P80~P87 | Input pin | | _ | _ | | | PB0~PB2,PC0~PC5 | Input mode | | _ | Input | | | | Output mode | | _ | Output | | | PB3~PB6 | Input mode | | Input | Input | | | | Output mode | | _ | Output | | | NMI | Input pin | | Input | Input | | | RESET | Input | | Input | Input | | | AM0, AM1 | Input | | Input | Input | | | X1,XT1 | Input IDLE1 | | Input | Input | | | | | STOP | _ | _ | | | X2,XT2 | Output | IDLE1 | Output | Output | | | | | STOP | "H" Level output | "H" Level output | | | | | | XT2 is Hi-Z | XT2 is Hi-Z | | - : Input for input mode/input pin 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 ## 3.4 Interrupts Interrupts are controlled by the CPU Interrupt Mask Register SR<IFF2:0> and by the built-in interrupt controller. The TMP91C824 has a total of 37 interrupts divided into the following five types: - Interrupts generated by CPU: 9 sources (Software interrupts,Illegal Instruction interrupt) - Internal interrupts: 23 sources - Interrupts on external pins (NMI and INT0 to INT3): 5 sources A (fixed) individual interrupt vector number is assigned to each interrupt. One of seven (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 piority 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 <IFF[2: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 <IFF[2:0]> value can be updated using the value of the EI instruction ("EI num" sets <IFF[2:0]> data to num). For example, specifying "EI 3" 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 (<IFF[2:0]> ="7") is identical to the "EI 7" 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 vaild 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,TMP91C824 has software start function for micro DMA processing request by the software not by the hardware interrupt. Figure 3.4.1 shows the overall interrupt processing flow. Figure 3.4.1 Overall interrupt processing flow #### 3.4.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. - (1) 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 <IFF[2: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(2.25usec. at 16MHz) as the best case(16bits data-bus width and 0-wait). When the CPU compled 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 <IFF[2:0]> comes out, the CPU accepts its interrupt. Then, the CPU Interrupt Mask Register <IFF[2: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 <IFF[2:0]> to "111", disabling all maskable interrupts. Table 3.4.1 shows the TMP91C824 interrupt vectors and micro DMA start vectors. The address FFFF00H to FFFFFH (256 bytes) is assigned for the interrupt vector area. Table 3.4.1 TMP91C824 interrupt vectors table | Default | | | | Vector | Micro | |----------|----------|------------------------------------------------------|------------|--------------|--------------| | Priority | Туре | Interrupt source and source of micro DMA request | Vector | reference | DMA | | Thomey | 1,700 | Zitoriage source and source or interest zitoriageos | value(V) | Address | start vector | | 1 | | "Reset" or 「SWI 0」 instruction | 0000Н | FFFF00H | - | | 2 | | 「SWI 1」 instruction | 0004H | FFFF04H | - | | 3 | | INTUNDEF: illegal instruction or 「SWI 2」 instruction | 0008H | FFFF08H | - | | 4 | | 「SWI 3」 instruction | 000CH | FFFF0CH | - | | 5 | Non- | 「SWI4」instruction | 0010H | FFFF10H | - | | 6 | Maskable | 「SWI 5」 instruction | 0014H | FFFF14H | - | | 7 | | 「SWI 6」 instruction | 0018H | FFFF18H | - | | 8 | | 「SWI7」instruction | 001CH | FFFF1CH | - | | 9 | | NMI pin | 0020H | FFFF20H | - | | 10 | | INTWD: Watchdog timer | 0024H | FFFF24H | - | | _ | | Micro DMA (MDMA) | - | - | - | | 11 | | INTO pin | 0028H | FFFF28H | 0AH | | 12 | | INT1 pin | 002CH | FFFF2CH | 0BH | | 13 | | INT2 pin | 0030H | FFFF30H | 0CH | | 14 | | INT3 pin | 0034H | FFFF34H | 0DH | | 15 | | INTALM0: ALM0(8KHz) | 0038H | FFFF38H | 0EH | | 16 | | INTALM1: ALM1(512Hz) | 003CH | FFFF3CH | 0FH | | 17 | | INTALM2: ALM2(64Hz) | 0040H | FFFF40H | 10H | | 18 | | INTALM3: ALM3(2Hz) | 0044H | FFFF44H | 11H | | 19 | | INTALM4: ALM4(1Hz) | 0048H | FFFF48H | 12H | | 20 | | INTTA0 : 8 bit timer0 | 004CH | FFFF4CH | 13H | | 21 | | INTTA1 : 8 bit timer1 | 0050H | FFFF50H | 14H | | 22 | | INTTA2 : 8 bit rimer2 | 0054H | FFFF54H | 15H | | 23 | | INTTA3 : 8 bit timer3 | 0058H | FFFF58H | 16H | | 24 | M11-1- | INTRX0 : serial reception (channel. 0) | 005CH | FFFF5CH | 17H | | 25 | Maskable | INTTX0 : serial transmission (channel. 0) | 0060H | FFFF60H | 18H | | 26 | | INTRX1 : serial reception (channel. 1) | 0064H | FFFF64H | 19H | | 27 | | INTTX1 : serial transmission (channel. 1) | 0068H | FFFF68H | 1AH | | 28 | | INTAD : A/D conversion end | 006CH | FFFF6CH | 1BH | | 29 | | INTRTC : RTC (alarm interrupt) | 0074H | FFFF74H | 1DH | | 30 | | INTSBI : SBI interrupt | 0078H | FFFF78H | 1EH | | 31 | | INTP0 : Protect0 (WR to special SFR) | 0080H | FFFF80H | 20H | | 32 | | INTP1 : Protect1 (WR to ROM) | 0084H | FFFF84H | 21H | | 33 | | INTTC0 : Micro DMA end (channel. 0) | 0088H | FFFF88H | | | 34 | | INTTC1 : Micro DMA end (channel. 1) | 008CH | FFFF8CH | | | 35 | | INTTC2 : Micro DMA end (channel. 2) | 0090H | FFFF90H | | | 36 | | INTTC3 : Micro DMA end (channel. 3) | 0094H | FFFF94H | | | | | (Reserved) | 0098H | FFFF98H | - | | | | (Reserved) | :<br>00FCH | :<br>FFFFFCH | : | ## 3.4.2 Micro DMA processing In addition to general-purpose interrupt processing, the TMP91C824 supprots 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. Micro. The micro DMA has 4 channels and is possible continuous transmission by specifing the say later burst mode. Because the micro DMA function has been implemented with the cooperative operation of CPU, when CPU goes to a stand-by mode by HALT instruction, the requirement of micro DMA will be ignored (pending). #### (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 <IFF[2: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 isn't specified the say 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. 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 16M bytes (the upper eight bits of the 32 bits are not valid). 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.4.2 (4) "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 24 interrupts shown in the micro DMA start vectors of Table 3.4.1 and by the micro DMA soft start, making a total of 25 interrupts. Figure 3.4.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, trandfer source/transfer destination addresses both even-numberd values). Figure 3.4.2 Timing for micro DMA cycle States 1~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~5: Micro DMA read cycle State 6: Dummy cycle (the address bus remains unchanged from state 5) States 7~8: Micro DMA write cycle (note1): 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. (note2): 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. #### (2) Soft start function In addition to starting the micro DMA function by interrupts, TMP91C824 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. 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". 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. | Symbol | NAME | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|---|---|---|---|-------|-------|---------|-------| | | | | | | | | | DMA I | Request | | | DMAD | DMA | 89h | | | | | DMAR3 | DMAR2 | DMAR1 | DMAR0 | | DMAR | Request | | | | | | | R/ | W | | | | Register | (no RMW) | | | | | 0 | 0 | 0 | 0 | #### (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. TOSHIBA (4) Detailed description of the Transfer Mode Register DMAM0 to 0 0 0 Mode (note): When setting a value in this register, write 0 to the upper 3 bits. | | | | Number of | Mada Dagainting | Number of | Minimum | |----------------|-----|----------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------| | | | | Transfer Bytes | Mode Description | Execution States | Execution Time<br>@ fc = 16 MHz | | 000<br>(fixed) | 000 | 00 | Byte transfer | Transfer Destination Address INC Mode | 8 states | 1000 ns | | | | 01<br>10 | Word transfer 4-byte transfer | $\begin{aligned} & DMACn \leftarrow DMACn - 1 \\ & If \; DMACn = 0, then \; INTTCn \; is \; generated. \end{aligned}$ | 12 sates | 1500 ns | | | 001 | 00 | Byte transfer | Transfer Destination Address DEC Mode | 8 states | 1000 ns | | | | 01<br>10 | Word transfer 4-byte transfer | (DMADn-) ← (DMASn) DMACn ← DMACn - 1 If DMACn = 0, then INTTCn is generated. | 12 sates | 1500 ns | | | 010 | 00 | Byte transfer | Transfer Source Address INC ModeMemory to I/O | 8 states | 1000 ns | | | | 01<br>10 | Word transfer 4-byte transfer | (DMADn) ← (DMASn+) DMACn ← DMACn − 1 If DMACn = 0, then INTTCn is generated. | 12 sates | 1500 ns | | | 011 | 00 | Byte transfer | Transfer Source Address DEC Mode Memory to I/O | 8 states | 1000 ns | | | | 01<br>10 | Word transfer 4-byte transfer | (DMADn) ← (DMASn–) DMACn ← DMACn – 1 If DMACn = 0, then INTTCn is generated. | 12 sates | 1500 ns | | | 100 | 00 | Byte transfer | Fixed Address Mode I/O to I/O | 8 states | 1000 ns | | | | 01<br>10 | Word transfer 4-byte transfer | (DMADn) ← (DMASn–) DMACn ← DMACn − 1 If DMACn = 0, then INTTCn is generated. | 12 sates | 1500 ns | | | 101 | 00 | $\begin{array}{c} DMASn \leftarrow DMASn \\ DMACn \leftarrow DMACn \end{array}$ | | 5 sates | 625 ns | (note1): "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. (note2): Execution time is under the condition of: 16bit bus width(both translation and destination address area) / 0 wait / fc = 16MHz / selected high frequency mode (fc x 1) (note3): Do not use an undefined code for the transfer mode register except for the defined codes listed in the above table. ## 3.4.3 Interrupt controller operation The block diagram in Figure 3.4.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 each of the 36 interrupt channels 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 zero 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 INTE12). 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 Watch dog Timer interrupts) is fixed at 7. If interrupt request with the same level are generated at the same time, the default priority (the interrupt with the lowest priority or, in other words, the interrupt with the lowest vector value) 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 with the highest priority among the simulateous interrupts and its vector address to the CPU. The CPU compares the priority value <IFF[2: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 <IFF[2: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<IFF[2: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 (see Table 3.4.1), enables the corresponding interrupt to be processed by micro DMA processing. The values must be set in the micro DMA parameter register (e.g. DMAS and DMAD) prior to the micro DMA processing. Figure 3.4.3 Block Diagram of Interrupt Controller 91C824-45 # (1) Interrupt level setting registers | Symbol | NAME | Address | 7 | 6 | 5 | 4 | | 3 | 2 | 1 | 0 | |----------|-----------------|---------|-------|--------|------------------|----------|------|---------------------------------------|-------------|---------|-----------| | | D. ITO C | | | | INTAD | | | | IN | Т0 | | | DIEE A D | INTO &<br>INTAD | 90h | IADC | IADM | 2 IADN | 11 IAD | M0 | IOC | I0M2 | I0M1 | I0M0 | | INTE0AD | Enable | 9011 | R | | R/W | <i>I</i> | | R | | R/W | | | | Endoic | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | INT1 & | | | | INT2 | | | | IN | T1 | | | INTE12 | INT2 | 91h | I2C | I2M2 | l I2M | 1 I2N | 10 | I1C | I1M2 | I1M1 | I1M0 | | 111212 | Enable | | R | | R/W | | | R | | R/W | | | | | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | INT3& | | | | NTALM4 | | | | | T3 | | | INTE3 | INTALM | 92h | IA4C | IA4M | | | M0 | I3C | I3M2 | I3M1 | I3M0 | | ALM4 | 4Enable | | R | 0 | R/W | | | R | 0 | R/W | 0 | | | DYTALA | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | INTALM<br>0 & | | IA1C | IA1M | NTALM1<br>2 IA1M | 11 IA11 | MO | IA0C | IA0M2 | IA0M1 | IA0M0 | | INTEALM | INTALM | 93h | R | IATIVI | Z IATIV | | VIU | R | IAUWIZ | R/W | IAUNIU | | 01 | 1 | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 R/W | 0 | | | Enable | | U | U | Ü | Ů | | U | O | Ü | Ü | | | INTALM | | | I | NTALM3 | | | | INTA | LM2 | | | INTEALM | 2 & | | IA3C | IA3M | 2 IA3N | 11 IA31 | M0 | IA2C | IA2M2 | IA2M1 | IA2M0 | | 23 | INTALM | 94h | R | | R/W | <i>I</i> | | R | | R/W | | | | 3 | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | Enable | | | INIT | TA1(TMRA1 | <u> </u> | | | INITTAO | (TMRA0) | | | | INTTA0<br>& | | ITA1C | ITA1N | · · | · • | M0 | ITA0C | ITA0M2 | ITA0M1 | ITA0M0 | | INTETA01 | INTTA1 | 95h | R | 117111 | R/W | - | 1110 | R | 11710112 | R/W | 117101110 | | | Enable | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | INTTA2 | | | | TA3(TMRA3 | | | | | (TMRA2) | | | | & | | ITA3C | ITA3N | <u> </u> | | 3M0 | ITA2C | ITA2M2 | ITA2M1 | ITA2M0 | | INTETA23 | INTTA3 | 96h | R | | R/W | 7 | | R | | R/W | | | | Enable | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | | | | | _ | - | | | INT | RTC | _ | | | INTRTC | 97h | | | | | | IRC | IRM2 | IRM1 | IRM0 | | INTERTC | enable | 9711 | | | | | | R | | R/W | | | | | | | | | | | 0 | 0 | 0 | 0 | | | | | 1 | | | | | 1 1 1 | | | | | Interru | pt request flag | | | | | | | | | | | | michia | pt request mag | | | | <b>—</b> | | | | | | | | | | | | | <u></u> | | | | | | | | | | | | lxxM2 | lxxM1 | lxxM0 | | Fu | nction (W | rite) | | | | | | | 0 | 0 | 0 | Di | isables interrup | ot requests | | | | | | | | 0 | 0 | 1 | | ets interrupt pri | | 1 | | | | | | | 0 | 1 | 0 | | ets interrupt pri | • | | | | | | | | 0 | 1 | 1 | | ets interrupt pri | - | | | | | | | | 1 | 0 | 0 | | ets interrupt pri | - | | | | | | | | 1 | 0 | 1 0 | | ets interrupt pri | | | | | | | | | 1 | 1<br>1 | 1 | | ets interrupt pri<br>isables interruj | - | U | | | | | | | 1 | 1 | 1 | וט | isavies mienuļ | r requests | | | | Symbol | NAME | Address | 7 | 6 | 5 | 4 | | 3 | 2 | 1 | 0 | |--------|--------------------|--------------|--------|---------|----------|---------|------------|------------------|-----------------|----------|--------| | | | | | | INTTX0 | | | | INT | RX0 | | | | Interrupt | 0011 | ITX0C | ITX0N | 12 ITX01 | M1 ITX0 | <b>M</b> 0 | IRX0C | IRX0M2 | IRX0M1 | IRX0M0 | | INTES0 | Enable<br>Serial 0 | 98H | R | | R/V | V | | R | | R/W | | | | Serial 0 | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | | | | • | INTTX1 | - | | | INT | RX1 | _ | | | INTRX1 & | 0011 | ITXT10 | C ITX1N | 12 ITX11 | M1 ITX1 | M0 | IRX1C | IRX1M2 | IRX1M1 | IRX1M0 | | INTES1 | INTTX1<br>Enable | 99H | R | | R/V | V | | R | | R/W | | | | Enable | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | | | | | | | | | IN | ΓS2 | | | | INTES2 | 9AH | | | | | | IS2C | IS2M2 | IS2M1 | IS2M0 | | INTES2 | Enable | 9AH | | | | | | R | | R/W | | | | | | | | | | | 0 | 0 | 0 | 0 | | | | | | | INTTC1 | | | | INT | TC0 | | | INTET | INTTC0 & INTTC1 | 9 <b>B</b> H | ITC1C | ITC1N | 12 ITC11 | M1 ITC1 | M0 | ITC0C | ITC0M2 | ITC0M1 | ITC0M0 | | C01 | Enable | ЭБП | R | | R/V | V | | R | | R/W | | | | Eliable | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | | | | | INTTC3 | | | | INT | TC2 | | | INTET | INTTC2 & | 9CH | ITC3C | ITC3N | 12 ITC31 | M1 ITC3 | M0 | ITC2C | ITC2M2 | ITC2M1 | ITC2M0 | | C23 | INTTC3<br>Enable | 9СП | R | | R/V | V | | R | | R/W | | | | Eliable | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | | | | | INTP1 | • | | | INT | ГРО | | | INTE | INTPO & | ODII | IP1C | IP1M | 2 IP1N | 11 IP1N | <b>4</b> 0 | IP0C | IP0M2 | IP0M1 | IP0M0 | | P01 | INTP1<br>Enable | 9DH | R | | R/V | V | | R | | R/W | | | | Eliable | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | ~ | | | | | | | | | | | | Interi | rupt request fla | g | • | | <b>—</b> | | | | | | | | | | | | | | | | | | | | | | | | | lxxM2 | lxxM1 | lxxM0 | | Fu | inction (Wi | rite) | | | | | | | 0 | 0 | 0 | Di | isables interru | nt requests | <u> </u> | | | | | | | 0 | 0 | 1 | | ets interrupt pr | - | 1 | | | | | | | 0 | 1 | 0 | | ets interrupt pr | - | | | | | | | | 0 | 1 | 1 | | ets interrupt pr | - | | | | | | | | 1 | 0 | 0 | | ets interrupt pr | - | | | | | | | | 1 | 0 | 1 | Se | ets interrupt pr | iority level to | 5 | | | | | | | 1 | 1 | 0 | Se | ets interrupt pr | iority level to | 6 | | | | | | | 1 | 1 | 1 | Di | isables interru | pt requests | | | #### (2) External interrupt control | Symbol | NAME | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|----------|----------|---|------------|------------|------------|------------|-----------|--------------| | | | | | - | I3EDGE | I2EDGE | I1EDGE | I0EDGE | I0LE | NMIREE | | | | | | | | | W | | | | | | Interrupt | 8CH | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | IIMC | Input | | Always | | INT3EDGE | INT2EDGE | INT1EDGE | INT0EDGE | INT0 mode | 1: Operates | | mvic | Mode | | write"0" | | 0: Rising | 0: Rising | 0: Rising | 0: Rising | 0: Edge | even on | | | control | (no RMW) | | | 1: Falling | 1: Falling | 1: Falling | 1: Falling | 1: Level | rising / | | | | | | | | | | | | falling edge | | | | | | | | | | | | of NMI | | | | | | | | | | | | | | INT0 lev | rel Enable | _ | | |----------|-----------------------------------------------|---|--| | 0 | Rising edge detect INT | | | | 1 | "H" level INT | | | | NMI ris | ing edge Enable | _ | | | 0 | INT request generation at falling edge | | | | 1 | INT request generation at rising/falling edge | | | #### (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.4 1, to the register INTCLR. For example, to clear the interrupt flag INTO, perform the following register operation after execution of the DI instruction. $INTCLR \leftarrow 0AH: \qquad \qquad Clears \ interrupt \ request \ flag \ INT0.$ | Symbol | NAME | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|----------|---|---|-------|----------|-----------|-------|-------|-------| | | _ | | | | CLRV5 | CLRV4 | CLRV3 | CLRV2 | CLRV1 | CLRV0 | | | Interrupt | 88H | | | | | W | | | | | INTCLR | Control | | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Control | (no RMW) | | • | | Interruj | ot Vector | • | | | #### (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 zero, 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) | Symbol | NAME | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------|-----------------|---------|---|---|--------|--------|-------------------|------------|--------|--------|--|--| | | | | | | | | DMA0 Start Vector | | | | | | | DMAON | DMA0 | 0011 | | | DMA0V5 | DMA0V4 | DMA0V3 | DMA0V2 | DMA0V1 | DMA0V0 | | | | DMA0V | Start<br>Vector | 80H | | | | | R/ | W | | | | | | | Vector | | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 200 | | | | | | DMA1 St | art Vector | | | | | | DMAIN | DMA1 | 81H | | | DMA1V5 | DMA1V4 | DMA1V3 | DMA0V2 | DMA1V1 | DMA1V0 | | | | DMA1V | Start<br>Vector | 81H | | | | | R/ | W | | | | | | | Vector | | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 53.61.0 | | | | | | DMA2 St | art Vector | | | | | | DMA2V | DMA2<br>Start | 82H | | | DMA2V5 | DMA2V4 | DMA2V3 | DMA2V2 | DMA2V1 | DMA2V0 | | | | DMAZV | Vector | 82H | | | | | R/ | W | | | | | | | Vector | | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | DMAG | | | | | | DMA3 St | art Vector | | | | | | DMA3V | DMA3 | 8311 | | | DMA3V5 | DMA3V4 | DMA3V3 | DMA3V2 | DMA3V1 | DMA3V0 | | | | DIMASV | Start<br>Vector | 83H | | | | | R/ | W | | | | | | | VCCtOI | | | | 0 | 0 | 0 | 0 | 0 | 0 | | | # (5) Micro DMA burst specification Specifying the micro DMA burst continues the micro DMA transfer until the transfer counter register reaches zero 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. | Symbol | NAME | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|---------|---|---|---|---|-------|-------------|---------------|-------| | | DMA | | | | | | DMAR3 | DMAR2 | DMAR1 | DMAR0 | | DMAR | Software | 89H | | | | | R/W | R/W | R/W | R/W | | DMAK | Request | 89П | | | | | 0 | 0 | 0 | 0 | | | Register | | | | | | | 1: DMA Soft | tware request | | | | DMA | 0.444 | | | | | DMAB3 | DMAB2 | DMAB1 | DMAB0 | | DMAB | Burst | 8AH | | | | | | R/ | W | | | | Register | | | | | | 0 | 0 | 0 | 0 | #### (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(\*1) 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 avobe plogram, place instructions that clear interrupt request flags after a DI instruction. 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. | INTO Level Mode | In Level Mode INTO is not an edge-triggered interrupt. Hence, in Level Mode the interrupt request flip-flop for INTO 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. If the CPU enters the interrupt response sequence as a result of INTO going from 0 to 1, INTO must then be held at 1 until the interrupt response sequence has been completed. If INTO is set to Level Mode so as to release a Halt state, INTO must be held at 1 from the time INTO 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 INTO 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. | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | EI | | INTRX | The interrupt request flip-flop can only be cleared by a Reset or by reading the Serial Channel Receive Buffer. It cannot be cleared by an instruction. | (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 L) INTRX: Instruction which read the Receive Buffer # 3.5 Port Functions The TMP91C824 features 56 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 3.5.1 lists the functions of each port pin. Table 3.5.2 lists I/O registers and their specifications. Table 3.5.1 Port functions (R: PU= with programmable pull-up resistor / U= with pull-up resistor) | Port name | Pin name | Number of pins | Direction | R | Direction<br>Setting unit | Pin name for built-in function | |-----------|------------|----------------|------------|----|---------------------------|--------------------------------| | Port 1 | P10 to P17 | 8 | I/O | _ | Rit | D8 to D15 | | Port 2 | P20 to P27 | 8 | Output | _ | (Fixed) | A16 to A23 | | Port 5 | P54 | 1 | I/O | PU | Bit | BUSRO | | | P55 | 1 | I/O | PU | Bit | BUSAK | | | P56 | 1 | I/O | PU | Bit | WAIT | | Port 6 | P60 | 1 | Output | _ | (Fixed) | /CS0 | | | P61 | 1 | Output | _ | (Fixed) | /CS1 | | | P62 | 1 | Output | _ | (Fixed) | /CS2,/CS2A | | | P63 | 1 | Output | _ | (Fixed) | /CS3 | | | P64 | 1 | Output | _ | (Fixed) | EA24,/CS2B | | | P65 | 1 | Output | _ | (Fixed) | EA25,/CS2C | | | P66 | 1 | Output | - | (Fixed) | /CS2D | | | P67 | 1 | Output | - | (Fixed) | /CS2E | | Port 7 | P70 | 1 | I/O | _ | Bit | SCK,OPTRX0 | | | P71 | 1 | I/O | PU | Bit | SO/SDA,OPTTX0 | | | P72 | 1 | I/O | PU | Bit | SI/SCL | | Port 8 | P80 to P87 | 8 | Input | - | (Fixed) | AN0 to AN7, ADTRG (P83) | | Port B | PB0 | 1 | I/O | _ | Bit | TA0IN | | | PB1 | 1 | I/O | _ | Bit | TA1OUT | | | PB2 | 1 | I/O | _ | Bit | TA3OUT | | | PB3 | 1 | I/O | _ | Bit | INT0 | | | PB4 | 1 | I/O | _ | Bit | INT1 | | | PB5 | 1 | I/O | _ | Bit | INT2 | | | PB6 | 1 | I/O | _ | Bit | INT3 | | Port C | PC0 | 1 | I/O | _ | Bit | TXD0 | | | PC1<br>PC2 | 1 | I/O<br>I/O | _ | Bit<br>Bit | RXD0 | | | PC2<br>PC3 | 1 | I/O | _ | Bit<br>Bit | SCLK0/CTS0<br>TXD1 | | | PC4 | 1 | I/O | _ | Bit | RXD1 | | | PC5 | 1 | I/O | _ | Bit | SCLK1/CTS1 | | PortD | PD5 | 1 | Output | _ | (Fixed) | SCOUT | | | PD6 | 1 | Output | _ | (Fixed) | ALARM,/MLDALM | | | PD7 | 1 | Output | _ | (Fixed) | MLDALM | | Port Z | PZ2 | 1 | I/O | PU | Bit | HWR | | | PZ3 | 1 | I/O | PU | Bit | $R/\overline{W}$ | Table 3.5.2 I/O Registers and Specifications (1/2) X: Don't care | D . | D. | g : c · · | | I/O regi | ster | | |---------|------------|--------------------------|----|----------|------|-------| | Port | Pin name | Specification | Pn | PnCR | PnFC | PnFC2 | | Port 1 | P10 to P17 | Input port | X | 0 | None | None | | (note1) | | Output port | X | 1 | | | | | | D8 to D15 bus | X | X | | | | Port 2 | P20 to P27 | Output port | X | None | 0 | | | | | A16 to A23 output | X | | 1 | | | Port 5 | P54 to P56 | Input port (Without PU) | 0 | 0 | 0 | | | | | Input port (with PU) | 1 | 0 | 0 | | | | | Output port | X | 1 | 0 | | | | P54 | BUSRQ input (Without PU) | 0 | 0 | 1 | | | | | BUSRQ input (With PU) | 1 | 0 | 1 | | | | P55 | BUSAK output | X | 1 | 1 | | | | P56 | WAIT input (Without PU) | 0 | 0 | | | | | | WAIT input (With PU) | 1 | 0 | None | | | Port 6 | P60 to P64 | Output port | X | | 0 | 0 | | | P60 | /CS0 output | X | | 1 | None | | | P61 | /CS1 output | X | 1 | 1 | | | | P62 | /CS2 output | X | | 1 | 0 | | | | /CS2A output | X | 1 | X | 1 | | | P63 | /CS3 output | X | None | 1 | None | | | P64 | EA24 output | X | None | 1 | 0 | | | | /CS2B output | X | | X | 1 | | | P65 | EA25 output | X | | 1 | 0 | | | | /CS2C output | X | 1 | X | 1 | | | P66 | /CS2D output | X | | 0 | 1 | | | P67 | /CS2E output | X | | 0 | 1 | | Port 7 | P70 to P72 | Input port (without PU) | 0 | 0 | 0 | 0 | | | | Input port (With PU) | 1 | 0 | 0 | 0 | | | | Output port | X | 1 | 0 | 0 | | | P70 | SCK input | X | 0 | 0 | 0 | | | | SCK output | X | 1 | 1 | 0 | | | | OPTRX0 input (note2) | 1 | 0 | X | 1 | | | P71 | SDA input | X | 0 | 0 | 0 | | | | SDA output (note3) | X | 1 | 1 | 0 | | | | SO output | X | 1 | 1 | 0 | | | | OPTTX0 output (note2) | 1 | 1 | X | 1 | | | P72 | SI input | X | 0 | 0 | 0 | | | | SCL input | X | 0 | 0 | 0 | | | | SCL output (note3) | X | 1 | 1 | 0 | Table 3.5.3 I/O Registers and Specifications (2/2) X: Don't care | Port | Pin name | Specification | | I/O regi | ster | | |-------------------|------------|----------------------------|----|----------|------|------| | Port | Pin name | Specification | Pn | PnCR | PnFC | PnFC | | Port 8 | P80 to P87 | Input port | X | | | | | | | AN0 to 7 input (note4) | X | No | ne | | | | P83 | ADTRG input (note5) | X | | | | | Port B | PB0 to PB6 | Input port | X | 0 | 0 | | | | | Output port | X | 1 | 0 | | | | PB0 | TA0IN input | X | 0 | None | | | | PB1 | TA1OUT output | X | 1 | 1 | | | | PB2 | TA3OUT output | X | 1 | 1 | | | | PB3 | INT0 input | X | 0 | 1 | | | | PB4 | INT1 input | X | 0 | 1 | | | | PB5 | INT2 input | X | 0 | 1 | | | | PB6 | INT3 input | X | 0 | 1 | | | Port C PC0 to PC5 | | Input port | X | 0 | 0 | | | | | Output port | X | 1 | 0 | | | | PC0 | TXD0 output (Note2) | 1 | 1 | 1 | | | | PC1 | RXD0 input (Note2) (Note6) | 1 | 0 | None | | | | PC2 | SCLK0 input (Note2) | 1 | 0 | 0 | N.T. | | | | SCLK0 output (Note2) | 1 | 1 | 1 | None | | | | CTS0 input (Note2) | 1 | 0 | 0 | | | | PC3 | TXD1 output (Note2) | 1 | 1 | 1 | | | | PC4 | RXD1 input (Note2) | 1 | 0 | None | | | | PC5 | SCLK1 input (Note2) | 1 | 0 | 0 | | | | | SCLK1 output (Note2) | 1 | 1 | 1 | | | | | CTS1 input (Note2) | 1 | 0 | 0 | | | Port D | PD5 to PD7 | Output port | X | | 0 | | | | PD5 | SCOUT output | X | | 1 | | | | PD6 | /ALARM output | 1 | None | 1 | | | | | /MLDALM output | 0 | | 1 | | | | PD7 | MLDALM output | X | | 1 | | | Port Z | PZ2 to PZ3 | Input port (Without PU) | 0 | 0 | 0 | | | | | Input port (with PU) | 1 | 0 | 0 | | | | | Output port | X | 1 | 0 | ] | | | PZ2 | HWR output | X | 1 | 1 | | | | PZ3 | R/W output | X | 1 | 1 | | (note1): PORT1 is only use for PORT or DATA bus(D8 to D15) by setting AM1 and AM0 pins. (note2): As for input ports of SIO1 and SIO2: (OPTRX0,OPTTX0,TXD0,TRX0,SCCLK0,/CTS0, TXD1,TRX1,SCCLK1,/CTS1), logical selection for output data or input data is determined by the output latch register Pn of each port. (note3): In case using P71 and P72 for SDA and SCL as open-drain ports, set to P7ODE<ODEP71:ODEP72>. (note4): In case using P80 to P87 for analog input ports of A/D converter, set to ADMOD1<ADCH2:ADCH1:ADCH0>. (note5): In case using P83 for ADTRG input port, set to ADMOD1<ADTRGE>. (note6): In case using PC1 for RXD0 port, set "1" to P7FC2<P70FC>. After Reset, the port pins listed below function as general-purpose I/O port pins. Resetting sets I/O pins, which can be programmed for either input or output to be input ports pins. Setting the port pins for internal function use must be done in software. ## Note about bus release and programmable pull-up I/O port pins When the bus is released (i.e. when $\overline{BUSAK} = 0$ ), the output buffers for D0 to D15, A0 to A23, and the control signals $\overline{(RD, WR, HWR, R/W \text{ and } CS0 \text{ to } CS3, EA24, 25/CS2A \text{ to } 2E)}$ are off and are set to High-Impedance. However, the output of built-in programmable pull-up resistors are kept before the bus is released. These programmable pull-up resistors can be selected ON/OFF by programmable when they are used as the input ports. When they are used as output ports, they cannot be turned ON/OFF in software. Table 3.5.4 shows the pin states after the bus has been released. Table 3.5.4 Pin states (after bus release) | Dia | The pin state (w | when the bus is released) | |------------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------| | Pin name | Port mode | Function mode | | D0-D7 | | Become high-impedance(Hz). | | D8-D15(P10-P17) | The state is not changed. (do not become to high impedance (Hz).) | 1 | | A0-A15 | | First sets all bits to high, then sets them to High-impedance(Hz). | | A16-23(P20-P27) | The state is not changed. (do not become to high impedance (Hz).) | <b>†</b> | | /RD.<br>/WR | | 1 | | PZ2 (/HWR),<br>PZ3 (R/W), | The state is not changed. (do not become to high impedance (Hz).) | First sets all bits to high, then the output buffer is OFF. The programmable pull up resistor is ON irrespective of the output latch. | | P60 (/CS0),P61 (/CS1),<br>P62 (/CS2,/CS2A),<br>P63 (/CS3), | <b>A</b> | First sets all bits to high, then sets them to high-impedance(Hz). | TOSHIBA # 3.5.1 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. Resetting, the control register P1CR to "0" and sets Port 1 to input mode. In addition to functioning as a general-purpose I/O port, Port 1 can also function as an address data bus (D8 to 15). Figure 3.5.1 Port 1 # 3.5.2 Port 2 (P20 to P27) Port 2 is an 8-bit output port. In addition to functioning as a output port, Port 2 can also function as an address bus (A16 to A23). Each bit can be set individually for address bus using the function register P2FC. Resetting sets all bits of the function register P2FC to 1 and sets Port 2 to address bus. Figure 3.5.2 Port 2 Port 1 Register P1 (0001H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------------|-----|-----------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--|--|--| | bit Symbol | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | | | | | | Read/Write | | R/W | | | | | | | | | | | | After Reset | | Input mode (Output latch register is cleared to 0.) | | | | | | | | | | | Port 1 Control Register P1CR (0004H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|------|--------------|------|------|------|------|------|------|--|--| | bit Symbol | P17C | P16C | P15C | P14C | P13C | P12C | P11C | P10C | | | | Read/Write | | W | | | | | | | | | | After Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Function | | 0: IN 1: OUT | | | | | | | | | | | | | | | | | | | | | → Port 1 I/O setting 0: Input 1: Output # Port 2 Register P2 (0006H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|-------------------------------------|-----|-----|-----|-----|-----|-----|-----|--|--|--| | bit Symbol | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | | | | | Read/Write | RW | | | | | | | | | | | | After Reset | Output latch register is set to "1" | | | | | | | | | | | ## Port 2 Function Register P2FC (0009H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------------|-------------------------------------|-------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|--|--|--| | bit Symbol | P27F | P27F P26F P25F P24F P23F P22F P21F P20F | | | | | | | | | | | | Read/Write | | W | | | | | | | | | | | | After Reset | 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | Function | 0: Port 1: Address bus (A23 to A16) | | | | | | | | | | | | (note): Read-modify-write is prohibited for P1CR and P2FC. Figure 3.5.3 Registers for Ports 1 and 2 # 3.5.3 Port 5 (P54 to P56) Port 5 is an 5-bit general-purpose I/O port. I/O is set using control register P5CR and P5FC. Resetting resets all bits of the output latch P5 to "1", the control register P5CR and the function register P5FC to "0" and sets P54 to P56 to input mode with pull-up register. In addition to functioning as a general-purpose I/O port, Port 5 also functions as I/O for the CPU's control / status signal. Figure 3.5.4 Port 5 (P55) Figure 3.5.5 Port 5 (P56,P54) P5 (000DH) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |----|-------------|---------------------------|-----|-----|-----|---|---|---|---|--|--|--| | | bit Symbol | | P56 | P55 | P54 | | | | | | | | | 1) | Read/Write | | RW | | | | | | | | | | | | After reset | Input mode (With Pull-up) | | | | | | | | | | | | | | | 1 | 1 | 1 | | | | | | | | Port 5 Control Register P5CR (000AH) Port 5 function register P5FC (000BH) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-----|-------------|---|---|---------------------|--------------------|---|---|---|---|--|--|--| | С | bit Symbol | | | P55F | P54F | | | | | | | | | BH) | Read/Write | W | | | | | | | | | | | | | After reset | | | 0 | 0 | | | | | | | | | | Function | | | 0: PORT<br>1: BUSAK | 0: PORT<br>1:BUSRQ | | | | | | | | (note1): Read-modify-write is prohibited for register P5CR,P5FC. (note2): When port5 is used in the input mode, P5 register controls the built-in pull-up resistor. Read-modify-write is prohibited in the input mode or the I/O mode. Setting the built-in pull-up resistor may be depended on the States of the input pin. (note3): When P56 pin is used as a /WAIT pin ,set P5CR<P56C> to "0" and Chip Select/WAIT control register <BnW2:0> to "010" Figure 3.5.6 Registers for Port 5 ## 3.5.4 Port6 (P60 to P67) Port60 to 67 are 8bit output ports. Resetting sets output latch of P62 to "0" and output latchs of P60 to P61,P63 to P67 to "1". Port6 also function as chip-select output (/CS0 to /CS3), extend address output(EA24). Writing "1" in the corresponding bit of P6FC, P6FC2 enables the respective functions. Resetting resets the P6FC, P6FC2 to "0", and sets all bits to output ports. Figure 3.5.7 Port 6 #### Port 6 Register 7 6 5 4 3 2 1 0 P6 P67 P66 P64 P63 P62 P61 P60 bit Symbol P65 (0012H)Read/Write R/W 0 1 After reset 1 1 1 1 1 1 Port 6 Function Register 6 5 4 3 2 1 0 P6FC P65F P64F P63F P62F P61F P60F bit Symbol (0015H) Read/Write W After reset 0 Always write "0" 0:PORT 0: PORT 0: PORT 0: PORT 0: PORT 0: PORT **Function** 1:EA25 1: EA24 1: /CS3 1: /CS2 1: /CS1 1: /CS0 Port 6 Function Register 2 6 5 4 3 2 1 0 P6FC2 P67F2 P66F2 P65F2 P64F2 P62F2 bit Symbol (001BH) Read/Write W W After reset 0: <P66F> 0: <P65F> 0: <P64F> 0: <P62F> 0: <P67F> Always Always write "0" **Function** 1: /CS2E 1: /CS2D 1: /CS2C 1: /CS2B write "0" 1: /CS2A (note): Read-modify-write is prohibited for P6FC and P6FC2 . Figure 3.5.8 Register for Port 6 ## 3.5.5 Port7 (P70 to P77) Port 7 is an 8-bit general-purpose I/O port. I/O can be set on bit basis using the control register. Resetting sets Port 7 to input port and all bits of output latch to"1". In addition to functioning as a general-purpose I/O port, Port 7 also functions as follows. - 1. Input/output function for serial bus interface(SCK,SO/SDA.SI/SCL) - 2. Input/output function for IrDA (OPTRX0,OPTTX0) Writing "1" in the corresponding bit of P7FC, P7FC2 enables the respective functions. Resetting resets the P7FC, P7FC2 to "0", and sets all bits to input ports. #### (1) Port70 (SCK, OPTRX0) Port70 is a general-purpose I/O port. It is also used as SCK(clock signal for SIO mode)and OPTRX0 (receive input for IrDA mode of SIO0). Used as OPTRX0, it is possible to logical-invert by P7<P70>="0". For PortC1, RXD0 or OPTRX0 is used P7FC2<P70F2>. Figure 3.5.9 Port 70 ## (2) Port71 (SO/SDA/OPTTX0) Port71 is a general-purpose I/O port. It is also used as SDA (data input for I<sup>2</sup>C mode), SO (data output for SIO mode) for serial bus interface and OPTTX0 (transmit output for IrDA mode of SIO0). Used as OPTTX0, it is possible to logical-invert by P7<P71>="0". Figure 3.5.10 Port 71 # (3) Port 72 (SI/SCL,/HRESET) Port72 is a general-purpose I/O port. It is also used as SI (data input for SIO mode), SCL (clock input/output for $I^2C$ mode) for serial bus interface and input for release hard-protect. Figure 3.5.11 Port 72 (note): Read-modify-write is prohibited for P7CR,P7FC, P7FC2 and P7ODE. Figure 3.5.12 Register for Port 7 # 3.5.6 Port 8 (P80 to P87) Port 8 is an 8-bit input port and can also be used as the analog input pins for the internal A/D converter. P83 can also be used as ADTRG pin for the A/D converter. Figure 3.5.13 Port 8 Port 8 Register P8 (0018H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------------|-----|------------|-----|-----|-----|-----|-----|-----|--|--|--|--| | Bit Symbol | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | | | | | Read/Write | | R | | | | | | | | | | | | After reset | | Input mode | | | | | | | | | | | (note): The input channel selection of A/D Converter and the permission of ADTRG input are set by A/D Converter mode register ADMOD1. Figure 3.5.14 Register for Port 8 # Port B (PB0 to PB6) Port B0 to PB6 is a 7-bit general-purpose I/O port. Each bit can be set individually for input or output. Resetting sets Port B to be an input port. In addition to functioning as a general-purpose I/O port, Port B0 has clock input terminal TA0IN of 8 bits timer 0, and port B1, B2 each has facility of 8 bits timer listing TA1OUT, TA3OUT terminal. And, port B3 to B6 has each external interruption input facility of INT0 to INT3. Edge selection of external interruption is establishes by IIMC register in the interrupt controller. Timer output function and external interrupt function can be enabled by writing "1" to the corresponding bits in the Port B Function Register (PBFC). Resetting resets all bits of the registers PBCR and PBFC to "0", and sets all bits to be input ports. Figure 3.5.15 Port B0 to B2 ## (2) PB3 (INT0), PB4 (INT1)-PB6 (INT3) Figure 3.5.16 Port B3 Figure 3.5.17 Port B4 to B6 (note1): Read-Modify-Write is prohibited for the registers PBCR and PBFC. (note2): PB0/TA0IN pin does not have a register changing PORT/FUNCTION. For example, when it is used as an input port, the input signal is inputted to 8 bit timer. Figure 3.5.18 Register for Port B ## 3.5.7 Port C (PC0 to PC5) Port C0 to C5 are 6-bit general-purpose I/O ports. Each bit can be set individually for input or output. Resetting sets PC0 to PC5 to be an input ports. It also sets all bits of the output latch register to "1". In addition to functioning as general-purpose I/O port pins, PC0 to PC5 can also function as the I/O for serial channels 0 and 1. A pin can be enabled for I/O by writing "1" to the corresponding bit of the Port C Function Register (PCFC). Resetting resets all bits of the registers PCCR and PCFC to 0 and sets all pins to be input ports . ### (1) Port C0, C3 (TXD0/TXD1) As well as functioning as I/O port pins, port C0 and C3 can also function as serial channel TXD output pins. In case of use TXD0/TXD1, it is possible to logical invert by setting the register PC<PC0,PC3>. And port C0 to C3 have a programmable open drain function which can be controlled by the register PCODE<ODEPC0, ODEPC3>. Figure 3.5.19 Port C0 and C3 ## (2) Port C1, C4 (RXD0, 1) Port C1 and C4 are I/O port pins and can also is used as RXD input for the serial channels. In case of use RXD0/RXD1, it is possible to logical invert by setting the register PC<PC1,PC4>. And input data of SIO0 can be select from RXD/PC1 pin or OPTRX0/P70 by setting the register PCFC2<P70F2>. Figure 3.5.20 Port C1 and C4 ## (3) Port C2(/CTS0,SCLK0),C5(/CST1,SCLK1) Port C2 and C4 are I/O port pins and can also is used as /CTS input or SCLK input/output for the serial channels. In case of use /CTS,SCLK, it is possible to logical invert by setting the register PC<PC2,PC5>. Figure 3.5.21 Port C2 and C5 | | Port C Register | | | | | | | | | | |-------------------------|-----------------|---|---|----------|-------------|---------|----------|------|---------|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PC | bit Symbol | | | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | | | (0023H) | Read/Write | | | | | R/ | W | | | | | | After Reset | | | | | Input | mode | | | | | | | | | 1 | 1 | 1 | 1 | 1 | 1 | | | Port C Control Register | | | | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PCCR | bit Symbol | | | PC5C | PC4C | PC3C | PC2C | PC1C | PC0C | | | (0026H) | Read/Write | | | | W | | | | | | | | After Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | 0 | : IN | 1: OU | Т | | | | | | | | Port C | Functon Reg | jister | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PCFC | bit Symbol | | | PC5F | | PC3F | PC2F | | PC0F | | | (0027H) | Read/Write | | | W | | W | W | | W | | | | After Reset | | | 0 | | 0 | 0 | | 0 | | | | | | | 0: PORT | | 0: PORT | 0: PORT | | 0: PORT | | | | Function | | | 1: SCLK1 | | 1: TXD1 | 1: SCLK0 | | 1: TXD0 | | | | | | | Output | | | Out put | | | | | , | | | | Port C | ODE Regis | ster | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PCODE | bit Symbol | | | | | ODEPC3 | | | ODEPC0 | | | (0028H) | Read/Write | | | | | W | | | W | | | | After Reset | | | | | 0 | | | 0 | | | | | | | | | TXD1 | | | TXD0 | | | | Function | | | | | 0: CMOS | | | 0: CMOS | | | | 1 UNICTION | | | | | 1: Open | | | 1: Open | | | | | | | | | Drain | | | Drain | | (note 1): Read-Modify-Write is prohibited for the registers PCCR, PCFC and PCODE. (note2): PC1/RXD0, PC4/RXD1 pins do not have a register changing PORT/FUNCTION. For example, when it is used as an input port, the input signal is inputted to SIO as the cereal receive data. Figure 3.5.22 Register for Port C # 3.5.8 Port D (PD0 to PD7) Port D is an 8-bit output port. Resetting sets the output latch PD to "1", and PD5 to PD7 pin output "1". In addition to functioning as output port, Port D also function as output pin for output pin for internal clock (SCOUT), output pin for RTC alarm (/ALARM) and output pin for melody/alarm generator (MLDALM,/MLDALM). Above setting is used the function register PDFC. Only PD6 has two output functions which /ALARM and /MLDALM. This selection is used PD<PD6>. Resetting resets the function register PDFC to "0", and sets all ports to output ports. Figure 3.5.23 Port D Figure 3.5.24 Port D TOSHIBA Figure 3.5.25 Port D (note): Read-Modify-Write is prohibited for the registers PDFC. Figure 3.5.26 Register for Port D # 3.5.9 Port Z(PZ2 to PZ3) Port Z is the 2-bit general-purpose I/O port. I/O is set using control register PZCR and PZFC. Resetting resets all bits of the output latch PZ to "1". In addition to functioning as a general-purpose I/O port, Port Z also functions as I/O for the CPU's control / status signal. Resetting initializes PZ2 and PZ3 pins to input mode with pull-up register. When the PZ<RDE> register clearing to "0",outputs the $\overline{RD}$ strobe (used for the peused static RAM) of the $\overline{RD}$ pin even when the internal addressed. If the $\langle RDE \rangle$ remains "1", the $\overline{RD}$ strobe signal is output only when the external address are is accessed. Figure 3.5.27 Port Z (PZ2,PZ3) Note 1: Read-Modify-write is prohibited for registers PZCR and PZFC. Note 2: When Port Z is used in Input Mode, the PZ register controls the built-in pull-up resistor. Read-Modify-Write is prohibited in Input Mode or I/O Mode. Setting the built-in pull-up resistor may be depended on the states of the input pin. Figure 3.5.28 Port Register for Port Z # 3.6 Chip Select/Wait Controller On the TM91C824, 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 /CS0 to /CS3 (which can also function as port pins P60 to P63) are the respective output pins for the areas CS0 to CS3. When the CPU specifies an address in one of these areas, the corresponding /CS0 to /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 P6FC must be set. /CS2A to /CS2E (CS pin except /CS0 to /CS3) are made by MMU. These pins is /CS pin that area and BANK value is fixed without concern in setting of CS/WAIT controller. 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 ( $\overline{\text{WAIT}}$ ). ## 3.6.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 /CS0 to /CS3 pin outputs the chip select signal and the bus cycle operates in accordance with the settings in chip select/wait control register B0CS to B3CS. (See 3.6.2, Chip Select/Wait Control Registers.) TMP91C824 ## (1) Memory Start Address Registers Figure 3.6.1 shows the 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 eight bits (A23 to A16) of the start address in <S23: S16>. 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 3.6.2 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 /MSAR1 | bit Symbol | S23 | S22 | S21 | S20 | S19 | S18 | S17 | S16 | | | | (00C8H)/(00CAH) | Read/Write | | | | | | | | | | | | MSAR2 /MSAR3 | After reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | (00CCH)/ (00CEH) | Function | Determines A23 to A16 of start address. | | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | → Sets s | tart address | es for areas | CS0 to CS3. | | | Figure 3.6.1 Memory Start Address Register Figure 3.6.2 Relationship between Start Address and Start Address Register value ### (2) Memory Address Mask Registers Figure 3.6.3 shows the 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) 6 5 3 2 0 MAMR0 bit Symbol V20 V19 V18 V17 V16 V15 V14 to 9 V8 (00C9H) Read/Write R/W After Reset Sets size of CS0 area Function 0: used for address compare Range of possible settings for CS0 area size: 256 bytes to 2 Mbytes ### Memory address mask register (CS1) 3 2 0 6 5 4 1 MAMR1 V21 V20 V19 V18 V17 V16 V15 to 9 V8 bit Symbol (00CBH) Read/Write R/W After Reset Function Sets size of CS1 area 0: Used for address compare Range of possible settings for CS1 area size: 256 bytes to 4M bytes. ## Memory address mask register (CS2, CS3) 7 6 5 4 3 2 1 0 MAMR2 / MAMR3 V19 V17 V16 V15 V22 V21 V20 V18 bit Symbol (00CDH)/ (00CFH) Read/Write R/W After reset 1 1 Function Sets size of CS2 or CS3 area 0: used for address compare Range of possible settings for CS2 and CS3 area sizes: 32 Kbytes to 8 Mbytes. Figure 3.6.3 Memory Address mask Registers ### (3) Setting Memory Start Addresses and Address Areas Figure 3.6.4 show an example of specifying a 64K-byte address area starting from 010000H using the CS0 areas. Set "01H" in memory start address register MSAR0<S23 to S16>(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 to V8>sets the area size This example sets "07H" in MAMR0 to specify a 64K-byte area. Figure 3.6.4 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 disabling the CS0, CS1 and CS3 areas. However, as B2CS<B2M> to "0" and B2CS<B2E> to "1", CS2 is enabled from 000FE0H-000FFFH to 003000H-FFFFFFH in TMP91C824. Also, the bus width and number of waits specified in BEXCS are used for accessing addresses outside the specified CS0 to CS3 area. (See 3.6.2, Chip Select/Wait Control Registers.) ## (4) Address Area Size Specification Table 3.6.1 shows the relationship between CS area and area size. 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 $\,$ , set the start address mask register in the desired steps starting from 000000H. If the CS2 area is set to 16M-bytes or if two or more areas overlap, the smaller CS area number has the higher priority. Example: To set the area size for CS0 to 128 Kbytes: ## Valid start addresses ## ② Invalid start addresses Table 3.6.1 Valid area sizes for each CS area | Size (bytes) CS area | 256 | 512 | 32 K | 64 K | 128 K | 256 K | 512 K | 1 M | 2 M | 4 M | 8 M | |----------------------|-----|-----|------|------|-------|-------|-------|-----|-----|-----|-----| | CS0 | | | | | | | | | | | | | CS1 | | | | | | | | | | | | | CS2 | | | | | | | | | | | | | CS3 | | | | | | | | | | | | (note): Indicates areas that cannot be set by memory start address register and address mask register combinations. ## 3.6.2 Chip Select/Wait Control Registers Figure 3.6.5 lists the 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. Figure 3.6.5 Chip Select/Wait Control Registers #### (1) Master Enable bits Bit 7 (<80E>, <81E>, <82E> or <83E>) 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")<80E>, <81E> and <83E>, and enabled (sets to "1") <82E>. This enables area CS2 only. #### (2) Data bus width selection Bit 3 (<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 3.6.2. **CPU** Data Operand Data **Operand Start** Memory Data CPU Address Bus Width Address Bus Width D15 to D8 D7 to D0 8 bits 2n + 08 bits 2n+0b7 ~ b0 xxxxx (Even number) 2n + 0b7 ~ b0 16 bits XXXXX 2n + 18 bits 2n + 1 $b7 \sim b0$ XXXXX (Odd number) 16 bits 2n + 1 $b7 \sim b0$ XXXXX 16 bits 2n + 08 bits 2n + 0 $b7 \sim b0$ XXXXX (Even number) 2n + 1b15 ~ b8 XXXXX b15 ~ b8 $b7 \sim b0$ 16 bits 2n + 02n + 18 bits b7 ~ b0 2n + 1xxxxx (Odd number) 2n + 2b15 ~ b8 16 bits 2n + 1 $b7 \sim b0$ XXXXX 2n + 2XXXXX $b15 \sim b8$ 32 bits 2n + 08 bits 2n + 0b7 ~ b0 XXXXX (Even number) $2n\,+\,1$ b15 ~ b8 xxxxx 2n + 2b23 ~ b16 XXXXX 2n + 3b31 ~ b24 XXXXX 16 bits 2n + 0b15 ~ b8 b7 - b02n + 2b31 ~ b24 b23 - b162n + 18 bits $b7 \sim b0$ 2n + 1XXXXX (Odd number) 2n + 2b15 ~ b8 xxxxx b23 ~ b16 2n + 3xxxxx b31 ~ b24 2n + 4XXXXX 16 bits 2n + 1 $b7 \sim b0$ XXXXX b15 ~ b8 2n + 2 $b23 \sim b16$ b31 ~ b24 2n + 4xxxxx Table 3.6.2 Dynamic bus sizing (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. ### (3) Wait control Bits 0 to 2 (<B0W0 to B0W2>, <B1W0 to B1W2>, <B2W0 to B2W2>, <B3W0 to B3W2>, <BEXW0 to BEXW2>) 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. | <u> </u> | | | | | | | | |----------------------------|--------------|-------------------------------------------------------------------------------|--|--|--|--|--| | <bxw2 bxw0="" ~=""></bxw2> | No. of Waits | Wait Operation | | | | | | | 000 | 2WAIT | Inserts a wait of 2 states, irrespective of the WAIT pin state. | | | | | | | 001 | 1WAIT | Inserts a wait of 1 state, irrespective of the WAIT pin state. | | | | | | | 010 | 1WAIT + N | 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 | 0WAIT | Ends the bus cycle without a wait, regardless of the WAIT pin state. | | | | | | | 100 | Reserved | Invalid setting | | | | | | | 101 | 3WAIT | Inserts a wait of 3 state, irrespective of the WAIT pin state. | | | | | | | 110 | 4WAIT | Inserts a wait of 4 state, irrespective of the WAIT pin state. | | | | | | | 111 | 8WAIT | Inserts a wait of 8 state, irrespective of the WAIT pin state. | | | | | | Table 3.6.3 Wait operation settings A Reset sets these bits to "000" (2 waits). #### (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) Selecting 16-Mbyte area/specified address area Setting B2CS<B2M> (bit 6 of the chip select/wait control register for CS2) to "0" designates the 16-Mbyte area 000FE0H-000FFFH, 003000H-FFFFFFH 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 (i.e. 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-M bytes address area. (6) Procedure for setting chip select/wait control When using the chip select/wait control function, set the registers in the following order: - Set the Memory Start Address Registers MSAR0 to MSAR3. Set the start addresses for CS0 to CS3. - ② 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 /CS0 to /CS3. The CS0 to S3 pins can also function as pins P60 to P63. To output a Chip Select signal using one of these pins, set the corresponding bit in the Port 6 Function Register P6FC to "1". If a CS0 "to S3 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. ## Setting example: In this example CS0 is set to be the 64-Kbyte area 010000H to 01FFFFH. The bus width is set to 16 bits and the number of waits is set to 0. MSAR0 = 01H...... Start address: 010000H MAMR0 = 07H..... Address area: 64 Kbytes BOCS = 83H..... ROM/SRAM, 16-bit data bus, zero waits, CS0 area settings enabled TOSHIBA # 3.6.3 Connecting external memory Figure 3.6.6 shows an example of how to connect external memory to the TMP91C824. 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 3.6.6 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 6 Control Register P6CR and the Port 6 Function Register P6FC to "0" and disables output of the CS signal. To output the CS signal, the appropriate bit must be set to "1". # 3.7 8-bit Timers (TMRA) The TMP91C824 features 4 channel(TMRA0 to TMRA3) built-in 8-bit timers. These timers are paired into 2 modules: TMRA01 and TMRA23. 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 3.7.1 to Figure 3.7.2 Show block diagrams for TMRA01 and TMRA23. 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-flop condition are controlled by 5bytes registers. We call control registers SFRs: Special Function Registers. Each of the two modules (TMRA01 and TMRA23) can be operated independently. All modules operate in the same manner; hence only the operation of TMRA01 is explained here. The contents of this chapter are as follows. - 3.7.1 Block diagrams - 3.7.2 Operation of each circuit - 3.7.3 SFRs - 3.7.4 Operation in each mode - (1) 8-Bit Timer Mode - (2) 16-Bit Timer Mode - (3) 8-Bit PPG (programmable pulse generation) Output Mode - (4) 8-Bit PWM (pulse width modulation) Output Mode - (5) Mode settings Table 3.7.1 Registers and pins for each module | | Module | TMRA01 | TMRA23 | | |-----------|----------------------------------|----------------------------------|----------------------------------|--| | External | Input pin for external clock | TA0IN (shared with PB0) | None | | | pin | Output pin for timer flip-flop | TA1OUT (shared with PB1) | TA3OUT (shared with PB2) | | | | Timer run register | TA01RUN (0100H) | TA23RUN (0108H) | | | SFR | Timer register | TA0REG (0102H)<br>TA1REG (0103H) | TA2REG (010AH)<br>TA3REG (010BH) | | | (address) | Timer mode register | TA01MOD (0104H) | TA23MOD (010CH) | | | | Timer flip-flop control register | TA1FFCR (0105H) | TA3FFCR (010DH) | | Figure 3.7.2 TMRA23 block diagram # 3.7.2 Operation of each circuit ## (1) Prescalers A 9-bit prescaler generates the input clock to TMRA01. The "T0" as the input clock to prescaler is a clock divided by 4 which selected using the Prescaler Clock Selection Register SYSCR0<PRCK1,PRCK0>. The prescaler's operation can be controlled using TA01RUN<TA0PRUN> in the timer control register. Setting <TA0PRUN> to "1" starts the count; setting <TA0PRUN> to "0" clears the prescaler to zero and stops operation. Table 3.7 (2) shows the various prescaler output clock resolutions. Table 3.7.2 Prescaler output clock resolution @fc = 16 MHz, fs = 32.768 kHz | System Clock | Prescaler Clock | Gear Value | Prescaler Output Clock Resolution | | | | | | |---------------------------|---------------------------------------|-----------------------------|-----------------------------------|----------------------------|-----------------------------|------------------------------|--|--| | Selection <sysck></sysck> | Selection <prck1,prck0></prck1,prck0> | <gear2~gear0></gear2~gear0> | фТ1 | фТ4 | фТ16 | фТ256 | | | | 1 (fs) | | XXX | fs/2 <sup>3</sup> (244 μs) | fs/2 <sup>5</sup> (977 μs) | $fs/2^7 (3.9 \mu s)$ | fs/2 <sup>11</sup> (62.5 μs) | | | | | | 000 (fc) | $fc/2^3 (0.5 \mu s)$ | fc/2 <sup>5</sup> (2.0 μs) | fc/2 <sup>7</sup> (8.0 μs) | fc/2 <sup>11</sup> (128 μs) | | | | | 00<br>(f <sub>FPH</sub> ) | 001 (fc/2) | fc/2 <sup>4</sup> (1.0 μs) | $fc/2^6$ (4.0 µs) | fc/2 <sup>8</sup> (16 μs) | fc/2 <sup>12</sup> (256 µs) | | | | | | 010 (fc/4) | fc/2 <sup>5</sup> (2.0 μs) | $fc/2^7 (8.0 \mu s)$ | fc/2 <sup>9</sup> (32 μs) | fc/2 <sup>13</sup> (512 μs) | | | | 0 (fc) | | 011 (fc/8) | fc/2 <sup>6</sup> (4.0 μs) | fc/2 <sup>8</sup> (16 μs) | fc/2 <sup>10</sup> (64 μs) | fc/2 <sup>14</sup> (1024 μs) | | | | | | 100 (fc/16) | fc/2 <sup>7</sup> (8.0 μs) | fc/2 <sup>9</sup> (32 μs) | fc/2 <sup>11</sup> (128 μs) | fc/2 <sup>15</sup> (2048 μs) | | | | | 10<br>(fc/16 CLOCK) | XXX | fc/2 <sup>7</sup> (8.0 μs) | fc/2 <sup>9</sup> (32 μs) | fc/2 <sup>11</sup> (128 μs) | fc/2 <sup>15</sup> (2048 µs) | | | xxx: Don't care # (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 T1, T4 or T16. The clock setting is specified by the value set in TA01MOD<TA01CLK1.TA01CLK0>. 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 T1, T16 or 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. ### (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^n$ - 1 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 3.7.3 show the configuration of TA0REG. Figure 3.7.3 Configuration of TA0REG (note): The same memory address is allocated to the timer register and the register buffer. When <TA0RDE> = 0, the same value is written to the register buffer and the timer register; when <TA0RDE> = 1, only the register buffer is written to. The address of each timer register is as follows. TA0REG: 000102H TA1REG: 000103H TA2REG: 00010AH TA3REG: 00010BH All these registers are write only and cannot be read. ### (4) Comparator (CP0) 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 zero 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. ## (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<TAFF1IE> in the Timer Flip-Flop Control Register. A Reset clears the value of TA1FF1 to "0". Writing "01" or "10" to TA1FFCR<TAFF1C[1: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 PB1). When this pin is used as the timer output, the timer flip-flop should be set beforehand using the Port B Function Register PBCR,PBFC. ## 3.7.3 SFRs # TMRA01 Run Register I2TA01 : Operation in IDLE2 Mode TA01PRUN : Run prescaler TA1RUN : Run Timer 1 TA0RUN : Run Timer 0 (note): The values of bits 4,5,6 of TA01RUN are undefined when read. TMRA23 Run Register | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |------------------------------|-------------|------------|---------------|---|---|------------|------------------------|-----------------|----------------|--|--| | TA23RUN | Bit symbol | TA2RDE | | | | I2TA23 | TA23PRUN | TA3RUN | TA2RUN | | | | (0108H) | Read/Write | R/W | | | | | R/ | W | | | | | | After Reset | 0 | | | | 0 | 0 | 0 | 0 | | | | | | Double | | | | IDLE2 | Timer Run/Stop control | | | | | | | Function | buffer | 0: Stop 0: St | | | | 0: Stop & C | 0: Stop & Clear | | | | | | Function | 0: Disable | | | | 1: Operate | 1: Run (count up) | | | | | | | | 1: Enable | | | | | | | | | | | TA2REG double buffer control | | | | | | | | | n/Stop control | | | | | | 0 Disa | ble | | | | | 0 5 | Stop & Clear | | | | | | 1 Enal | ole | | | | | 1 F | Run (count up) | | | I2TA23 : Operation in IDLE2 Mode TA23PRUN : Run prescaler TA3RUN : Run Timer 3 TA2RUN : Run Timer 2 (note): The values of bits 4,5,6 of TA23RUN are undefined when read. Figure 3.7.4 TMRA Registers Figure 3.7.5 TMRA registers Figure 3.7.6 TMRA registers Figure 3.7.7 TMRA registers Figure 3.7.8 TMRA registers # 3.7.4 Operation in each mode (1) 8-Bit Timer Mode Both TMRA0 and TMRA1 can be used independently as 8-bit interval timers. Setting its function or counter data for TMRA0 and TMRA1 after stop these registers. ① 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 20 $\mu$ seconds at fc = 16 MHz, set each register as follows: ``` * Clock state System clock: High frequency (fc) Prescaler clock: fFPH ``` ``` MSB LSB 6 5 4 3 2 1 TA01RUN X \quad X 0 Stop TMRA1 and clear it to 0. TA01MOD 0 X X 1 0 X X Select 8-Bit Timer Mode and select \phi T1 (0.5 \mu s at fc = 16 MHz) as the input clock. TA1REG 0 0 1 0 0 0 Set TA1REG to 20 \mus ÷ \phiT1 = 40 = 28H 0 1 INTETA01 0 X 1 Enable INTTA1 and set it to Level 5. - 1 TA01RUN X \quad X \quad X \quad - \quad 1 \quad 1 \quad - \quad Start TMRA1 counting. ``` (note): X = Don't care; "-" = No change Select the input clock using in Table 3.7.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\$ ② 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 3.0- $\mu$ s square wave pulse from the TA1OUT pin at fc = 16 MHz, use the following procedure to make the appropriate register settings. This example uses TMRA1; however, either TMRA0 or TMRA1 may be used. ``` * Clock state System clock: High frequency (fc) Clock gear: 1 (fc) Prescaler clock: fFPH 5 TA01RUN X X X Stop TMRA1 and clear it to 0. TA01MOD X Select 8-Bit Timer Mode and select \, T1 (0.5 \mu s at fc = 16 \, MHz) as the input clock. TA1REG 0 0 0 Set the timer register to 3.0 \mus ÷ \phiT1 ÷ 2 = 3 Clear TA1FF to "0" and set it to invert on the match detects TA1FFCR X signal from TMRA1. P7CR Set PB1 to function as the TA1OUT pin. P7FC _TA01RUN X X X Start TMRA1 counting. ``` (note): X = Don't care; "-" = No change Figure 3.7.9 Square wave output timing chart (50% Duty) TOSHIBA 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 3.7.10 TMRA1 count up on signal from TMRA0 #### (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,TA01M0> 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<TA01CLK1,TA01CLK0>. Table 3.7.2 shows the relationship between the timer (interrupt) cycle and the input clock selection. 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. Setting example: To generate an INTTA1 interrupt every 0.5 seconds at fc = 16 MHz, set the timer registers TA0REG and TA1REG as follows: \* Clock state System clock: High frequency (fc) Clock gear: 1 (fc) Prescaler clock: f<sub>FPH</sub> If $\phi$ T16 (8.0 $\mu$ s at 16 MHz) is used as the input clock for counting, set the following value in the registers: 0.5 sec / 8.0 $\mu$ sec = 62500 = F424H; i.e. set TA1REG to F4H and TA0REG to 24H. The comparator match signal is output from TMRA0 each time the up-counter UC0 matches TA0REG, though the up-counter UC0 is not be 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 3.7.11 Timer output by 16-Bit Timer Mode ## (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 (concurrent with P71). Figure 3.7.12 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 3.7.13 shows a block diagram representing this mode. Figure 3.7.13 Block diagram of 8-Bit PPG Output Mode 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 3.7.14 Operation of register buffer Example: To generate 1/4-duty 50-kHz pulses (at fc = 16 MHz): Prescaler clock: fFPH 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 \text{ } \mu \text{ sec}$ $\phi T1 = 0.5 \, \mu sec (at 16 \, MHz);$ $20 \mu sec / 0.5 \mu sec = 40$ Therefore set TA1REG to 40 (28H) The duty is to be set to 1/4: $t \times 1/4 = 20 \mu sec \times 1/4 = 5 \mu sec$ $5 \mu sec / 0.5 \mu sec = 10$ Therefore, set TA0REG = 10 = 0AH. (note): X = Don't care; "-" = No change ## (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 (which is also used as P71). 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$ - 1 counter overflow occurs (n = 6, 7 or 8 as specified by TA01MOD<PWM01 to PWM00>). The up-counter UC0 is cleared when $2^n$ - 1 counter overflow occurs. The following conditions must be satisfied before this PWM mode can be used. Value set in TA0REG < value set for $2^n$ - 1 counter overflow Value set in TA0REG 0 Figure 3.7.15 8-bit PWM waveforms Figure 3.7.16 shows a block diagram representing this mode. Figure 3.7.16 Block diagram of 8-Bit PWM Mode In this mode, the value of the register buffer will be shifted into TA0REG if $2^n - 1$ overflow is detected when the TA0REG double buffer is enabled. Use of the double buffer facilitates the handling of low duty ratio waves. Figure 3.7.17 Register buffer operation Example: To output the following PWM waves on the TA1OUT pin at fc = 16 MHz: To achieve a 63.5- $\mu$ s PWM cycle by setting $\phi$ T1 to 0.5 $\mu$ sec (at fc = 16 MHz): $$63.5 \, \mu sec / 0.5 \, \mu sec = 127 = 2^n - 1$$ Therefore n should be set to 7. Since the low-level period is 36.0 $\mu$ sec when $\phi T1 = 0.5 \mu$ sec, set the following value for TA0REG: $$36.0 \, \mu sec / 0.5 \, \mu sec = 72 = 48H$$ | | MS | В | | | | | | ] | LSB | | | |------------------|--------------|---|---|---|---|---|---|---|-----|------------------------------------------------------------------------|----| | _ | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TA01RUN | $\leftarrow$ | _ | X | X | X | _ | _ | _ | 0 | Stop TMRA0 and clear it to 0. | | | TA01MOD | $\leftarrow$ | 1 | 1 | 1 | 0 | _ | _ | 0 | 1 | Select 8-Bit PWM Mode (cycle: 2 <sup>7</sup> - 1) and select T1 as the | he | | | | | | | | | | | | input clock. | | | TA0REG | $\leftarrow$ | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | Write 48H. | | | TA1FFCR | $\leftarrow$ | X | X | X | X | 1 | 0 | 1 | X | Clear TA1FF to 0, enable the inversion and double buffer. | | | | | | | | | | | | | | | | P7CR | $\leftarrow$ | X | - | - | - | _ | _ | 1 | - | Cat DD1 and the TA1OLIT nin | | | P7FC | $\leftarrow$ | X | - | - | - | _ | _ | 1 | X | Set PB1 and the TA1OUT pin. | | | P7FC<br>_TA01RUN | $\leftarrow$ | 1 | X | X | X | _ | 1 | - | 1 | Start TMRA0 counting. | | | | | | | | | | | | | | | (note): X = Don't care; "-" = No change Table 3.7.3 PWM cycle @fc = 16 MHz, fs = 32.768 kHz | Select System | Select Prescaler | C V.1 | PWM cycle | | | | | | | | | | |-----------------|-----------------------------|-------------------------------------------|-----------|---------|---------|---------|-----------|-----------|----------|-----------|----------|--| | Clock | Clock | Gear Value<br><gear2~gear0></gear2~gear0> | $2^6 - 1$ | | | | $2^{7}-1$ | | | $2^8 - 1$ | | | | <sysck></sysck> | <prck1~prck0></prck1~prck0> | <gear2~gearu></gear2~gearu> | φT1 | фТ4 | φT16 | φT1 | фТ4 | φT16 | фТ1 | фТ4 | φT16 | | | 1 (fs) | | XXX | 15.4 ms | 61.5 ms | 246 ms | 31.0 ms | 124 ms | 496 ms | 62.3 ms | 249 ms | 996 ms | | | | | 000 (fc) | 31.5 µs | 126 µs | 504 μs | 63.5 μs | 254 m | 1016 μs | 127.5 μs | 510 μs | 2040 μs | | | | 00 | 001 ( <sup>fc</sup> /2) | 63.0 µs | 252 μs | 1008 μs | 127 μs | 508 μs | 2032 μs | 255 μs | 1020 μs | 4080 μs | | | | (f <sub>FPH</sub> ) | 010 (fc/4) | 126 µs | 504 μs | 2016 μs | 254 μs | 1016 μs | 4064 μs | 510 μs | 2040 μs | 8160 μs | | | 0 (fc) | | 011 ( <sup>fc</sup> /8) | 252 μs | 1008 μs | 4032 μs | 508 μs | 2032 μs | 8128 μs | 1020 μs | 4080 μs | 16.32 μs | | | | | 100 ( <sup>fc</sup> /16) | 504 μs | 2016 μs | 8064 μs | 1016 μs | 4064 μs | 16.256 µs | 2040 μs | 8160 μs | 32.64 μs | | | | 10<br>(fc/16 clock) | XXX | 504 μs | 2016 μs | 8064 μs | 1016 μs | 4064 μs | 16.256 ms | 2040 μs | 8160 µs | 32.64 µs | | XXX: Don't care ## (5) Settings for each mode Table 3.7.4 shows he SFR settings for each mode. Table 3.7.4 Timer mode setting registers | Register name | | TA011 | MOD | | TA1FFCR | |--------------------------|------------------------------------|------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------| | <bit symbol=""></bit> | <ta01m1:ta01m 0=""></ta01m1:ta01m> | <pwm01:00></pwm01:00> | <ta1clk1:0></ta1clk1:0> | <ta0clk1:0></ta0clk1:0> | TAFF1IS | | Function | Timer mode | PWM cycle | Upper timer input clock | Lower timer input clock | Timer F/F invert signal select | | 8-bit timer × 2 channels | 00 | - | Lower timer match<br>\$\phi T1, \phi T16, \phi T256\$<br>(00, 01, 10, 11) | External clock<br>\$\phi T1, \phi T4, \phi T16\$<br>(00, 01, 10, 11) | 0: Lower timer output 1: Upper timer output | | 16-bit timer mode | 01 | - | - | External clock<br>\$\phi T1, \phi T4, \phi T16\$<br>(00, 01, 10, 11) | - | | 8-bit PPG × 1 channel | 10 | - | - | External clock<br>\$\phi T1, \phi T4, \phi T16\$<br>(00, 01, 10, 11) | - | | 8-bit PWM × 1 channel | 11 | $2^6 - 1, 2^7 - 1, 2^8 - 1$ (01, 10, 11) | - | External clock<br>\$\phi T1, \phi T4, \phi T16\$<br>(00, 01, 10, 11) | - | | 8-bit timer × 1 channel | 11 | _ | φΤ1, φΤ16, φΤ256<br>(01, 10, 11) | - | Output disabled | (note): "-" = Don't care ## 3.8 External memory extension function (MMU) This is MMU function which can expand program / data area to 106M byte by having 4 local area. Address pins to external memory are 2 extended address bus pins (EA24,EA25) and 8 extended chip select pins (/CS2A to /CS2E) in addition to 24 address bus pins (A0 $\sim$ A23) which are common specification of TLCS-900 and 4 chip select pins (/CS0 $\sim$ /CS3) output from CS/WAIT controller. The feature and the recommendation setting method of two types are shown below. In addition, AH in the table is the value which number address 23-16 displayed as hex . | Purpose | Item | (A): For standard extended memory | (B): For many pieces extended memory | | | |--------------------|------------------------------|-----------------------------------|--------------------------------------|--|--| | | Maximum memory size | COMMON2 2MB+1 | 4MB (16MB × 1pcs) | | | | Program-ROM | Used local area RANK number | LOCAL2(AH=C0-D | DF 2MB ×7BANK) | | | | 1 Togram ROM | Setting CS/WAIT | Set up AH=C0-FF to CS2 | Set up AH=80-FF to CS2 | | | | | Used /CS nin | /C.S2. | /CS2A | | | | | Maximum memory size | 64MR(64MR x 1ncs) | 64MR(16MR x 4ncs) | | | | D . DOM | Used local area, BANK number | LOCAL3(AH=80-BF: 4MB × 16BANK) | LOCAL3(AH=80-BF:4MB × 24BANK) | | | | Data-ROM | Setting CS/WAIT | Set up AH=80-BF to CS3 | Set up AH=80-FF to CS2 | | | | | Used /CS pins | /CS3,EA24,EA25 | /CS2B,/CS2C,/CS2D,/CS2E | | | | | Maximum memory size | COMMON1 2MB+1 | 4MB(16MB x 1ncs) | | | | Option Program-ROM | Used local area, BANK number | LOCAL1(AH=40-51 | F: 2MB × 7BANK)) | | | | Option Flogram-KOW | Setting CS/WAIT | Set up AH=40-7F to CS1 | | | | | | Used /CS pin | /CS1 | | | | | | Maximum memory size | COMMON() 1MR+7MR(8MR x 1ncs) | | | | | Data-RAM | Used local area, BANK number | LOCAL0(AH=10-11 | F: 1MB × 7BANK)) | | | | Data-KAWI | Setting CS/WAIT | Set up AH=00-3F to CS0 | Set up AH=00-1F to CS3 | | | | | Used /CS pin | /CS0 | /CS3 | | | | | Maximum memory size | COMMON0 | 2MB(2MB x 1ncs) | | | | Extended memory -1 | Used local area, BANK number | Overlapped Data-RAM | None | | | | Extended memory -1 | Setting CS/WAIT | Set up AH=00-3F to CS0 | Set up AH=20-3F to CS0 | | | | | Used /CS pin | /CS0 | /CS0 | | | | Total Mo | emory Size | 16M+64M+16M+8M=104Mbyte | 16M+(16M+16M+16M+16M) | | | | | | | +16M+8M+2M=106Mbyte | | | ## 3.8.1 Recommendable memory map The recommendation logic address memory map at the time of varieties extension memory correspondence is shown in Figure 3.8.1.1. And, a physical-address map is shown in Figure 3.8.1.2. However, when memory area is less than 16M bytes and is not expanded, please refer to section of CS/WAIT controller. Setting of register in MMU is not necessary. Since it is being fixed, the address of a local-area cannot be changed. Figure 3.8.1.1 Logical address map Figure 3.8.1.2 Physical address map (Type B) TOSHIBA ## 3.8.2 Block diagram Figure 3.8.2.1 Block diagram of MMU ## 3.8.3 Control registers ### LOCAL0 register LOCAL0 (0350H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---------------------------------------------------|---|---|---|---|------------|-------------|-----------| | bit Symbol | L0E | | | | | L0EA22 | L0EA21 | L0EA20 | | Read/Write | R/W | | | | | | R/W | | | After reset | 0 | | | | | 0 | 0 | 0 | | Function | Use BANK<br>for<br>LOCAL0<br>0: not use<br>1: use | | | | | Setting BA | NK number f | or LOCAL0 | ### LOCAL1 register LOCAL1 (0351H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|---------------------------------------------------|---|---|---|---|------------|--------------|-----------|--|--| | bit Symbol | L1E | | | | | L1EA23 | L1EA22 | L1EA21 | | | | Read/Write | R/W | | | | | R/W | | | | | | After reset | 0 | | | | | 0 | 0 | 0 | | | | Function | Use BANK<br>for<br>LOCAL1<br>0: not use<br>1: use | | | | | Setting BA | NK number fo | or LOCAL1 | | | ## LOCAL2 register LOCAL2 (0352H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|------------------------------------------------------|---|---|---|---|------------|-------------|-----------| | bit Symbol | L2E | | | | | L2EA23 | L2EA22 | L2EA21 | | Read/Write | R/W | | | | | | R/W | | | After reset | 0 | | | | | 0 | 0 | 0 | | Function | Use BANK<br>for<br>LOCAL2<br>0: disable<br>1: enable | | | | | Setting BA | NK number f | or LOCAL2 | ## LOCAL3 register LOCAL3 (0353H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|------------|---|---|----------------------------------|-----------|-------------|-------------|--------|--| | bit Symbol | L3E | | | *L3EA26 | L3EA25 | L3EA24 | L3EA23 | L3EA22 | | | Read/Write | R/W | | | R/W | R/W | R/W | R/W | R/W | | | After reset | 0 | | | 0 | 0 | 0 | 0 | 0 | | | | Use BANK | | | 01000 to 01 | 011 /CS2D | 01100 to 01 | 111 : /CS2E | | | | | for | | | 00000 to 00011 /CS2B | | | | | | | Function | LOCAL3 | | | 00100 to 00111 /CS2C | | | | | | | | 0: disable | | | 10000 to 11111 : Set prohibition | | | | | | | | 1: enable | | | | | | | | | (Note) In case of this TMP91C824, because most upper address bit of physical address is EA25, most upper address bit of BANK register is meaningless. 4-bits of upper 5-bits address means 16-BANKs. ## 3.8.4 Operational description Set up bank value and bank use in bank setting-register of each local area of LOCAL register in common area. Moreover, in that case, a combination pin is set up and mapping is simultaneously set up by the CS/WAIT controller. When CPU outputs logical address of the local area, MMU outputs physical address to the outside address bus pin according to value of bank setting-register. Access of external memory becomes possible therefore. Please do not use as bank that overlaps with another bank since this common area overlaps with either of eight banks of local area on the physical map. Example program is as next page follows Figure 3.8.4.1 H/W Setting Example At Figure 3.8.4.1, it shows example of connection TMP91C824 and some memories: Program ROM:MROM,16Mbyte, Data ROM:MROM,64Mbyte, Data RAM:SRAM,8Mbyte, 8bit bus, Option ROM:Flash,16Mbyte. In case of 16bit bus memory connection, it need to shift 1bit address bus from TMP91C824 and 8bit bus case, direct connection address bus from TMP91C824. In that figure, Logical address and physical address are shown. And each memory allot each chip select signal, RAM:/CS0, FLASH\_ROM:/CS1, Program MROM:/CS2, Data MROM:/CS3. In case of this example, as Data MROM is 64Mbyte, this MROM connect to EA24 and EA25. Initial condition after reset, because TMP91C824 access from CS2 area, CS2 area allot to Program ROM. It can set free setting except Program ROM. | ;Initia<br>;CS0 | al Setting | | | |-----------------|------------|-------------|-----------------------------------------------| | ,030 | LD | (MSAR0),00H | ; Logical address area: 000000H ~ 1FFFFFH | | | | | 8 | | | LD | (MAMR0),FFH | ; Logical address size: 2Mbyte | | | LD | (B0CS),89H | ; Condition: 8bit,1wait (8MB, SRAM) | | ;CS1 | | | | | | LD | (MSAR1),40H | ; Logical address area: 400000H ~ 7FFFFFH | | | LD | (MAMR1),7FH | ; Logical address size: 4Mbyte | | | LD | (B1CS),80H | ; Condition: 16bit,2wait (16Mbyte, Flash ROM) | | ;CS2 | | | | | | LD | (MSAR2),C0H | ; Logical address area: C00000H ~ FFFFFFH | | | LD | (MAMR2),7FH | ; Logical address size: 4Mbyte | | | LD | (B2CS),C3H | ; Condition: 16bit,0wait (16Mbyte, MROM) | | ;CS3 | | | | | | LD | (MSAR3),80H | ; Logical address area: 800000H ~ BFFFFFH | | | LD | (MAMR3),FFH | ; Logical address size: 4Mbyte | | | LD | (B3CS),85H | ; Condition: 16bit,3wait (64Mbyte, MROM) | | ;CSX | | | | | | LD | (BEXCS),00H | ; Other: 16bit,2wait (don't care) | | ;Port | | | | | | LD | (P6FC),3FH | ; /CS0 ~ /CS3,EA24,EA25 :port6 setting | | ~ | | | | Figure 3.8.4.2 Bank Operation S/W Example1 Secondly, it shows example of initial setting at Figure 3.8.4.2. Because /CS0 connect to RAM: 8bit bus, 8Mbyte, it need to set 8bit bus. At this example, it set 1-wait setting. In the same way /CS1 set to 16bit bus and 2-wait, /CS2 set 16bit bus and 0-wait, /CS3 set 16bit bus and 3-wait. By CS/WAIT controller, each chip selection signal's memory size, don't set actual connect memory size, need to set that logical address size: fitting to each local area. Actual physical address is set by each area's BANK register setting. CSEX setting of CS/WAIT controller is except above CS0 $\sim$ CS3's setting. This program example isn't used CSEX setting. Finally pin condition is set. $PORT60 \sim 65$ set to /CS0,1,2,3,EA24,EA25. 91C824-115 Figure 3.8.4.3 Bank Operation S/W Example2 Here shows example of data access between one BANK and other BANK. Figure 3.8.4.3 is one software example. A dot line square area shows one memory and each dot line square shows /CS2's Program ROM and /CS3's Data ROM. Program start from E00000H address, firstly, write to BANK register of LOCAL3 area upper 5-bit address of access point. In case of this TMP91C824, because most upper address bit of physical address is EA25, most upper address bit of BANK register is meaningless. 4-bits of upper 5-bits address means 16-BANKs. After setting BANK5, accessing $800000 \sim BFFFFFH$ address: logical local3 address, actually access to physical $1400000 \sim 1700000H$ address. Figure 3.8.4.4 Bank Operation S/W Exapmle3 At Figure 3.8.4.4, it shows example of program jump. In the same way with before example, two dot line squares show each /CS2's program ROM and /CS1's option ROM. Program start from E00000H common address, firstly, write to BANK register of LOCAL2 area upper 3-bit address of jumping point. After setting BANK1, jumping $C00000 \sim DFFFFFH$ address: logical local2 address, actually jump to physical $2000000 \sim 3FFFFFH$ address. When return to common area, it can only jump to $E00000 \sim FFFFFFH$ without writing to BANK register of LOCAL2 area. By a way of setting of BANK register, the setting that BANK address and common address conflict with is possible. When two kinds or more logical addresses to show common area exist, management of BANK is confused. We recommends not to use The BANK setting, BANK address and common address conflict with. When it jump to one memory from other different memory, it can set same as the last time setting. It needs to write to BANK register of LOCAL1 area upper 3-bit address of jumping point. After setting BANK4, jumping $400000 \sim 5FFFFFH$ address: logical local1 address, actually jump to physical $8000000 \sim 9FFFFFH$ address. It is a mark paid attention to here, it needs to go by way of common area by all means when moves from a bank to a bank. In other words, it must write to BANK register only in common area and It is prohibit to write the BANK register in BANK area. If it modify the BANK register's data in BANK area, program run-away. ## 3.9 Serial Channels TMP91C824 includes 2 serial I/O channels. For both channels either UART Mode (asynchronous transmission) or I/O Interface Mode (synchronous transmission) can be selected. • I/O Interface Mode — Mode 0: For transmitting and receiving I/O data using the synchronizing signal SCLK for extending I/O. UART Mode UART Mode Mode 1: 7-bit data Mode 2: 8-bit data Mode 3: 9-bit data In Mode 1 and Mode 2 a parity bit can be added. Mode 3 has a wake-up function for making the master controller start slave controllers via a serial link (a multi-controller system). Figure 3.9 2, 3 are block diagrams for each channel. Serial Channels 0 and 1 can be used independently. Both channels operate in the same fashion except for the following points; hence only the operation of Channel 0 is explained below. Table 3.9.1 Differences between Channels 0 to 1 | | Channel 0 | Channel 1 | |-----------|-----------------------------------------------|----------------------------------------------| | Pin Name | TXD0 (PC0)<br>RXD0 (PC1)<br>CTS0 /SCLK0 (PC2) | TXD1 (PC3)<br>RXD1 (PC4)<br>CTS1/SCLK1 (PC5) | | IrDA Mode | Yes | No | This chapter contains the following sections: | 3.9.1 | Block diagram | |-------|---------------| | 202 | 0 | 3.9.2 Operation of each circuit 3.9.3 SFRs 3.9.4 Operation in each mode 3.9.5 Support for IrDA Mode Figure 3.9.1 Data formats TOSHIBA ## 3.9.1 Block diagrams Figure 3.9.2 is a block diagram representing Serial Channel 0. Figure 3.9.2 Block diagram of the Serial Channel 0 (SIO0) Figure 3.9.3 Block diagram of the Serial Channel 1(SIO1) ## 3.9.2 Operation of each circuit ## (1) Prescaler There is a 6-bit prescaler for generating a clock to SIO0. The clock selected using SYSCR<PRCK1:PRCK0> is divided by 4 and input to the prescaler as T0. The prescaler can be run by selecting the baud rate generator as the serial transfer clock. Table 3.9.2 shows prescaler clock resolution into the baud rate generator. Table 3.9.2 Prescaler Clock Resolution to Baud Rate Generator | Select System | Select Prescaler | Gear Value | Prescal | Prescaler Output Clock Resolution | | | | | |--------------------------|----------------------------------------------|---------------------------------------|-------------------------|-----------------------------------|--------------------|---------------------------|--|--| | Clock<br><sysck></sysck> | Clock<br><prck1 to<br="">PRCK0&gt;</prck1> | <gear2 to<br="">GEAR0&gt;</gear2> | фТ0 | фТ2 | фТ8 | фТ32 | | | | 1 (fs) | Х | XXX | fs/22 | fs <sub>/24</sub> | fs <sub>/26</sub> | $^{\mathrm{fs}}_{/28}$ | | | | | | 000 (fc) | $\frac{\text{fc}}{2^2}$ | fc <sub>/24</sub> | fc <sub>/26</sub> | $^{\mathrm{fc}}_{/2^{8}}$ | | | | | 00 | 001 ( <sup>fc</sup> / <sub>2</sub> ) | $fc_{/23}$ | fc <sub>/25</sub> | fc <sub>/27</sub> | fc <sub>/29</sub> | | | | | (f <sub>FPH</sub> ) | 010 ( <sup>fc</sup> / <sub>4</sub> ) | fc <sub>/24</sub> | fc<br>/26 | fc<br>/28 | fc/210 | | | | 0 (fc) | | 011 ( <sup>fc</sup> / <sub>8</sub> ) | $\frac{\text{fc}}{2^5}$ | fc <sub>/27</sub> | fc <sub>/29</sub> | fc <sub>/211</sub> | | | | | | 100 ( <sup>fc</sup> / <sub>16</sub> ) | fc <sub>/26</sub> | $\frac{\text{fc}}{28}$ | fc <sub>/210</sub> | fc <sub>/212</sub> | | | | | 10<br>( <sup>fc</sup> / <sub>16</sub> clock) | XXX | | fc/28 | fc <sub>/210</sub> | fc <sub>/212</sub> | | | (note): X = Don't care; "-" = Cannot be used The Baud Rate Generator selects between 4 clock inputs : $\phi T0$ , $\phi T2$ , $\phi T8$ , and $\phi T32$ among the prescaler outputs. ### (2) Baud rate generator The baud rate generator is the circuit which generates transmission and receiving clocks which determine the transfer 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 BR0CK<br/>8BR0CK1 to BR0CK0> field in the Baud Rate Generator Control Register. The baud rate generator includes a frequency divider, which divides the frequency by 1 or N+(16-k)/16 to 16 values, determining the transfer rate. The transfer rate is determined by the settings of BR0CR<BR0ADDE, BR0S3 to BR0S0> and BR0ADD<BR0K3 to BR0K0>. #### • In UART Mode ### (1) When BR0CR < BR0ADDE > = 0 The settings BR0ADD<BR0K3 to BR0K0> are ignored. The baud rate generator divides the selected prescaler clock by N, which is set in BR0CK<BR0S3 to BR0S0>. (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 to BR0S0> (N = 2, 3 ··· 15) and the value of K set in BR0ADD<BR0K3 to R0K0> (K = 1, 2, 3 ··· 15) Note: If N = 1 or N = 16, the N + (16 - K) / 16 division function is disabled. Set BR0CR<BR0ADDE> to 0. #### • 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 transfer rate when the baud rate generator is used is explained below. • Integer divider (N divider) For example, when the source clock frequency (fc) = 12.288 MHz, the input clock frequency = T2 (fc/16), the frequency divider N (BR0CR<BR0S3 to BR0S0>) = 5, and BR0CR<BR0ADDE> = 0, the baud rate in UART Mode is as follows: Baud Rate = $$\frac{\text{fc/16}}{5} \div 16$$ = $12.288 \times 10^6 \div 16 \div 5 \div 16 = 9600 \text{ (bps)}$ Note: The N + (16 - K) / 16 division function is disabled and setting BR0ADD<BR0K3 to BR0K0> is invalid. • N+(16-K)/16 divider (UART Mode only) Accordingly, when the source clock frequency (fc) = 4.8 MHz, the input clock frequency = 10 To, the frequency divider N (BR0CR<BR0S3 to BR0S0>) = 10 To, K (BR0ADD<BR0K3 to BR0K0>) = 10 To, and BR0CR <BR0ADDE> = 10 To, the baud rate in UART Mode is as follows: \* Clock state System clock: High frequency (fc) Clock gear: 1 (fc) Prescaler clock: System clock Baud Rate = $$\frac{fc/4}{7 + (16 - 3)/16} \div 16$$ Baud Rate = $$\frac{-3.5 - 2}{7 + (16 - 3)/16} \div 16$$ = $4.8 \times 10^6 \div 4 \div (7 + 13/16) \div 16 = 9600 \text{ (bps)}$ Table 3.9.3, Table 3.9.4 show examples of UART Mode transfer rates. Additionally, the external clock input is available in the serial clock. (Serial Channels 0, 1). 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)> = fc / 4 • In I/O Interface Mode Baud rate = external clock input frequency It is necessary to satisfy (external clock input cycle) >=16 / fc | | | | | | Unit (kbps) | |-----------|----------------------------------|---------|--------|-------|-------------| | fc [MHz] | Input Clock<br>Frequency Divider | фТ0 | фТ2 | фТ8 | фТ32 | | | 2 | 76.800 | 19.200 | 4.800 | 1.200 | | 0.020400 | 4 | 38.400 | 9.600 | 2.400 | 0.600 | | 9.830400 | 8 | 19.200 | 4.800 | 1.200 | 0.300 | | | 0 | 9.600 | 2.400 | 0.600 | 0.150 | | 12 200000 | 5 | 38.400 | 9.600 | 2.400 | 0.600 | | 12.288000 | A | 19.200 | 4.800 | 1.200 | 0.300 | | | 2 | 115.200 | | | | | 14.745600 | 3 | 76.800 | 19.200 | 4.800 | 1200 | | | 6 | 38.400 | 9.600 | 2.400 | 0.600 | | | | | | i e | † | Table 3.9.3 Transfer rate selection (when baud rate generator Is used and BR0CR <BR0ADDE> = 0) (note1): Transfer rates in I/O Interface Mode are eight times faster than the values given above. (note2): The values in this table are calculated for when fc is selected as the system clock, the clock gear is set for fc/1 and the system clock is the prescaler clock input $f_{\text{FPH}}$ . Table 3.9.4 UART baud rate selection (When TMRA0 with input Clock φT1 is used) Unit (kbps) | | | | | | оти (кърз) | |---------|--------|-------|--------|-------|------------| | fc | 12.288 | 12 | 9.8304 | 8 | 6.144 | | TA0REG0 | MHz | MHz | MHz | MHz | MHz | | 1H | 96 | | 76.8 | 62.5 | 48 | | 2H | 48 | | 38.4 | 31.25 | 24 | | 3Н | 32 | 31.25 | | | 16 | | 4H | 24 | | 19.2 | | 12 | | 5H | 19.2 | | | | 9.6 | | 8H | 12 | | 9.6 | | 6 | | AH | 9.6 | | | | 4.8 | | 10H | 6 | | 4.8 | | 3 | | 14H | 4.8 | | | | 2.4 | Method for calculating the transfer rate (when TMRA0 is used): Transfer rate = $\frac{\text{Clock frequency determined by SYSCR0<PRCK1, PRCK0>}}{\text{TA0REG} \times \underline{8} \times 16}$ $\frac{1}{2} \text{ (when TMRA0 (input clock T1) is used)}$ (note1): The TMRA0 match detect signal cannot be used as the transfer clock in I/O Interface Mode. (note2): The values in this table are calculated for when fc is selected as the system clock, the clock gear is set for fc/1 and the system clock is the prescaler clock input $f_{\text{FPH}}$ . ### (3) Serial clock generation circuit This circuit generates the basic clock for transmitting and receiving data. #### • In I/O Interface Mode In SCLK Output Mode with the setting SCOCR < IOC > = 0, the basic clock is generated by dividing the output of the baud rate generator by 2, as described previously. In SCLK Input Mode with 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. ## • In UART Mode The SC0MOD0 <SC1, SC0> setting determines whether the baud rate generator clock, the internal system clock fSYS, the match detect signal from timer TMRA0 or the external clock (SCLK0) is used to generate the basic clock SIOCLK. ### (4) Receiving counter The receiving counter is a 4-bit binary counter used in UART Mode which counts up the pulses of the SIOCLK 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. ### (5) Receiving control #### • In I/O Interface Mode In SCLK Output Mode with the setting SC0CR<IOC> = 0, the RXD0 signal is sampled on the rising edge of the shift clock which is output on the SCLK0 pin. 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. ### • In UART Mode The receiving control block has 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. ### (6) The 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 transferred 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. SC0CR<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 wake-up 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. #### (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 3.9.4 Generation of the transmission clock ### (8) Transmission controller ### • In I/O Interface Mode In SCLK Output Mode with the setting SC0CR<IOC> = 0, the data in the Transmission Buffer is output one bit at a time to the TXD0 pin on the rising edge of the shift clock which is output on the SCLK0 pin. In SCLK Input Mode with the setting SC0CR<IOC> = 1, the data in the Transmission Buffer is output one bit at a time on the TXD0 pin on the rising or falling edge of the SCLK0 input, according to the SC0CR<SCLKS> setting. #### • 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, generating a transmission shift clock TXDSFT. ### Handshake function Serial Channels 0, 1 each has a $\overline{\text{CTS pin}}$ . Use of this pin allows data can be sent in units of one frame; thus, Overrun errors can be avoided. The handshake functions is enabled or disabled by the SC0MOD <CTSE> setting. When the CTS0 pin foes High on completion of the current data send, data transmission is halted until the CTS0 pin foes 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 sending is halted. Though there is no RTS pin, a handshake function can be easily configured by setting any port assigned to be the RTS function. The RTS should be output "High" to request send data halt after data receive is completed by software in the RXD interrupt routine. Figure 3.9.5 Handshake function (note1): If the $\overline{\text{CTS}}$ signal goes High during transmission, no more data will be sent after completion of the current transmission. (note2): Transmission starts on the first falling edge of the TXDCLK clock after the CTS signal has fallen. Figure 3.9.6 CTS (Clear to send) Timing #### (9) Transmission Buffer The Transmission Buffer (SC0BUF) shifts out and sends the transmission data written from the CPU form the least significant bit (LSB) in order. When all the bits are shifted out, the Transmission Buffer becomes empty and generates an INTTX0 interrupt. ### (10) Parity control circuit When SC0CR<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 SC0CR<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 transferred 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. ### (11) Error flags Three error flags are provided to increase the reliability of data reception. #### 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 <OERR>=1 then - 4) Set to disable receiving (write '0' to SC0MOD0<RXE>) - 5) Wait to terminate current frame - 6) Read receiving buffer - 7) Read error flag - 8) Set to enable receiving (write '1' to SC0MOD0<RXE>) - 9) Request to transmitt again - 10) Other ### 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. ## 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. ## (12) Timing generation # ① In UART Mode ## Receiving | Mode | 9-Bit<br>(Note) | 8-Bit + Parity (Note) | 8-Bit, 7-Bit + Parity, 7-Bit | |----------------------|----------------------------|---------------------------------|---------------------------------| | Interrupt timing | Center of last bit (bit 8) | Center of last bit (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 (parity bit) | Center of last bit (parity bit) | | Overrun error timing | Center of last bit (bit 8) | Center of last bit (parity bit) | Center of stop bit | # Transmitting | Mode | 9-Bit | 8-Bit + Parity | 8-Bit, 7-Bit + Parity, 7-Bit | | |------------------|-------------------------|-------------------------|-------------------------------------|--| | Interrupt timing | Just before stop bit is | Just before stop bit is | Just before stop bit is transmitted | | | transmitted | | transmitted | | | ## ② I/O interface | Transmission<br>Interrupt | SCLK Output Mode | Immediately after rise of last SCLK signal. (See figure 3.9 19.) | |---------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------| | timing | SCLK Input Mode | Immediately after rise of last SCLK signal Rising Mode, or immediately after fall in Falling Mode. (See figure 3.9 20.) | | Receiving<br>Interrupt | SCLK Output Mode | Timing used to transfer received to data Receive Buffer 2 (SC0BUF) (i.e. immediately after last SCLK). (See figure 3.9 21.) | | timing | SCLK Input Mode | Timing used to transfer received data to Receive Buffer 2 (SC0BUF) (i.e. immediately after last SCLK). (See figure 3.9 22.) | TOSHIBA ## 3.9.3 SFR Figure 3.9.7 Serial Mode Control Register (SIO0, SC0MOD0) Figure 3.9.8 Serial Mode Control Register (SIO1, SC1MOD0) (note): As all error flags are cleared after reading do not test only a single bit with a bit-testing instruction. Figure 3.9.9 Serial Control Register (SIO0, SC0CR) (note): As all error flags are cleared after reading do not test only a single bit with a bit-testing instruction. Figure 3.9.10 Serial Control Register (SIO1, SC1CR) (note1): The baud rate generator can be set "1" when UART mode and disable + (16 - K)/16 division function. Don't use in I/O interface mode. (note2): Set BR0CR <BR0ADDE> to "1" after setting K (K=1 to 15) to BR0ADD<BR0K3 to 0> when + (16 - K)/16 division function is used. However, don't use + (16 - K)/16 division function when BR0CR<BR0S3 to 0>="0000" or "0001" (N=16 or 1). (note3): +(16-K)/16 division function is possible to use in only UART mode. Set BR0CR <BR0ADDE> to "0" and disable +(16-K)/16 division function in I/O interface mode. Figure 3.9.11 Baud rate generator control (SIO0, BR0CR, BR0ADD) (note1): The baud rate generator can be set "1" when UART mode and disable + (16 - K)/16 division function. Don't use in I/O interface mode. (note2): Set BR1CR <BR1ADDE> to "1" after setting K (K=1 to 15) to BR1ADD<BR1K3 to 0> when + (16 - K)/16 division function is used. However, don't use + (16 - K)/16 division function when BR1CR<BR1S3 to 0>="0000" or "0001" (N=16 or 1). (note3): +(16-K)/16 division function is possible to use in only UART mode. Set BR1CR <BR1ADDE> to "0" and disable +(16-K)/16 division function in I/O interface mode. (note): Prohibit read modify write for SC0BUF. Figure 3.9.13 Serial Transmission/Receiving Buffer Registers (SIO0, SC0BUF) SC0MOD1 (0205H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----------------------------|------------------------------|---|---|---|---|---|---| | Bit symbol | I2S0 | FDPX0 | | | | | | | | 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 | | | | | | | Figure 3.9.14 Serial Mode Control Register 1 (SIO0, SC0MOD1) (note): Prohibit read modify write for SC1BUF. Figure 3.9.15 Serial Transmission/Receiving Buffer Registers (SIO1, SC1BUF) | SC1MOD1 | |---------| | (020DH) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----------------------------|------------------------------|---|---|---|---|---|---| | bit Symbol | I2S0 | FDPX0 | | | | | | | | 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 | | | | | | | Figure 3.9.16 Serial Mode Control Register 1 (SIO1, SC1MOD1) TOSHIBA ## 3.9.4 Operation in each mode ## (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 3.9.17 SCLK Output Mode connection example Figure 3.9.18 SCLK Input Mode Connection example #### ① 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 3.9.19 Transmitting Operation in I/O Interface Mode (SCLK0 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, INTES0 <ITX0C> will be set to generate INTTX0 interrupt. Figure 3.9.20 Transmitting Operation in I/O Interface Mode (SCLK0 Input Mode) ## ② 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 INTES0<IRX0C> is cleared by reading the received data. When 8-bit data are received, the data will be transferred to Receiving Buffer 2 (SC0BUF according to the timing shown below) and INTES0<IRX0C> will be set to generate INTRX0 interrupt. The outputting for the first SCLK0 starts by setting SC0MOD0<RXE>to 1. Figure 3.9.21 Receiving operation in I/O Interface Mode (SCLK0 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 INTES0 <IRX0C> 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 3.9.22 Receiving Operation in I/O interface Mode (SCLK0 Input Mode) (note): The system must be put in the Receive Enable state (SCMOD0<RXE> = 1) before data can be received. #### 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 transfer interrupt. In the transfer interrupt program, The receiving operation should be done like the above example before setting the next transfer data. ``` Example: Channel 0, SCLK output Baud rate = 9600 \text{ bps} fc = 14.7456 \text{ MHz} ``` System clock : High frequency (fc) Clock gear : 1 (fc) Prescaler clock: f<sub>FPH</sub> | | . • | |---------|---------| | Main | routine | | IVIGIII | TOULTIE | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Set the INTTX0 level to 1. | |--------------------------|---|---|---|---|---|---|---|---|----------------------------------------------------------| | | , | - | - | - | - | _ | _ | - | | | INTES0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Set the INTRX0 level to 0. | | PCCR | _ | - | - | - | - | 1 | 0 | 1 | Set PC0, PC1 and PC2 to function as the TXD0, RXD0 and | | | | | | | | | | | SCLK0 pins respectively. | | PCFC | - | - | - | - | - | 1 | - | 1 | | | SC0MOD | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Select I/O Interface Mode. | | 0 | | | | | | | | | | | SC0MOD | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Select Full Duplex Mode. | | 1 | | | | | | | | | | | SC0CR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Sclk_out, transmit on negative edge, receive on positive | | | | | | | | | | | edge | | BR0CR | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | Baud rate = $9600$ bps | | SC0MOD | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | Enable receiving | | 0 | | | | | | | | | | | SC0BUF | * | * | * | * | * | * | * | * | Set the transmit data and start. | | INTTX0 interrupt routine | | | | | | | | | | Acc SC0BUF Read the receiving buffer. SC0BUF Set the next transmit data. (note): X = Don't care; "-" = No change TMP91C824 #### (2) Mode 1 (7-bit UART Mode) 7-Bit UART Mode is selected by setting Serial Channel Mode Register SC0MOD0<SM1, SM0> 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). Setting example: When transmitting data of the following format, the control registers should be set as described below. This explanation applies to Channel 0. ### (3) Mode 2 (8-Bit UART Mode) 8-Bit UART Mode is selected by setting SC0MOD0<SM1, SM0> 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). Setting example: When receiving data of the following format, the control registers should be set as described below. Transmission direction (transmission rate: 9600 bps at fc = 12.288 MHz) ``` * Clock state System clock: High frequency (fc) Clock gear: 1 (fc) Prescaler clock: System clock ``` #### Main settings ``` 7 \ \ 6 \ \ 5 \ \ 4 \ \ 3 \ \ 2 \ \ 1 \ \ 0 PCCR - - - - 0 - Set PC1 to function as the RXD0 pin. - 0 1 X 1 0 0 1 Enable receiving in 8-Bit UART Mode. SC0CR \leftarrow \ X \ 0 \ 1 \ X \ X \ X \ 0 \ 0 Add even parity. BR0CR \leftarrow \ 0 \ \ 0 \ \ 0 \ \ 1 \ \ 0 \ \ 1 \ \ 0 \ \ 1 Set the transfer rate to 9600 bps. INTES0 \leftarrow -\ -\ -\ -\ 1\ 1\ 0\ 0 Enable the INTTX0 interrupt and set it to Interrupt Level 4. Interrupt processing \leftarrow \mathsf{SC}\mathsf{0CR}\,\mathsf{AND}\,\mathsf{00011100} Acc Check for errors. if Acc ≠ 0 then ERROR \leftarrow SC0BUF Read the received data. Acc ``` (note): X = Don't care; "-" = No change ### (4) Mode 3 (9-Bit UART Mode) 9-Bit UART Mode is selected by setting SC0MOD0<SM1, SM0> 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. ### Wake-up function In 9-Bit UART Mode, the wake-up 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 3.9.23 Serial Link using Wake-up function ## Protocol - ① Select 9-Bit UART Mode on the master and slave controllers. - ② Set the SC0MOD0<WU> bit on each slave controller to 1 to enable data receiving. - ③ The master controller transmits one-frame data including the 8-bit select code for the slave controllers. The MSB (bit 8)<TB8> is set to 1. - Each slave controller receives the above frame. Each controller checks the above select code against its own select code. The controller whose code matches clears its WU bit to 0. - ⑤ The master controller transmits data to the specified slave controller whose SC0MOD<WU> bit is cleared to 0. The MSB (bit 8) <TB8> is cleared to 0. - © The other slave controllers (whose <WU> bits remain at 1) ignore the received data because their MSBs (bit 8 or <RB8>) are set to 0, disabling INTRX0 interrupts. - 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. Setting example: To link two slave controllers serially with the master controller using the internal clock $f_{SYS}$ as the transfer clock. Since Serial Channels 0 and 1 operate in exactly the same way, Channel 0 only is used for the purposes of this explanation. ### • Setting the master controller | Main | | | |---------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P9CR P9FC INTES0 SC0MOD0 SC0BUF | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\label{eq:set_PC0} \begin{cases} \text{Set PC0 and PC1 to function as the TXD0 and RXD0 pins respectively.} \\ \text{Enable the INTTX0 interrupt and set it to Interrupt Level 4.} \\ \text{Enable the INTRX0 interrupt and set it to Interrupt Level 5.} \\ \text{Set } f_{SYS} \text{ as the transmission clock for 9-Bit UART Mode.} \\ \text{Set the select code for slave controller 1.} \end{cases}$ | | INTTX0 into | errupt | | | SC0MOD0<br>SC0BUF | ← 0 + * * * * * | Set TB8 to 0. Set data for transmission. | ## • Setting the slave controller ``` \begin{array}{lll} \text{Main} \\ & \begin{array}{lll} \text{P9CR} & \leftarrow - - - - - - & 0 & 1 \\ \text{P9FC} & \leftarrow - - - - & - & - & X & 1 \\ \text{PCODE} & \leftarrow X & X & X & X & - & X & X & 1 \\ \end{array} \end{array} \right\} \\ \text{Set PC1 to RXD and PC0 to TXD0(open-drain output).} \\ \text{NTES0} & \leftarrow 1 & 1 & 0 & 1 & 1 & 1 & 1 & 0 \\ \text{SC0MOD0} & \leftarrow 0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 \\ \text{SC0MOD0} & \leftarrow 0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 \\ \end{array} \\ \text{SC0MOD0} & \leftarrow 0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 \\ \text{Set <WU> to 1 in 9-Bit UART Transmission Mode using $f_{SYS}$ as the transfer clock.} \\ \\ \text{INTRX0 interrupt} \\ \\ \text{Acc} & \leftarrow \text{SC0BUF} \\ \text{if } \text{Acc} & = \text{select code} \\ \\ \text{Then SC0MOD0} & \leftarrow - - & 0 & - & - & - & \text{Clear <WU> to 0}. \\ \end{array} ``` TOSHIBA # 3.9.5 Support for IrDA SIO0 includes support for the IrDA 1.0 infrared data communication specification. Figure 3.9.24 shows the block diagram. Figure 3.9.24 IrDA block diagram #### (1) Modulation of the transmission data When the transfer data is 0, the modem outputs 1 to TXD0 pin with either 3/16 or 1/16 times for width of baud-rate. The pulse width is selected by the SIRCR<PLSEL>. When the transfer data is 1, the modem outputs 0. Figure 3.9.25 Modulation example of transfer data ### (2) Modulation of the receive data When the receive data has the effective high level pulse width(software selectable), the modem outputs "0" to SIO0. Otherwise the modem outputs "1" to SIO0. The receive pulse logic is also selectable by SIRCR<RXSEL>. Figure 3.9.26 Demodulation example of receive data #### (3) Data format The data format is fixed as follows: • Data length: 8-bit • Parity bits: none • Stop bits: 1 Any other setting don't guarantee the normal operation. #### (4) SFR Figure 3.9.27 shows the control register SIRCR. Set the data SIRCR during SIO0 is inhibited (Both TXEN and RXEN of this register should be set to 0). Any changing for this register during transmission or receiving operation don't guarantee the normal operation. The following example describes how to set this register: 1) SIO setting ; Set the SIO to UART Mode. 2) LD (SIRCR), 07H ; Set the receive data pulse width to 16×. 3) LD (SIRCR), 37H ; TXEN, RXEN Enable the Transmission and receiving of SIO. $\downarrow$ 4) Start transmission ; The modem operates as follows: and receiving for SIO0 • SIO0 starts transmitting. • IR receiver starts receiving. ### (5) Notes 1) Baud rate generator for IrDA To generate baud-rate for IrDA, use baud-rate generator in SIO0 by setting "01" to SC0MOD0<SC1:0>. To use another source (TA0TRG,fsys and SCLK0-input) are not allowed. 2) As the IrDA 1.0 physical layer specification, the data transfer speed and infra-red pulse width is specified | odulation | Rate Tolerance<br>(% of rate) | Pulse Width (minimum) | Pulse Width (typical) | Pulse wid<br>(maximun | |-----------|-------------------------------|-----------------------|-----------------------|-----------------------| | RZI | ±0.87 | 1.41 µs | 78.13 μs | 88.55 με | | | | | | | | | Baud Rate | Modulation | Rate Tolerance<br>(% of rate) | Pulse Width (minimum) | Pulse Width (typical) | Pulse width (maximum) | |---|------------|------------|-------------------------------|-----------------------|-----------------------|-----------------------| | | 2.4 kbps | RZI | ±0.87 | 1.41 µs | 78.13 μs | 88.55 μs | | | 9.6 kbps | RZI | ±0.87 | 1.41 μs | 19.53 μs | 22.13 μs | | L | 19.2 kbps | RZI | ±0.87 | 1.41 µs | 9.77 μs | 11.07 μs | | L | 38.4 kbps | RZI | ±0.87 | 1.41 µs | 4.88 μs | 5.96 μs | | l | 57.6 kbps | RZI | ±0.87 | 1.41 μs | 3.26 µs | 4.34 μs | | L | 115.2 kbps | RZI | ±0.87 | 1.41 µs | 1.63 μs | 2.23 μs | Table 3.9.5 Baud rate and pulse width specifications The infra-red pulse width is specified either band rate T x 3/16 or $1.6 \,\mu$ sec (1.6 $\mu$ sec is equal to 3/16 pulse width when baud rate is 115.2 kbps). The TMP91C824F has the function selects the pulse width on the transmission either 3/16 or 1/16. But 1/16 pulse width can be selected when the baud rate is equal or less than 38.4 kbps only. When 57.6 kbps and 115.2 kbps, the output pulse width should not be set to T x 1/16. As the same reason, +(16-k)/16 division function in the baud rate generator of SIO0 can not be used to generate 115.2 kbps baud rate. Also when the 38.4 kbps and 1/16 pulse width, +(16-k)/16 division function can not be used. Table 3.9.6 shows Baud rate and pulse width for (16-k)/16 division function. Table 3.9.7 Baud rate and pulse width for $(16-k)\,/\,16$ division function | Pulse Width | | | Baud | Rate | | | |-------------|------------|-----------|-----------|-----------|----------|----------| | ruise widdi | 115.2 kbps | 57.6 kbps | 38.4 kbps | 19.2 kbps | 9.6 kbps | 2.4 kbps | | T × 3/16 | × | 0 | 0 | 0 | 0 | 0 | | T × 1/16 | _ | _ | × | 0 | 0 | 0 | O: Can be used (16-k)/16 division function ×: Can not be used (16-k)/16 division function -: Can not be set to 1/16 pulse width Figure 3.9.27 IrDA Control Register # 3.10 Serial Bus Interface (SBI) The TMP91C824F has a 1-channel serial bus interface which employs a clocked-synchronous 8-bit SIO mode and an $I^2C$ bus mode. The serial bus interface is connected to an external device through P71 (SDA) and P72 (SCL) in the I<sup>2</sup>C bus mode; and through P70 (SCK), P71 (SO), P72 (SI) in the clocked-synchronous 8-bit SIO mode. Each pin is specified as follows. | | P7ODE <ode72, ode71=""></ode72,> | P7CR <p72c, p70c="" p71c,=""></p72c,> | P7FC <p72f, p70f="" p71f,=""></p72f,> | |---------------------------|----------------------------------|---------------------------------------|---------------------------------------| | I <sup>2</sup> C Bus Mode | 11 | 11X | 11X | | Clocked Synchronous | VV | 011 | X11 | | 8-Bit SIO Mode | ΛΛ | 010 | ΛΠ | X: Don't care ### 3.10.1 Configuration Figure 3.10.1 Serial Bus Interface (SBI) TMP91C824 ### 3.10.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 1 (SBI0CR1) - Serial bus interface control register 2 (SBI0CR2) - Serial bus interface data buffer register (SBI0DBR) - I<sup>2</sup>C bus address register (I2C0AR) - Serial bus interface status register (SBIOSR) - Serial bus interface baud rate register 0 (SBI0BR0) - Serial bus interface baud rate register 1 (SBI0BR1) The above registers differ depending on a mode to be used. Refer to Section "3.10.4 I2C bus Mode Control" and "3.10.7 Clocked-synchronous 8-bit SIO Mode Control". # 3.10.3 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) Note: S: Start condition $R/\overline{W}$ : Direction bit ACK: Acknowledge bit P: Stop condition Figure 3.10.2 Data format in the I<sup>2</sup>C Bus Mode # 3.10.4 I<sup>2</sup>C Bus Mode Control 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. Note 1: Set the <BC2 to 0> to "000" before switching to a clock-synchronous 8-bit SIO mode. Note 2: For the frequency of the SCL line clock, see 3.10.5 (3) Serial clock. Figure 3.10.3 Registers for the I<sup>2</sup>C Bus Mode TOSHIBA Serial Bus Interface Control Register 2 Note1: Reading this register function as SBI0SR register. Note2: Switch a mode to port mode after confirming that the bus is free. Switch a mode between I<sup>2</sup>C bus mode and clock-synchronous 8-bit SIO mode after confirming that input signals via port are high-level. Figure 3.10.4 Registers for the I<sup>2</sup>C Bus Mode Note1: Writing in this register functions as SBI0CR2. Figure 3.10.5 Registers for the I<sup>2</sup>C Bus Mode | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------------|-------------|-----|--------------|---------------|-------------|--------------|--------------|-----|-------------------------------------------------| | I2C0AR | bit Symbol | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 | SA0 | ALS | | (0242H) | Read/Write | | | | V | V | | | | | Prohibit | After Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read-<br>modify-write | Function | Sla | ve address s | selection for | when device | is operating | as slave dev | 100 | Address<br>recognition<br>mode<br>specification | | · | | | | | | | | | <b>—</b> | Address recognition mode specification Slave address recognition Non slave address recognition Figure 3.10.6 Registers for the I<sup>2</sup>C Bus Mode # 3.10.5 Control in I<sup>2</sup>C Bus Mode ### (1) Acknowledge Mode Specification Set the SBI0CR1<ACK> to 1 for operation in the acknowledge mode. The TMP91C824F generates an additional clock pulse for an Acknowledge signal when operating in Master Mode, it counts a clock pulse for an acknowledge signal when operating in the slave 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 TMP91C824F does not generate a clock pulse for the Acknowledge signal when operating in the Master Mode, and it does not count a clock pulse as an Acknowledge signal when operating in Slave Mode. ### (2) Number of transfer bits The SBI0CR1<BC2 to BC0> is used to select a number of bits for next transmitting and receiving data. Since the <BC2 to BC0> is cleared to 000 as a start condition, a slave address and direction bit transmission are executed in 8 bits. Other than these, the <BC2 to 0> retains a specified value. #### (3) Serial clock Clock source The SBI0CR1 <SCK2 to SCK0> is used to select a maximum transfer frequency outputted on the SCL pin in Master Mode. Figure 3.10.7 Clock Source 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 TMP91C824F 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 3.10.8 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 wait 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. (4) Slave address and address recognition mode specification When the TMP91C824F is used as a slave device, set the slave address <SA6 to SA0> and <ALS> to the I2C0AR. Clear the <ALS> to "0" for the address recognition mode. (5) Master/Slave selection Set the SBI0CR2<MST> to "1" for operating the TMP91C824F 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. #### (6) Transmitter/Receiver selection Set the SBI0CR2<TRX> to "1" for operating the TMP91C824F 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 <TRX> is set to "1" by the hardware if the direction bit $(R/\overline{W})$ sent from the master device is "1", and is cleared to "0" by the hardware if the bit is "0". In the Master Mode, after an Acknowledge signal is returned from the slave device, the <TRX> is cleared to "0" by the hardware if a transmitted direction bit is "1", and is set to "1" by the hardware if it is "0". When an Acknowledge signal is not returned, the current condition is maintained. The <TRX> is cleared to "0" by the hardware after a stop condition on the I²C bus is detected or arbitration is lost. #### (7) Start/Stop condition generation When the SBIOSR<BB> is "0", 8-bit data which are set to SBIODBR are output on a bus after generating a start condition by writing "1" to the SBIOCR2 <MST,TRX,BB,PIN>. It is necessary to set transmitted data to the data buffer register (SBIODBR) and set "1" to <ACK> beforehand. Figure 3.10.9 Start condition generation and slave address generation When the <BB> is "1", a sequence of generating a stop condition is started by writing "1" to the <MST,TRX,PIN>, and "0" to the <BB>. Do not modify the contents of <MST,TRX,BB,PIN> until a stop condition is generated on a bus. Figure 3.10.10 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. And about generation of stop condition in master mode, there are some limitation point. Please refer to "3.10.6(4) Stop condition generation ". #### (8) Interrupt service requests and interrupt cancellation When a serial bus interface interrupt request (INTS2) 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 a 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 SBI0CR2<PIN> can be set to "1" by the program, the <PIN> is not clear it to "0" when it is written "0". #### (9) Serial bus interface operation mode selection SBIOCR2<SBIM1 to SBIM0> is used to specify the serial bus interface operation mode. Set SBIOCR2<SBIM1 to SBIM0> to "10" when the device is to be used in I<sup>2</sup>C Bus Mode. Switch a mode to port after confirming a bus is free. #### (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 wire-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 3.10.11 Arbitration Lost The TMP91C824F 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 SBIOSR<AL> is set to "1". When SBIOSR<AL> is set to "1", SBIOSR<MST,TRX> are cleared to "00" and the mode is switched to Slave Receiver Mode. SBIOSR<AL> is cleared to "0" when data is written to or read from SBIODBR or when data is written to SBIOCR2. Figure 3.10.12 Example of when TMP91CW12 is a Master Device B (D7A = D7B, D6A = D6B) ### (11) Slave address match detection monitor SBIOSR<AAS> is set to "1" in Slave Mode, in Address Recognition Mode (i.e. 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. #### (12) GENERAL CALL detection monitor SBI0SR<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). SBI0SR<AD0> is cleared to "0" when a start condition or stop condition is detected on the bus. ### (13) Last received bit monitor The SDA line value stored at the rising edge of the SCL line is set to the SBI0SR<LRB>. In the acknowledge mode, immediately after an INTS2 interrupt request is generated, an acknowledge signal is read by reading the contents of the SBI0SR<LRB>. #### (14) Software Reset function The software Reset function is used to initialize the SBI circuit, when SBI is rocked by external noises, etc. An internal Reset signal pulse can be generated by setting SBI0CR2<SWRST1,SWRST0> to "10" and "01". This initializes the SBI circuit internally. All command registers and status registers are initialized as well. SBI0CR2<SWRST1, SWRST0> is automatically cleared to "00" after the SBI circuit has been initialized. ### (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. ### (16) I<sup>2</sup>CBUS Address Register (I2C0AR) I2C0AR<SA6 to SA0> is used to set the slave address when the TMP91C824F 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. ### (17) Baud Rate Register (SBI0BR1) Write "1" to SBI0BR1<P4EN> before operation commences. #### (18) Setting register for IDLE2 mode operation (SBI0BR0) SBI0BR0<I2SBI0> is the register setting operation/stop during IDLE2-mode. Therefor, setting <I2SBI0> is necessary before the HALT instruction is executed. ### 3.10.6 Data Transfer in I<sup>2</sup>C Bus Mode ### (1) Device initialization Set the SBI0BR1<P4EN>, SBI0CR1<ACK,SCK2 to SCK0>, Set SBI0BR1 to "1" and clear bits 7 to 5 and 3 in the SBI0CR1 to "0". Set a slave address <SA6 to SA0> 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 <MST, TRX, BB> and set "1" to the <PIN>, "10" to the <SBIM1 to SBIM 0>. #### (2) Start condition and slave address generation 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 SBI0CR2<BB> = "0", the start condition are generated by writing "1111" to SBI0CR2<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 SBI0DBR. At the 9th clock, the SDA line is released and the acknowledge signal is received from the slave device. An INTS2 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. #### 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 INTS2 interrupt request occurs on the falling edge of the 9th clock. The <PIN> is cleared to "0". In Slave Mode the SCL line is pulled down to the Low-level while the <PIN> = "0". Figure 3.10.13 Start Condition Generation and Slave Address Transfer #### (3) 1-word Data Transfer Check the <MST> by the INTS2 interrupt process after the 1-word data transfer is completed, and determine whether the mode is a master or slave. ① If $\langle MST \rangle = "1"$ (Master Mode) Check the <TRX> and determine whether the mode is a transmitter or receiver. When the $\langle TRX \rangle = "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 3.10.6 (4)) and terminate data transfer. When the <LRB> is "0", the receiver is requests new data. When the next transmitted data is 8 bits, write the transmitted data to SBI0DBR. When the next transmitted data is other than 8 bits, set the <BC2 to BC0> <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 INTS2 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. Figure 3.10.14 Example in which <BC2 to BC0> = "000" and <ACK> = "1" in Transmitter Mode #### When the **<TRX>** is "0" (Receiver mode) When the next transmitted data is 8 bits, write the transmitted data to SBI0DBR. When the next transmitted data is other than 8 bits, set <BC2 to BC0> <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". The TMP91C824F outputs a serial clock pulse to the SCL to transfer new 1-word of data and sets the SDA pin to "0", When the acknowledge signal is set to Low-level at the final bit. An INTS2 interrupt request then occurs and the <PIN> becomes "0", Then the TMP91C824F pulls down the SCL pin to the Low-level. The TMP91C824F outputs a clock pulse for 1-word of data transfer and the acknowledge signal each time that received data is read from the SBI0DBR. Figure 3.10.15 Example of when <BC2 to 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 to BC0> to "001" and read the data. The TMP91C824F generates a clock pulse for a 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 TMP91C824F generates a stop condition (see Section 3.10.6 (4)) and terminates data transfer. Figure 3.10.16 Termination of data Transfer in Master Receiver Mode ### In the slave mode, an INTS2 interrupt request occurs when the TMP91C824F 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 TMP91C824F operates in a slave mode if it losing arbitration. An INTS2 interrupt request occurs when a word data transfer terminates after losing arbitration. When an INTS2 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_{LOW}$ time. In the slave mode the TMP91C824F operates either in normal slave mode or in slave mode after losing arbitration. Check the SBI0SR<AL>, <TRX>, <AAS>, and <AD0> and implements processes according to conditions listed in the next table. Table 3.10.1 Operation in the Slave Mode | <trx></trx> | <al></al> | <aas></aas> | <ad0></ad0> | Conditions | Process | |-------------|-----------|-------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | 1 | 1 | 0 | | Set the number of bits a word in <bc2 bc0="" to=""> and write the transmitted data to SBI0DBR</bc2> | | | 0 | 1 | 0 | In Salve Receiver Mode the TMP91C824F receives a slave address for which the value of the direction bit sent from the master is "1". | | | | | 0 | 0 | In Salve Transmitter Mode a single word of is transmitted. Set <bc2 bc0="" to=""> to the number of bits in a word.</bc2> | 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, cleat <trx> to "0" to release the bus. If <lrb> is cleared to "0" of and write the transmitted data to SBIODBR since the receiver requests next data.</lrb></trx></pin></lrb></lrb> | | 0 | 1 | 1 | 1/0 | | Read the SBIODBR for setting the <pin> to "1" (reading dummy data) or set the <pin> to "1".</pin></pin> | | | | 0 | 0 | The TMP91C824F loses arbitration when transmitting a slave address or data and terminates word data transfer. | | | | 0 | 1 | 1/0 | In Slave Receiver Mode the TMP91C824F 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 TMP91C824F terminates receiving word data. | Set <bc2 bc0="" to=""> to the number of bits in a word and read the received data from SBI0DBR.</bc2> | ### (4) Stop condition generation When SBIOSR<BB> = 1, the sequence for generating a stop condition can be initiated 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 TMP91CW12 generates a stop condition when the other device has released the SCL line. When SBI0CR2<MST,TRX,PIN> are written "1" and <BB> is written "0", <BB> changes to "0" by internal SCL changes to "1", without waiting stop condition. To check whether SCL and SDA-pin are "1" by sensing their ports is needed to detect bus free condition. Figure 3.10.17 Stop condition generation (Single-master) Figure 3.10.18 condition generation (Multi-master) #### (5) Restart Restart is used to change the direction of data transfer between a master device and a slave device during transferring data. The following explains how to restart when the TMP91C824F is in the master mode. Clear "0" to the SBI0CR2<MST,TRX,BB>, and set "1" to the <PIN> and release the bus. The SDA line remains the High-level and the SCL pin is released. Since a stop condition is not generated on a bus, a bus is assumed to be in a busy state from other devices. Check the SBI0SR<BB> is "0" and SCL terminal level is "1" to check that the TMP91C824F is released. 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 a bus stays in a free state, generate a start condition with procedure 3.10.6 (2). In order to meet setup time when restarting, take at least $4.7~\mu$ s of waiting time by software from the time of restarting to confirm that the bus is free until the time to generate the start condition. Figure 3.10.19 Timing diagram for TMP91C824F Restart ### 3.10.7 Clocked Synchronous 8-Bit SIO Mode control The following registers are used to control and monitor the operation status when the Serial Bus Interface (SBI) is being operated in Clocked Synchronous 8-Bit SIO Mode. Figure 3.10.20 Register for the SIO Mode Note: Set the SBI0CR1<BC2 to 0> "000" before switching to a clocked-synchronous 8-bit SIO mode. (reserved) Serial Bus Interface Status Register 7 6 5 4 3 2 0 bit Symbol SIOF SEF SBI0SR (0243H) Read/Write After reset 0 0 Serial transfer Shift operation Function operation status monitor status monitor Shift operation status monitor Shift operation terminated Shift operation in progress Serial transfer operating status monitor 0 Transfer terminated Transfer in progress Figure 3.10.21 Registers for the SIO Mode Figure 3.10.22 Registers for the SIO Mode - (1) Serial Clock - ① Clock source SBI0CR1<SCK2 to SCK0> is used to select the following functions: ### Internal Clock In Internal Clock Mode one of seven frequencies can be selected. The serial clock signal is output to the outside on the SCK pin. The SCK pin goes High when data transfer starts. When the device is writing (in Transmit Mode) or reading (in Receive Mode), data cannot follow the serial clock rate, so an automatic wait function is executed which automatically stops the serial clock and holds the next shift operation until reading or writing has been completed. Figure 3.10.23 Automatic-wait Function External clock (<SCK2 to SCK0> = "111") An external clock input via the SCK pin is used as the serial clock. In order to ensure the integrity of shift operations, both the high and Low-level serial clock pulse widths shown below must be maintained. The maximum data transfer frequency is 1 MHz (when fc = 16 MHz). Figure 3.10.24 Maximum data transfer frequency when external clock input used ## ② Shift edge Data is transmitted on the leading edge of the clock and received on the trailing edge. ### Leading edge shift Data is shifted on the leading edge of the serial clock (on the falling edge of the SCK pin input/output). # Trailing edge shift Data is shifted on the trailing edge of the serial clock (on the rising edge of the SCK pin input/output). Figure 3.10.25 Shift edge #### (2) Transfer modes The SBI0CR1<SIOM1 to SIOM0> is used to select a transmit, receive or transmit / receive mode. #### ① 8-Bit Transmit Mode Set a control register to a transmit mode and write transmit data to the SBIODBR. After the transmit data is written, set the SBI0CR1<SIOS> to "1" to start data transfer. The transmitted data is transferred from SBI0DBR to the Shift Register and output to the SO pin in synchronized with the serial clock, starting from the least significant bit (LSB), When the transmission data is transferred to the Shift Register, the SBI0DBR becomes empty. An INTS2 (buffer empty) interrupt request is generated to request new data. When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated if new data is not loaded to the data buffer register after the specified 8-bit data is transmitted. When new transmit data is written, automatic-wait function is canceled. When the external clock is used, data should be written to SBI0DBR before new data is shifted. The transfer speed is determined by the maximum delay time between the time when an interrupt request is generated and the time when data is written to SBI0DBR by the interrupt service program. When the transmit is started, after the SBIOSR<SIOF> goes "1" output from the SO pin holds final bit of the last data until falling edge of the SCK. Transmitting data is ended by clearing the <SIOS> to "0" by the buffer empty interrupt service program or setting the <SIOINH> to "1". When the <SIOS> is cleared, the transmitted mode ends when all data is output. In order to confirm if data is surely transmitted by the program, set the <SIOF> (bit 3 of SBIOSR) to be sensed. The SBIOSR<SIOF> is cleared to "0" when transmitting is complete. When the <SIOINH> is set to "1", transmitting data stops. SBIOSR<SIOF> turns "0". When an external clock is used, it is also necessary to clear SBIOSR<SIOS> to "0" before new data is shifted; otherwise, dummy data is transmitted and operation ends. Example: Program to stop data transmission (when an external clock is used) Clear<SIOS> <SIOS> <SIOF> <SEF> SCK pin (output) SO pin a<sub>7</sub> INTSBI interrupt request SBI0DBR (a) Internal clock Write transmitted data Clear <SIOS> <SIOS> <SIOF> <SEF> SIOF> SEF> SCK pin (input) SO pin INTSBI interrupt request SBIODBR A b (b) External clock Write transmitted data Figure 3.10.26 Transfer Mode STEST1: BIT SEF, (SBIOSR) ; If $\langle SEF \rangle = 1$ then loop JR NZ, STEST1 STEST2: BIT 0, (P6) ; If SCK ]= 0 then loop JR Z, STEST2 LD (SBI0CR1), 00000111B ; $\langle SIOS \rangle \leftarrow 0$ #### ② 8-Bit Receive Mode Figure 3.10.27 Transmitted data hold time at end of transmission Set the control register to receive mode and set SBI0CR1<SIOS> to "1" for switching to receive mode. Data is received into the Shift Register via the SI pin and synchronized with the serial clock, starting from the least significant bit (LSB). When 8-bit data is received, the data is transferred from the Shift Register to SBI0DBR. An INTS2 (buffer full) interrupt request is generated to request that the received data be read. The data is then read from SBI0DBR by the interrupt service program. When an internal clock is used, the serial clock will stop and the automatic wait function will be in effect until the received data has been read from SBI0DBR. When an external clock is used, since shift operation is synchronized with an external clock pulse, the received data should be read from SBI0DBR before the next serial clock pulse is input. If the received data is not read, any further data which is to be received is canceled. The maximum transfer speed when an external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when the received data is read. Receiving of data ends when <SIOS> is cleared to "0" by the buffer full interrupt service program or when <SIOINH> is set to "1". If <SIOS> is cleared to "0", received data is transferred to SBIODBR in complete blocks. The received mode ends when the transfer is complete. In order to confirm whether data is being received properly by the program, set SBIOSR<SIOF> to be sensed. <SIOF> is cleared to "0" when receiving has been completed. When it is confirmed that receiving has been completed, the last data is read. When <SIOINH> is set to "1", data receiving stops. <SIOF> is cleared to "0" (the received data becomes invalid, therefore no need to read it). Note: When the transfer mode is changed, the contents of SBI0DBR will be lost. If the mode must be changed, conclude data receiving by clearing <SIOS> to "0", read the last data, then change the mode. Figure 3.10.28 Receiver Mode (example: Internal clock) ### 3 8-Bit Transmit/Receive Mode Set a control register to a transmit/receive mode and write data to SBI0DBR. After the data has been written, set SBI0CR<SIOS> to "1" to start transmitting/receiving. When data is transmitted, the data is output via the SO pin, starting from the least significant bit (LSB) and synchronized with the leading edge of the serial clock signal. When data is received, the data is input via the SI pin on the trailing edge of the serial clock signal. 8-bit data is transferred from the Shift Register to SBI0DBR and an INTS2 interrupt request is generated. The interrupt service program reads the received data from the data buffer register and writes the data which is to be transmitted. SBI0DBR is used for both transmitting and receiving. Transmitted data should always be written after received data has been read. When an internal clock is used, the automatic wait function will be in effect until the received data has been read and the next data has been written. When an external clock is used, since the shift operation is synchronized with the external clock, received data is read and transmitted data is written before a new shift operation is executed. The maximum transfer speed when an external clock is used is determined by the delay time between the time when an interrupt request is generated and the time at which received data is read and transmitted data is written. When the transmit is started, after the SBIOSR<SIOF> goes "1" output from the SO pin holds final bit of the last data until falling edge of the SCK. Transmitting/receiving data ends when <SIOS> is cleared to "0" by the INTS2 interrupt service program or when SBI0CR1<SIOINH> is set to "1". When <SIOS> is cleared to "0", received data is transferred to SBI0DBR in complete blocks. The transmit/receive mode ends when the transfer is complete. In order to confirm whether data is being transmitted/received properly by the program, set SBI0SR to be sensed. <SIOF> is set to "0" when transmitting/receiving has been completed. When <SIOINH> is set to 1, data transmitting/receiving stops. <SIOF> is then cleared to 0. Note: When the transfer mode is changed, the contents of SBI0DBR will be lost. If the mode must be changed, conclude data transmitting/receiving by clearing <SIOS> to "0", read the last data, then change the transfer mode. Figure 3.10.29 Transmit/Received Mode (example using internal clock) Figure 3.10.30 Transmitted data hold time at end of transmit/receive # 3.11 Analog/Digital Converter The TMP91C824 incorporates a 10-bit successive approximation-type analog/digital converter (A/D converter) with 8-channel analog input. Figure 3.11.1 is a block diagram of the A/D converter. The 8-channel analog input pins (AN0 to AN7) are shared with the input-only port 8 and can thus be used as an input port. (note): When IDLE2, IDLE1 or STOP mode is selected, so as to reduce the power, with some timings the system may enter a stand-by mode even though the internal comparator is still enabled. Therefore be sure to check that A/D converter operations are halted before a HALT instruction is executed. Figure 3.11.1 Block diagram of A/D converter ### 3.11.1 Analog/Digital converter registers The A/D converter is controlled by the two A/D mode control registers: ADMOD0 and ADMOD1. The A/D conversion results are stored in 8 kinds of A/D conversion data Upper and Lower registers: ADREG04H/L, ADREG15H/L, ADREG26H/L and ADREG37H/L. Figure 3.11.2 shows the registers related to the A/D converter. Figure 3.11.2 A/D Converter Related Register (note): As pin AN3 also functions as the ADTRG input pin, do not set < ADCH2: 0> = "011" when using ADTRG with < ADTRGE> = "0". Figure 3.11.3 A/D Converter related registers #### A/D Conversion Data Low Register 0/4 6 3 0 5 4 ADR01 ADR00 ADR0RF Bit symbol ADREG04L (02A0H) Read/Write R R After Reset Undefined 0 A/D **Function** Stores lower 2-bits of Conversion A/D conversion result Data Storage flag 1: Conversion result store #### A/D Conversion Data Upper Register 0/4 3 0 6 5 4 2 1 ADR09 ADR08 ADR07 ADR06 ADR05 ADR04 ADR03 ADR02 ADREG04H Bit symbol (02A1H) Read/Write R After Reset Undefined Function Stores upper 8-bits A/D conversion result. #### A/D Conversion Data Lower Register 1/5 7 6 5 4 3 2 1 0 ADR1RF Bit symbol ADR11 ADR10 ADREG15L (02A2H) Read/Write R R After Reset Undefined 0 A/D **Function** stores lower 2-bits of Conversion A/D conversion result Result flag 1: Conversion result stored ### A/D Conversion Data Upper Register 1/5 6 0 ADR16 Bit symbol ADR19 ADR18 ADR17 ADR15 ADR14 ADR13 ADR12 ADREG15H (02A3H) Read/Write R After Reset Undefined Stores upper 8-bits of A/D conversion result. Function - Bits 5-1 are always read as "1". - Bit 0 is the A/D conversion data storage flag <ADRxRF>. When the A/D conversion result is stored, the flag is set to "1". When either of the registers (ADREGxH, ADREGxL) is read, the flag is cleared to "0". Figure 3.11.4 A/D Converter related registers ### A/D Conversion Result Lower Register 2/6 ADREG26L (02A4H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-----------------------------------------------|-------|---|---|---|---|---|--------------------------------------------------------------| | Bit symbol | ADR21 | ADR20 | | | | | | ADR2RF | | Read/Write | R<br>Undefined | | | | | | | R | | After Reset | | | | | | | | 0 | | Function | Stores lower 2-bits of A/D conversion result. | | | | | | | A/D conversion data storage flag 1: Conversion result stored | #### A/D Conversion Data upper Register 2/6 ADREG26H (02A5H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |---|-------------|-------|-----------------------------------------------|-------|-------|-------|-------|-------|-------|--|--|--| | Н | Bit symbol | ADR29 | ADR28 | ADR27 | ADR26 | ADR25 | ADR24 | ADR23 | ADR22 | | | | | | Read/Write | | R | | | | | | | | | | | | After Reset | | Undefined | | | | | | | | | | | | Function | | Stores upper 8-bits of A/D conversion result. | | | | | | | | | | A/D Conversion Data Lower Register 3/7 ADREG37L (02A6H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-------------|----------------------------------------------|-------|---|---|---|---|---|-------------------------------------------------------------| | ر ا | Bit symbol | ADR31 | ADR30 | | | | | | ADR3RF | | | Read/Write | F | ₹ | | | | | | R | | | After Reset | Undefined | | | | | | | 0 | | | Function | Stores lower 2-bits of AD conversion result. | | | | | | | AD Conversion Data Storage flag 1: conversion result stored | ### A/D Conversion Result Upper Register 3/7 ADREG37H (02A7H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|-------|-----------------------------------------------|-------|---|---|---|---|---|--|--|--| | Bit symbol | ADR34 | ADR33 | ADR32 | | | | | | | | | | Read/Write | | R | | | | | | | | | | | After Reset | | Undefined | | | | | | | | | | | Function | | Stores upper 8-bits of A/D conversion result. | | | | | | | | | | Channel x conversion result - Bits 5 to1 are always read as "1" - $\bullet\,$ Bit 0 is the A/D conversion data storage flag <ADRxRF>. When the A/D conversion result is stored, the flag is set to "1". When either of the registers (ADREGxH, ADREGxL) is read, the flag is cleared to "0". Figure 3.11.5 A/D Converter related registers ### 3.11.2 Description of operation #### (1) Analog reference voltage A High-level analog reference voltage is applied to the VREFH pin; a low-level analog reference voltage is applied to the VREFL pin. To perform A/D conversion, the reference voltage as the difference between VREFH and VREFL, is divided by 1024 using string resistance. The result of the division is then compared with the analog input voltage. To turn off the switch between VREFH and VREFL, write "0" to ADMOD1<VREFON> in A/D Mode Control Register 1. To start A/D conversion in the OFF state, first write "1" to ADMOD1<VREFON>, wait 3 $\mu$ s until the internal reference voltage stabilizes (this is not related to fc), then set ADMOD0< ADS> to "1". #### (2) Analog input channel selection The analog input channel selection varies depends on the operation mode of the A/D converter. - In Analog Input Channel Fixed Mode (A/D MOD0<SCAN> = "0") Setting ADMOD1<ADCH2 to ADCH0> selects one of the input pins AN0 to AN7 as the input channel. - In Analog Input Channel Scan Mode (ADMOD0<SCAN> = "1") Setting ADMOD1<ADCH2 to ADCH0> selects one of the 8 scan modes. Table 3.11.1 illustrates analog input channel selection in each operation mode. After Reset, ADMOD0<SCAN> = "0" and ADMOD1<ADCH2 to ADCH0> = "000". Thus pin AN0 is selected as the fixed input channel. Pins not used as analog input channels can be used as standard input port pins. | <adch2~0></adch2~0> | Channel fixed <scan> = "0"</scan> | Channel scan <scan> = "1"</scan> | |---------------------|-----------------------------------|-------------------------------------------------------| | 000 | AN0 | AN0 | | 001 | AN1 | $AN0 \rightarrow AN1$ | | 010 | AN2 | $AN0 \rightarrow AN1 \rightarrow AN2$ | | 011 | AN3 | $AN0 \rightarrow AN1 \rightarrow AN2 \rightarrow AN3$ | | 100 | AN4 | AN4 | | 101 | AN5 | $AN4 \rightarrow AN5$ | | 110 | AN6 | $AN4 \rightarrow AN5 \rightarrow AN6$ | | 111 | AN7 | $AN4 \rightarrow AN5 \rightarrow AN6 \rightarrow AN7$ | Table 3.11.1 Analog input channel selection #### (3) Starting A/D Conversion To start A/D conversion, write "1" to ADMOD0<ADS> in A/D Mode Control Register 0, or ADMOD1<ADTRGE> in A/D Mode Control Register 1 and input falling edge on ADTRG pin. When A/D conversion starts, the A/D Conversion Busy flag ADMOD0<ADBF> will be set to "1", indicating that A/D conversion is in progress. Writing "1" to ADMOD0<ADS> during A/D conversion restarts conversion. At that time, to determine whether the A/D conversion results have been preserved, check the value of the conversion data storage flag ADREGxL<ADRxRF>. During A/D conversion, a falling edge input on the ADTRG pin will be ignored. # (4) A/D conversion modes and the A/D Conversion End interrupt The 4 A/D conversion modes are: - Channel Fixed Single Conversion Mode - Channel Scan Single Conversion Mode - Channel Fixed Repeat Conversion Mode - Channel Scan Repeat Conversion Mode The ADMOD0<REPET> and ADMOD0<SCAN> settings in A/D Mode Control Register 0 determine the A/D mode setting. Completion of A/D conversion triggers an INTAD A/D Conversion End interrupt request. Also, ADMOD0<EOCF> will be set to "1" to indicate that A/D conversion has been completed. Channel Fixed Single Conversion Mode Setting ADMOD0<REPET> and ADMOD0<SCAN> to "00" selects Channel Fixed Single Conversion Mode. In this mode, data on one specified channel is converted once only. When the conversion has been completed, the ADMOD0<EOCF> flag is set to "1", ADMOD0<ADBF> is cleared to "0", and an INTAD interrupt request is generated. Channel Scan Single Conversion Mode Setting ADMOD0<REPET> and ADMOD0<SCAN> to "01" selects Channel Scan Single Conversion Mode. In this mode, data on the specified scan channels is converted once only. When scan conversion has been completed, ADMOD0<EOCF> is set to "1", ADMOD0<ADBF> is cleared to "0", and an INTAD interrupt request is generated. Channel Fixed Repeat Conversion Mode Setting ADMOD0<REPET> and ADMOD0<SCAN> to "10" selects Channel Fixed Repeat Conversion Mode. In this mode, data on one specified channel is converted repeatedly. When conversion has been completed, ADMOD0<EOCF> is set to "1" and ADMOD0<ADBF> is not cleared to "0" but held "1". INTAD interrupt request generation timing is determined by the setting of ADMOD0<ITM0>. Setting <ITM0> to "0" generates an interrupt request every time an A/D conversion is completed. Setting <ITM0> to "1" generates an interrupt request on completion of every fourth conversion. Channel Scan Repeat Conversion Mode Setting ADMOD0<REPET> and ADMOD0<SCAN> to "11" selects Channel Scan Repeat Conversion Mode. In this mode, data on the specified scan channels is converted repeatedly. When each scan conversion has been completed, ADMOD0<EOCF> is set to "1" and an INTAD interrupt request is generated. ADMOD0<ADBF> is not cleared to "0" but held "1". To stop conversion in a repeat conversion mode (i.e. in cases and ), write a "0" to ADMOD0<REPET>. After the current conversion has been completed, the repeat conversion mode terminates and ADMOD0<ADBF> is cleared to "0". Switching to a halt state (IDLE2 Mode with ADMOD1<I2AD> cleared to "0", IDLE1 Mode or STOP Mode) immediately stops operation of the A/D converter even when A/D conversion is still in progress. In repeat conversion modes (i.e. in cases and ), when the halt is released, conversion restarts from the beginning. In single conversion modes (i.e. in cases and ), conversion does not restart when the halt is released (the converter remains stopped). Table 3.11.2 shows the relationship between the A/D conversion modes and interrupt requests . Table 3.11.2 Relationship between A/D Conversion modes and Interrupt requests | Mode | Interrupt Request | | ADMOD0 | | |-----------------------------------------|-------------------------------------------|---------------|-------------------|---------------| | Wode | Generation | <itm0></itm0> | <repeat></repeat> | <scan></scan> | | Channel Fixed Single<br>Conversion Mode | After completion of conversion | X | 0 | 0 | | Channel Scan Single<br>Conversion Mode | After completion of scan conversion | X | 0 | 1 | | Channel Fixed Repeat | Every conversion | 0 | 1 | 0 | | Conversion Mode | Every forth conversion | 1 | 1 | 0 | | Channel Scan Repeat<br>Conversion Mode | After completion of every scan conversion | X | 1 | 1 | X: Don't care (5) A/D conversion time 84 states (10.5 $\mu$ s @ f<sub>FPH</sub> = 16MHz) are required for the A/D conversion for one channel. (6) Storing and reading the results of A/D conversion The A/D Conversion Data Upper and Lower Registers (ADREG04H/L to ADREG37H/L) store the A/D conversion results. (ADREG04H/L to ADRG37H/L are read-only registers.) In Channel Fixed Repeat Conversion Mode, the conversion results are stored successively in registers ADREG04H/L to ADRG37H/L. In other modes, the AN0 and AN4, AN1 and AN5, AN2 and AN6, and AN3 and AN7 conversion results are stored in ADREG04H/L, ADREG15H/L, ADREG26H/L and ADREG37H/L respectively. Table 3.11.3 shows the correspondence between the analog input channels and the registers which are used to hold the results of A/D conversion. Table 3.11.3 Correspondence Between Analog Input Channels and A/D Conversion Result Registers | | A/D Conversion | n Result Register | |----------------------------------|--------------------------------------|-------------------------------------------------------------------| | Analog input channel<br>(Port A) | Conversion modes other than at right | Channel fixed repeat<br>conversion mode<br>(every 4th conversion) | | AN0 | ADREG04H/L | | | AN1 | ADREG15H/L | ADREG04H/L ← | | AN2 | ADREG26H/L | ₩<br>ADREG15H/L | | AN3 | ADREG37H/L | ADICEO 1311/E | | AN4 | ADREG04H/L | ADREG26H/L | | AN5 | ADREG15H/L | ↓ | | AN6 | ADREG26H/L | ADREG37H/L | | AN7 | ADREG37H/L | | <ADRxRF>, bit "0" of the A/D conversion data lower register, is used as the A/D conversion data storage flag. The storage flag indicates whether the A/D conversion result register has been read or not. When a conversion result is stored in the A/D conversion result register, the flag is set to "1". When either of the A/D conversion result registers (ADREGxH or ADREGxL) is read, the flag is cleared to "0". Reading the A/D conversion result also clears the A/D Conversion End flag ADMOD0<EOCF> to "0". TMP91C824 ### Setting example: Convert the analog input voltage on the AN3 pin and write the result, to memory address 0800H using the A/D interrupt (INTAD) processing routine. #### Main routine: ``` 7 6 5 4 3 2 1 0 INTE0AD ← X 1 0 0 - - - - Enable INTAD and set it to Interrupt Level 4. ADMOD1 Set pin AN3 to be the analog input channel. ADMOD0 \leftarrow X X 0 0 0 0 0 1 Start conversion in Channel Fixed Single Conversion Mode. Interrupt routine processing example: WA ← ADREG37 Read value of ADREG37L and ADREG37H into 16-bit general-purpose register WA. WA >>6 Shift contents read into WA six times to right and zero-fill upper bits. (H0080) \leftarrow \text{WA} Write contents of WA to memory address 0800H. ``` This example repeatedly converts the analog input voltages on the three pins AN0, AN1 and AN2, using Channel Scan Repeat Conversion Mode. # 3.12 Watch Dog Timer (runaway detection timer) The TMP91C824 features a watch dog timer for detecting runaway. The watch dog 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 watch dog timer detects a malfunction, it generates a non-maskable interrupt INTWD to notify the CPU. Connecting the watch dog timer output to the Reset pin internally forces a reset. ### 3.12.1 Configuration Figure 3.12.1 is a block diagram of he watchdog timer (WDT). Figure 3.12.1 Block diagram of watch dog timer The watch dog 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}/215$ , $f_{SYS}/217$ , $f_{SYS}/219$ and $f_{SYS}/221$ . Selecting one of the outputs using WDMOD<WDTP1,WDTP0> generates a Watchdog interrupt and outputs watchdog timer out when an overflow occurs as shown in Figure 3.12.2. Figure 3.12.2 Normal mode The runaway detection result can also be connected to the Reset pin internally. In this case, the reset time will be between 22 and 29 states as shown in Figure 3.12.3. Figure 3.12.3 Reset mode ## 3.12.2 Control registers The watchdog timer WDT is controlled by two control registers WDMOD and WDCR. - (1) Watch dog timer Mode Register (WDMOD) - ① Setting the detection time for the watch dog timer in <WDTP1,WDTP0> This 2-bit register is used for setting the watch dog timer interrupt time used when detecting runaway. After Reset, this register is initialized to WDMOD<WDTP1,WDTP0> = "00". The detection times for WDT are shown in Figure 3.12.4. ② Watch dog timer Enable/Disable Control Register <WDTE> After Reset, WDMOD<WDTE> is initialized to "1", enabling the watch dog timer. To disable the watch dog timer, it is necessary to set this bit to "0" and to write the disable code (B1H) to the watch dog timer Control Register WDCR. This makes it difficult for the watch dog timer to be disabled by runaway. However, it is possible to return the watch dog timer from the disabled state to the enabled state merely by setting <WDTE> to "1". ③ Watch dog timer out reset connection <RESCR> This register is used to connect the output of the watch dog timer with the RESET terminal internally. Since WDMOD<RESCR>is initialized to "0" on Reset, a Reset by the watch dog timer will not be performed. (2) Watch dog timer Control Register (WDCR) This register is used to disable and clear the binary counter for the watch dog timer. Disable control the watch dog 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". • Watch dog timer clear control To clear the binary counter and cause counting to resume, write the clear code (4EH) to the WDCR register. ``` WDCR \leftarrow 0 \ 1 \ 0 \ 0 \ 1 \ 1 \ 1 \ 0 Write the clear code (4EH). ``` Figure 3.12.4 Watch dog timer mode register Figure 3.12.5 Watch dog timer control register ### 3.12.3 Operation The watch dog timer generates an INTWD interrupt when the detection time set in the WDMOD<WDTP1,WDTP0> has elapsed. The watch dog timer must be cleared "0" by software before an INTWD interrupt will be generated. If the CPU malfunctions (i.e. 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 watch dog timer works immediately after reset. The watch dog timer does not operate in IDLE1 or STOP mode, as the binary counter continues counting during bus release (When BUSAK goes Low). 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. Example: ① Clear the binary counter. ``` WDCR \leftarrow 0 1 0 0 1 1 1 1 0 Write the clear code (4EH). ② Set the watchdog timer detection time to 2^{17}/f_{SYS}. WDMOD \leftarrow 1 0 1 - - - - X X ③ Disable the watchdog timer. WDMOD \leftarrow 0 - - - - - - X X Clear WDTE to "0". WDCR \leftarrow 1 0 1 1 0 0 0 1 Write disable code (B1H). ``` # 3.13 Real time clock (RTC) ### 3.13.1 Function description for RTC - 1) Clock function (hour, minute, second) - 2) Calendar function (month and day, day of the week, and leap year) - 3) 24 or 12-hour (AM/PM) clock function - 4) $\pm 30$ second adjustment function (by software) - 5) Alarm function (Alarm output) - 6) Alarm interrupt generate ## 3.13.2 Block diagram Figure 3.13.1 RTC block diagram ### (note1) The Christian era year column: This product has year column toward only lower two columns. Therefore the next year in 99 works as 00 years. In system to use it, please manage upper two columns with the system side when handle year column in the Christian era. ### (note2) Leap year: A leap year is the year, which is divisible with 4, but the year, which there is exception, and is divisible with 100 is not a leap year. However, the year, which is divisible with 400, is a leap year. But there is not this product for the correspondence to the above exception. Because there are only with the year which is divisible with 4 as a leap year, please cope with the system side if this function is problem. TOSHIBA # 3.13.1 Control registers Table 3.13.1 PAGE 0 (Timer function) registers | Symbol | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Function | Read<br>/Write | |--------|---------|------|------|-------|--------|-------|------------|--------------|-------|------------------------|----------------| | SECR | 0320h | | 40 | 20 | 10 | 8 | 4 | 2 | 1 | Second column | R/W | | BECK | 032011 | | sec. Second column | 10 11 | | MINR | 02011 | | 40 | 20 | 10 | 8 | 4 | 2 | 1 | Minute column | R/W | | MIINK | 0321h | | min. Milliute Column | K/W | | HOURR | 0322h | | | 20 | 10 | 8 | 4 | 2 | 1 | Hour column | R/W | | HOUKK | 052211 | | | hours | hours | hours | hours | hours | hour | Hour coluilli | K/W | | DAYR | 0323h | | | | | | W2 | W1 | W0 | Day of the week column | R/W | | DATED | 02241- | | | Day | Day | Day | Day | Day | Day | D1 | R/W | | DATER | 0324h | | | 20 | 10 | 8 | 4 | 2 | 1 | Day column | | | MONTHR | 0325h | | | | Oct. | Aug. | Apr. | Feb. | Jan. | Month column | R/W | | VEADD | 0226 | Year column | D/W | | YEARR | 0326h | 80 | 40 | 20 | 10 | 8 | 4 | 2 | 1 | (lower two columns) | R/W | | DACED | 02271- | INT | | | | ENA | ENA | | D. C. | DACE resistan | W, | | PAGER | 0327h | ENA | | | ADJUST | TMR | ALM | | PAGE | PAGE register | R/W | | DECTD | 02201 | DIS | DIS | RST | RST | | A levere V | Inita to 10 | , | Dagat magistan | Write | | RESTR | 0328h | 1HZ | 16HZ | TMR | ALM | | Aiways v | Vrite to '0' | | Reset register | only | (note): As for SECR, MINR, HOURR, DAYR, MONTHR, YEAR of PAGEO, current state is read when read it. Table 3.13.2 PAGE 1(Alarm function) registers | Symbol | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Function | Read<br>/Write | |--------|---------|------------|-------------|-------------|-------------|---------------------|------------|----------------|---------------|----------------------------------|----------------| | SECR | 0320h | | | | | | | | | | R/W | | MINR | 0321h | | 40<br>min. | 20<br>min. | 10<br>min. | 8<br>min. | 4 min. | 2<br>min. | 1<br>min. | Minute column | R/W | | HOURR | 0322h | | | 20<br>hours | 10<br>hours | 8<br>hours | 4<br>hours | 2<br>hours | 1<br>hour | Hour column | R/W | | DAYR | 0323h | | | | | | W2 | W1 | W0 | Day of the week column for Alarm | R/W | | DATER | 0324h | | | Day<br>20 | Day<br>10 | Day<br>8 | Day<br>4 | Day<br>2 | Day<br>1 | Day column | R/W | | MONTHR | 0325h | | | | | | | | 24/12 | 24-hour clock mode | R/W | | YEARR | 0326h | | | | | | | Leap<br>1 | Leap<br>2 | Leap –year mode | R/W | | PAGER | 0327h | INT<br>ENA | | | | ENA ENA<br>TMR ALM | | PAGE | PAGE register | W,<br>R/W | | | RESTR | 0328h | DIS<br>1HZ | DIS<br>16HZ | RST<br>TMR | RST<br>ALM | Always Write to '0' | | Reset register | Write only | | | # 3.13.2 Detailed explanation of control register RTC is not initialized by reset. Therefore, all registers must be initialized at the beginning of the program. # (1) Second column register (for PAGE0 only) SECR (0320H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|--------------|---------|-------------------|------------------|------------------|--------|-----------------|-----------------|--|--| | bit Symbol | | SE6 | SE5 | SE4 | SE3 | SE2 | SE1 | SE0 | | | | Read/Write | | | | | | | | | | | | After reset | | | | | Undefined | | | | | | | Function | "0" is read. | 40 sec. | 20 sec.<br>Column | 10sec.<br>Column | 8 sec.<br>column | 4 sec. | 2sec.<br>column | 1sec.<br>column | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 sec. | |---|---|---|---|---|---|---|---------| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 sec. | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 2 sec. | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 4 sec. | | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 5 sec. | | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 6 sec. | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 7 sec. | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 8 sec. | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 9 sec. | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 10 sec. | | | | | | | | | | | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 19 sec. | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 20 sec. | | | | | | | | | | | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 sec. | | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 30 sec. | | ľ | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 39 sec. | |---|---|---|---|---|---|---|---|---------| | ľ | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 40 sec. | | _ | | | | | | | | | | _ | | | | | | | | | | | 1 | Λ | Λ | 1 | Λ | Λ | 1 | 10 sec | | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 59 sec. | |---|---|---|---|---|---|---|---------| 0 0 50 sec. # (2) Minute column register (for PAGE0/1) MINR (0321H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|--------------|-------------------|------------------|------------------|------------------|------------------|------------------|-----------------|--| | bit Symbol | | MI6 | MI5 | MI4 | MI3 | MI2 | MI1 | MI0 | | | Read/Write | | | | | R/W | | | | | | After reset | | | Undefined | | | | | | | | Function | "0" is read. | 40 min,<br>column | 20min,<br>column | 10min,<br>column | 8 min.<br>column | 4 min.<br>column | 2 min,<br>column | 1min,<br>column | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 min. | |---|---|---|---|---|---|---|---|---------| | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 min. | | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 2 min. | | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 3 min. | | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 4 min. | | | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 5 min. | | | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 6 min. | | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 7 min. | | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 8 min. | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 9 min. | | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 10 min. | | | | | | | | | | | | ſ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 19 min. | | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 20 min. | | | | | | | | | | | | ſ | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 min. | | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 min. | |---|---|---|---|---|---|---|---------| | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 30 min. | | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 39 min. | |---|---|---|---|---|---|---|---------| | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 40 min. | | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 49 min. | |---|---|---|---|---|---|---|---------| | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 50 min. | | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 59 min. | |---|---|---|---|---|---|---|---------| **TOSHIBA** # (3) Hour column register (for PAGE0/1) In case of 24-hour clock mode (MONTHR<MO0>='1') of PAGE1 | HOURR | | |---------|--| | (0322H) | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|--------|-------|-------------------|-------------------|------------------|------------------|------------------|------------------| | bit Symbol | | | HO5 | HO4 | НО3 | HO2 | HO1 | HO0 | | Read/Write | | | R/W | | | | | | | After reset | | | Undefined | | | | | | | Function | "0" is | read. | 20 hour<br>column | 10 hour<br>column | 8 hour<br>column | 4 hour<br>column | 2 hour<br>column | 1 hour<br>column | | 0 | 0 | 0 | 0 | 0 | 0 | 0 o'clock | |---|---|---|---|---|---|-----------| | 0 | 0 | 0 | 0 | 0 | 1 | 1 o'clock | | 0 | 0 | 0 | 0 | 1 | 0 | 2 o'clock | | 0 | 0 | 1 | 0 | 0 | 0 | 8 o'clock | |---|---|---|---|---|---|------------| | 0 | 0 | 1 | 0 | 0 | 1 | 9 o'clock | | 0 | 1 | 0 | 0 | 0 | 0 | 10 o'clock | | 0 | 1 | 1 | 0 | 0 | 1 | 19 o'clock | |---|---|---|---|---|---|------------| | 1 | 0 | 0 | 0 | 0 | 0 | 20 o'clock | | 1 | 0 | 0 | 0 | 1 | 1 | 23 o'clock | |---|---|---|---|---|---|------------| # In case of 12-hour clock mode (MONTHR<MO0>='0') of PAGE1 HOURR (0322H) | ľ | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---|-------------|--------|-------|-----------|-------------------|------------------|------------------|------------------|------------------|--| | | bit Symbol | | | HO5 | HO4 | НО3 | HO2 | HO1 | HO0 | | | L | Read/Write | | | R/W | | | | | | | | L | After reset | | | Undefined | | | | | | | | | Function | "0" is | read. | PM/ĀM | 10 hour<br>column | 8 hour<br>column | 4 hour<br>column | 2 hour<br>column | 1 hour<br>column | | | | | | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 o'clock<br>(AM) | |---|---|---|---|---|---|-------------------| | 0 | 0 | 0 | 0 | 0 | 1 | 1 o'clock | | 0 | 0 | 0 | 0 | 1 | 0 | 2 o'clock | | 0 | 0 | 1 | 0 | 0 | 1 | 9 o'clock | | 0 | 1 | 0 | 0 | 0 | 0 | 10 o'clock | | 0 | 1 | 0 | 0 | 0 | 1 | 11 o'clock | | 1 | 0 | 0 | 0 | 0 | 0 | 0 o'clock<br>(PM) | | 1 | 0 | 0 | 0 | 0 | 1 | 1 o'clock | # (4) Day of the week column register (for PAGE0/1) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------|---|---|--------------|----|----|-----|-----------|-----| | DAYR | bit Symbol | | | | | | WE2 | WE1 | WE0 | | (0323H) | Read/Write | | | | | | | R/W | | | | After reset | | | | | | | Undefined | | | | Function | | | "0" is read. | W2 | W1 | W0 | | | **♦** | 0 | 0 | 0 | Sunday | |---|---|---|-----------| | 0 | 0 | 1 | Monday | | 0 | 1 | 0 | Tuesday | | 0 | 1 | 1 | Wednesday | | 1 | 0 | 0 | Thursday | | 1 | 0 | 1 | Friday | | 1 | 1 | 0 | Saturday | # (5) Day column register (for PAGE0/1) | DATER | |---------| | (0324H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|--------|-------|------------------|--------|-------|-------|-------|-------|--| | bit Symbol | | | DA5 | DA4 | DA3 | DA2 | DA1 | DA0 | | | Read/Write | | | R/W<br>Undefined | | | | | | | | After reset | | | | | | | | | | | Function | "0" is | read. | Day 20 | Day 10 | Day 8 | Day 4 | Day 2 | Day 1 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | |---|---|---|---|---|---|----------------------------------------------| | 0 | 0 | 0 | 0 | 0 | 1 | 1 <sup>st</sup> day | | 0 | 0 | 0 | 0 | 1 | 0 | 2 <sup>nd</sup> day | | 0 | 0 | 0 | 0 | 1 | 1 | 3 <sup>rd</sup> day | | 0 | 0 | 0 | 1 | 0 | 0 | 4 <sup>th</sup> day | | | | | | | | | | 0 | 0 | 1 | 0 | 0 | 1 | 9 <sup>th</sup> day<br>10 <sup>th</sup> day | | 0 | 1 | 0 | 0 | 0 | 0 | 10 <sup>th</sup> day | | 0 | 1 | 0 | 0 | 0 | 1 | 11 <sup>th</sup> day | | | | | | | | | | 0 | 1 | 1 | 0 | 0 | 1 | 19 <sup>th</sup> day | | 1 | 0 | 0 | 0 | 0 | 0 | 19 <sup>th</sup> day<br>20 <sup>th</sup> day | | | | | | | | | | 1 | Λ | 1 | Λ | Λ | 1 | 20th day | | 1 | 0 | 1 | 0 | 0 | 1 | 29 <sup>th</sup> day | |---|---|---|---|---|---|----------------------| | 1 | 1 | 0 | 0 | 0 | 0 | 30 <sup>th</sup> day | | 1 | 1 | 0 | 0 | 0 | 1 | 31 <sup>st</sup> day | # (6) Month column register (for PAGE0 only) | | | U | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|--------------------------------------|----------------------------------------------------------------------------------------------|--|--| | bit Symbol | | | | MO4 | MO3 | MO2 | MO1 | MO0 | | | | Read/Write | | | | R/W | | | | | | | | After reset | | | | Undefined | | | | | | | | Function | " | '0" is read. | | 10 months | 8 months | 4 months | 2 months | 1 month | | | | | Read/Write After reset | Read/Write After reset | Read/Write After reset | Read/Write After reset | Read/Write After reset | Read/Write After reset | Read/Write R/W After reset Undefined | Read/Write After reset Undefined Function "0" is read. 10 months 8 months 4 months 2 months | | | | 0 | 0 | 0 | 0 | 1 | January | |---|---|---|---|---|-----------| | 0 | 0 | 0 | 1 | 0 | February | | 0 | 0 | 0 | 1 | 1 | March | | 0 | 0 | 1 | 0 | 0 | April | | 0 | 0 | 1 | 0 | 1 | May | | 0 | 0 | 1 | 1 | 0 | June | | 0 | 0 | 1 | 1 | 1 | July | | 0 | 1 | 0 | 0 | 0 | August | | 0 | 1 | 0 | 0 | 1 | September | | 1 | 0 | 0 | 0 | 0 | October | | 1 | 0 | 0 | 0 | 1 | November | | 1 | 0 | 0 | 1 | 0 | December | # (7) Select 24-hour clock or 12-hour clock (for PAGE1 only) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------|---|---|---|--------------|------------------------|---|---|---------------| | MONTHR | bit Symbol | | | | | | | | MO0 | | (0325H) | Read/Write | | | | | | | | R/W | | | After reset | | | | | | | | Undefine<br>d | | | Function | | | | "0" is read. | 1:24-hour<br>0:12-hour | | | | # (8) Year column register (for PAGE0 only) | YEARR | |---------| | (0326H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|----------|-----------|----------|----------|---------|---------|---------|--------|--| | bit Symbol | YE7 | YE6 | YE5 | YE4 | YE3 | YE2 | YE1 | YE0 | | | Read/Write | | R/W | | | | | | | | | After reset | | Undefined | | | | | | | | | Function | 80 Years | 40 Years | 20 Years | 10 Years | 8 Years | 4 Years | 2 Years | 1 Year | | | | | | | | 1 | | | | | | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 99 year | |---|---|---|---|---|---|---|---|---------| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 year | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 01 year | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 02 year | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 03 year | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 04 year | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 05 year | # (9) Leap-year register (for PAGE1 only) YEARR (0326H) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------------|---|---|--------|-------|---|---|-----------------------------------------------------------------------------------|---------------------------------------------| | 2 | bit Symbol | | | | | | | LEAP1 | LEAP0 | | ) | Read/Write | | | | | | | R/ | W | | | After reset | | | | | | | | | | | Function | | | "0" is | read. | | | 00:leap-yea<br>01: one year<br>leap-ye<br>10:two year<br>leap-yea<br>11:three yea | r after<br>ar<br>s after<br>ur<br>urs after | | 0 | 0 | Current year is leap-year | |---|---|----------------------------------------| | 0 | 1 | Present is next year of a leap year | | 1 | 0 | Present is two years after a leap year | | 1 | 1 | Present is three years after leap year | ## (10) PAGE register setting (for PAGE0/1) ### (11) Reset register setting (for PAGE0/1) TOSHIBA # 3.13.5 Operational description ### (1) Reading timer data There is the case which reads wrong data when carry of the inside counter happens during the operation which timer data reads. Therefore, please read two times with the following way for reading correct data. Figure 3.13.2 Flowchart of timer data read As shown in Figure 3.13.2, confirm the data by reading twice and compare them in case reading timer data. If it happen to take up a digit, the comparing result becomes incorrect. Therefore, It should be read data again. TOSHIBA Readout of timer data that used /ALARM output Timer data can be read with rising edge of /ALARM output by detecting /ALARM='1' with interrupt routine of INTRTC of 1 Hz Figure 3.13.3 Read out of the timer table used /ALARM output The reason why read a timer of RTC after reading PORT in interrupt routine of /ALARM=1 is that carry of RTC timer occurs with rising edge of pulse period of 1 Hz. By reading timer during 0.5second after carry happening, right data (a timer value) can be read. # (2) Writing timer data When there is carry on the way of write operation, expecting data can not be wrote exactly. Therefore, in order to write in data exactly please follow the below way. ### Reset for a divider Inside of RTC, there is 15-stage divider which generates 1Hz clock from 32,768KHz. Carry of a timer is not done for one second when reset this divider. So write in data during this interval. Figure 3.13.4 Flowchart of data write ### Disabling the timer Carry of a timer is prohibited when write '0' to PAGER<ENATMR> and can prevent malfunction by CLOCK HOLD circuit. During a timer prohibited, CLOCK HOLD circuits holds one sec. carry signal, which is generated from divider. After becoming timer enable state, output the carry signal to timer and revise time and continue operation. However, timer is late when timer-disabling state continues for one second or more. During timer disabling, pay attention with system power is downed. In this case the timer is stopped and time is delayed. Figure 3.13.5 Flowchart of timer disable ### 3.13.3 Explanation of the alarm function It can use alarm function by setting of register of PAGE1 and output either of three signal from /ALARM pin as follows. INTRTC always output 1-shot pulse detecting falling down edge. RTC circuit isn't reset by /RESET signal, it need to init interrupt request flag before setting timer and alarm of RTC. - (1) In accordance of alarm register and the timer, output '0' - (2) Output clock of 1Hz - (3) Output clock of 16Hz #### (1) In accordance of alarm register and a timer, output '0'. When value of a timer of PAGE0 accorded with alarm register of PAGE1 with a state of PAGER<ENAALM>='1', output '0' to /ALARM pin and occur INTRTC. Follows are ways using alarm. Initialization of alarm is done by writing in '1' at RESTR<RSTALM>, setting value of all alarm becomes don't care. In this case, always accorded with value of a timer and occur INTRTC interrupt if PAGER<ENAALM> is '1'. Setting alarm min., alarm hour, alarm day and alarm the day week is done by writing in data at each register of PAGE1. When all setting contents accorded, RTC generates INTRTC interrupt, if PAGER<ENAALM> is '1'. However, contents (don't care state) which does not set it up is considered to always accord. The contents, which set it up once, cannot be returned to don't care state in independence. Initialization of alarm and resetting of alarm register are necessary. Follows are example program at outputting alarm in noon (PM12: 00) every day | LD | (PAGER), 09H | ; Alarm disable, setting PAGE1 | |----|---------------|--------------------------------| | LD | (RESTR), 10H | ; Alarm initialize | | LD | (MONTHR), 01H | ; 24-hour clock mode | | LD | (HOURR), 12H | ; setting 12 o'clock | | LD | (MINR), 00H | ; setting 00 min. | | LD | (PAGER), 0CH | ; Alarm enable | #### (2) When output clock of 1Hz RTC outputs clock of 1Hz to /ALARM pin by setting up PAGER<ENAALM>='0', RESTR<DIS1HZ>='0', <DIS16HZ>='1'. And RTC generates INTRC interrupt by falling edge of the clock. #### (3) When output clock of 16Hz RTC outputs clock of 16Hz to /ALARM pin by setting up PAGER<ENAALM>='0', RESTR<DIS1HZ>='1', <DIS16HZ>='0'. And RTC generates INTRC interrupt by falling edge of the clock. # 3.14 Melody / Alarm generator (MLD) TMP91C824 incorporates melody function and alarm function, both of which are output from the MLDALM pin. 5 kinds of fixed cycle interrupts are generated by the 15-bit free-run counter, which is used for alarm generator. Features are as follows. ### Melody generator The Melody function generates signals of any frequency (4Hz- 5461Hz) based on low-speed clock (32.768KHz) and outputs several signals from the MLDALM pin. By connecting a loud speaker outside, Melody tone can sound easily. ### Alarm generator The Alarm function generates 8 kinds of alarm waveform having a modulation frequency (4096Hz) determined by the low-speed clock (32.768KHz). And this waveform is able to invert by setting a value to a register. By connecting a loud speaker outside, Alarm tone can sound easily. And also 5 kinds of fixed cycle (1Hz, 2Hz, 64Hz, 512Hz, 8KHz) interrupts are generated by the free-run counter which is used for alarm generator. This section is constituted as follows. - 3.14.1 Block diagram - 3.14.2 Control registers - 3.14.3 Operational description - 3.14.3.1 Melody generator - 3.14.3.2 Alarm generator # 3.14.1 Block Diagram Figure 3.14.1 MLD Block Diagram # 3.14.2 Control registers ### ALM R register ALM (0330H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-----|-----------------------|-----|-----|-----|-----|-----|-----| | bit Symbol | AL8 | AL7 | AL6 | AL5 | AL4 | AL3 | AL2 | AL1 | | Read/Write | R/W | | | | | | | | | After reset | | 0 | | | | | | | | Function | | Setting alarm pattern | | | | | | | # MLDALMC register MELALMC (0331H) | L | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-------------|---------------------------------------------------------------------------|-----|------------------------------------------|---|-------|------|---|-------------------------------------------------------| | ]د | bit Symbol | FC1 | FC0 | ALMINV | | | | | MELALM | | I | Read/Write | R/W | | R/W | | | | | R/W | | I | After reset | 0 | | 0 | | | | | 0 | | | Function | Free-run counter control 00: Hold 01: Restart 10: Clear 11: Clear & Start | | Alarm<br>Wavefor<br>m invert<br>1:INVERT | | Write | ÷"0" | | Output<br>Waveform<br>select<br>0: Alarm<br>1: Melody | (note1): MELALMEC<FC1> is read always "0". (note2): When setting MELALMC register except <FC1:0> during the free-run counter is running, <FC1:0> is kept "01". ### MELFL register MELFL (0332H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-----|---------------------------------------|-----|-----|-----|-----|-----|-----| | bit Symbol | ML7 | ML6 | ML5 | ML4 | ML3 | ML2 | ML1 | ML0 | | Read/Write | R/W | | | | | | | | | After reset | | 0 | | | | | | | | Function | | Setting melody frequency (lower 8bit) | | | | | | | ## MELFH register MELFH (0333H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|----------------------------------------------------------------|---|---|---|---------|---------------|-------------|-------|--| | bit Symbol | MELON | | | | ML11 | ML10 | ML9 | ML8 | | | Read/Write | R/W | | | | R/W | | | | | | After reset | 0 | | | | 0 | | | | | | Function | Control<br>melody<br>counter<br>0: Stop &<br>Clear<br>1: Start | | | | Settino | g melody freq | uency(upper | 4bit) | | # ALMINT register ALMINT (0334H) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|-----------|---|---|------------------------------------------|--------|--------|--------|--------|--| | bit Symbol | | | | IALM4E | IALM3E | IALM2E | IALM1E | IALM0E | | | Read/Write | | | | | | R/W | | | | | After reset | | | | | 0 | | | | | | Function | Write "0" | | | 1:Interrupt enable for INTALM4 ~ INTALM0 | | | | | | ### 3.14.3 Operational Description ### 3.14.3.1 Melody generator The Melody function generates signals of any frequency (4Hz- 5461Hz) based on low-speed clock (32.768KHz) and outputs the signals from the MLDALM pin. By connecting a loud speaker outside, Melody tone can sound easily. (Operation) At first, MELALMC<MELALM> have to be set as 1 in order to select melody waveform as output waveform from MLDALM. Then melody output frequency has to be set to 12-bit register MELFH, MELFL. Followings are setting example and calculation of melody output frequency. (Formula for calculating of melody waveform frequency) @fs = 32.768[KHz] melody output waveform $fMLD[Hz] = 32768 / (2 \times N+4)$ setting value for melody $N = (16384 \, / \, \text{fMLD} \, ) - 2$ (notice: N=1 ~ 4095(001H ~ FFFH) 、 0 is not acceptable ) (Example program) In case of outputting "La" musical scale (440Hz) LD (MELALMC),--XXXXX1B ; select melody waveform LD (MELFL),23H ; N = 16384/440 - 2 = 35.2 = 023H LD (MELFH),80H ; start to generate waveform ### (Refer to "Basic musical scale setting table") | Scale | Frequency [Hz] | Register value: N | |-------|----------------|-------------------| | Do | 264 | 03CH | | Re | 297 | 035H | | Mi | 330 | 030H | | Fa | 352 | 02DH | | Sol | 396 | 027H | | La | 440 | 023H | | Si | 495 | 01FH | | Do | 528 | 01DH | ### 3.14.3.2 Alarm generator The Alarm function generates 8 kinds of alarm waveform having a modulation frequency 4096Hz determined by the low-speed clock (32.768KHz). And this waveform is reversible by setting a value to a register. By connecting a loud speaker outside, Alarm tone can sound easily. 5 kinds of fixed cycle (1Hz, 2Hz, 64Hz, 512Hz, 8KHz) interrupts are generated by the free-run counter, which is used for alarm generator. ### (Operation) At first, MELALMC<MELALM> have to be set as 0 in order to select alarm waveform as output waveform from MLDALM. Then alarm pattern have to be set on 8 bit register of ALM. Finally "10" be set on MLDALMC<AC1:0> register, and <ALMINV> be set as invert. By it is setting these values, counter start to generate alarm waveform. Followings are example program, setting value of alarm pattern and waveform of each setting value. ### (Setting value of alarm pattern) | Setting value for ALM register | Alarm waveform | |--------------------------------|----------------| | 00H | "0" fixed | | 01H | AL1 pattern | | 02H | AL2 pattern | | 04H | AL3 pattern | | 08H | AL4 pattern | | 10H | AL5 pattern | | 20H | AL6pattern | | 40H | AL7 pattern | | 80H | AL8 pattern | | Other | Undefined | | | (do not set) | ### (Example program) In case of outputting AL2 pattern (31.25ms/8 times/1sec) LD (MELALMC),C0H ; set output alarm waveform ; free-run counter start LD (ALM),02H ; set AL2 pattern, start Example: Waveform of alarm pattern for each setting value: not invert) # 4. Electrical Characteristics # 4.1 Absolute Maximum Ratings | Symbol | Parameter | Rating | Unit | |---------|------------------------------------------|-------------------|------| | Vcc | Power Supply Voltage | -0.5 to 4.0 | V | | VIN | Input Voltage | -0.5 to Vcc + 0.5 | V | | IOL | Output Current | 2 | mA | | IOH | Output Current | -2 | mA | | ΣΙΟL | Output Current (total) | 80 | mA | | ΣΙΟΗ | Output Current (total) | -80 | mA | | PD | Power Dissipation ( $Ta = 85^{\circ}C$ ) | 600 | mW | | TSOLDER | Soldering Temperature (10 s) | 260 | °C | | TSTG | Storage Temperature | -65 to 150 | °C | | TOPR | Operating Temperature | -40 to 85 | °C | # 4.2 DC Characteristics (1/2) | | Parameter | Symbol | Condi | ition | Min. | Тур. | Max. | Unit | |--------------------|------------------------------------------------------|-------------|-----------------------------------------|-------------------|------------|------|---------|------| | ( A' | Supply Voltage<br>VCC = DVCC )<br>VSS = DVSS = 0 V ) | VCC | $fc = 2 \sim 33MHz$ $fc = 2 \sim 10MHz$ | fs =30to<br>34kHz | 2.7<br>1.8 | - | 3.6 | V | | | D0 to 15 | VIL | Vcc 2.7V | - | | | 0.6 | | | | D0 to 15 | VIL | Vcc<2.7V | | ] | - | 0.2Vcc | | | In | D52 ( DD7/ (DD2) | X711 1 | Vcc 2.7V | | | | 0.3Vcc | | | put | P52 to PD7(excep tPB3) | VIL1 | Vcc<2.7V | | ] | - | 0.2Vcc | | | Input Low Voltage | /RESET/NMI, | VIII 0 | Vcc 2.7V | | 0.2 | | 0.25Vcc | | | ¥<br> <b>&lt;</b> | PB3(INT0) | VIL2 | Vcc<2.7V | | -0.3 | - | 0.15Vcc | | | olta | ANG 1 | VIII 2 | Vcc 2.7V | | | | 0.3 | | | ıge | AM0~1 | VIL3 | Vcc<2.7V | | ] | - | 0.3 | | | | 37.1 | 3.733 A | Vcc 2.7V | | | | 0.2Vcc | | | | X1 | VIL4 | Vcc<2.7V | | 1 | - | 0.1Vcc | | | | | | 3.6V Vcc> 3.3V | | 2.4 | | | V | | | D0 ~ 15 | VIH | 3.3V>Vcc 2.7V | | 2.0 | - | | | | <u></u> | | | Vcc<2.7V | | 0.7Vcc | | | | | nou | D52 / DD7/ / DD2) | X 7 T T T 1 | Vcc 2.7V | | 0.7Vcc | | | | | Inout High Voltage | P52 to PD7(except PB3) | VIH1 | Vcc<2.7V | | 0.8Vcc | - | | | | gh | /RESET/NMI, | VIH2 | Vcc 2.7V | | 0.75Vcc | | Vcc+0.3 | | | Vol | PB3(INT0) | V 1112 | Vcc<2.7V | | 0.85Vcc | - | | | | tage | AM0 to 1 | VIH3 | Vcc 2.7V | | Vcc-0.3 | _ | | | | | 71110 to 1 | V 1113 | Vcc<2.7V | | Vcc-0.3 | | | | | | X1 | VIH4 | Vcc 2.7V | | 0.8Vcc | _ | | | | | | | Vcc<2.7V | | 0.9Vcc | | | | | Output | Low Voltage | VOL1 | IOL=1.6mA | Vcc 2.7V | | _ | 0.45 | | | Jaipat | 20 orage | , 021 | IOL=0.4mA | Vcc<2.7V | | | 0.15Vcc | V | | Output | Uigh Voltage | VOH2 | IOH=-400uA | Vcc 2.7V | Vcc-0.3 | | | • | | Output | High Voltage | VOII2 | IOH=-200uA | Vcc<2.7V | 0.8Vcc | - | - | | (note1): Typical values are for when $Ta = 25^{\circ}C$ and Vcc = 3.0 V uncles otherwise noted. # 4.2 DC Characteristics (2/2) | Parameter | Symbol | Condition | Min | Тур | Max. | Unit | |------------------------------------------|--------|---------------------------------|-----|------|------|------| | Input Leak Current | ILI | 0.0 VIN Vcc | - | 0.02 | ± 5 | ^ | | Output Leak Current | ILO | 0.2 VIN Vcc-0.2 | - | 0.05 | ± 10 | μA | | Power Down Voltage (at STOP,RAM Back up) | VSTOP | VIL2 = 0.2Vcc,<br>VIH2 = 0.8Vcc | 1.8 | - | 3.6 | V | | (DEGETE D. 11 M. D | DDCT | 3.6V Vcc 2.7V | 80 | - | 400 | | | /RESET Pull Up Resister | RRST | Vcc=2V ± 10% | 200 | | 1000 | k | | Pin Capacitance | CIO | fc = 1MHz | - | - | 10 | pF | | Schmitt Width | | Vcc 2.7V | 0.4 | 0.9 | - | | | /RESET,/NMI,<br>INT0,KI0-7 | VTH | Vcc<2.7V | 0.3 | 0.7 | | V | | Programmable Pull Up | DIZII | 3.6V Vcc 2.7V | 80 | - | 400 | | | Resister | RKH | Vcc=2V ± 10% | 200 | | 1000 | k | | NORMAL (Note2) | | 201 11 271 | - | 14.0 | 20.0 | | | IDLE2 | | 3.6V Vcc 2.7V<br>fc = 33MHz | - | 4.0 | 6.1 | mA | | IDLE1 | | IC — SSIVILIZ | - | 1.2 | 2.2 | | | SLOW (Note2) | | Vcc=2V ± 10% | - | 2.6 | 3.0 | | | IDLE2 | | fs=10MHz | - | 0.7 | 1.2 | μA | | IDLE1 | | (Typ.value :Vcc=2.0V) | - | 0.2 | 0.4 | | | SLOW (Note2) | Icc | 3.6V Vcc 2.7V | - | 17.5 | 30.5 | | | IDLE2 | | fs=32.768kHz | - | 7.0 | 13.5 | μA | | IDLE1 | | | - | 5.0 | 10.0 | | | SLOW (Note2) | | Vcc=2V ± 10% | - | 10.5 | 13.0 | | | IDLE2 | | fs=32.768kHz | - | 4.5 | 6.5 | μA | | IDLE1 | | (Typ. Value : Vcc=2.0V) | - | 3.0 | 4.5 | | | STOP | | 3.6V Vcc 1.8V | - | 0.2 | 15 | μΑ | (note1): Typical values are for when $Ta = 25^{\circ}C$ and Vcc = 3.0 V unless otherwise noted. (note2): Icc measurement conditions (NORMAL, SLOW): All functions are operational; output pins are open and input pins are fixed. Data & address bus CL=30pF loaded. ## 4.3 AC Characteristics (1) $Vcc = 3.0 V \pm 10\%$ | No. | Symbol | Parameter | Var | iable | $f_{\text{FPH}} = 3$ | 33 MHz | 1.114 | |------|-------------------|-------------------------------------------------------------------------------------------------|-----------|-----------|----------------------|--------|-------| | 110. | Symbol | 1 diameter | Min | Max | Min | Max | Unit | | 1 | t <sub>FPH</sub> | $f_{\text{FPH}} \text{ Period } (=x)$ | 30.3 | 31250 | 30.3 | | ns | | 2 | t <sub>AC</sub> | A0 to 23 Vaild $\rightarrow \overline{RD} / \overline{WR}$ Fall | x - 23 | | 7 | | ns | | 3 | t <sub>CAR</sub> | $\overline{RD}$ Rise $\rightarrow$ A0 to A23 Hold | 0.5x -13 | | 2 | | ns | | 4 | $t_{CAW}$ | $\overline{WR}$ Rise $\to$ A0 to A23 Hold | x – 13 | | 17 | | ns | | 5 | $t_{AD}$ | A0 to A23 Valid $\rightarrow$ D0 to D15 Input | | 3.5x - 24 | | 82 | ns | | 6 | t <sub>RD</sub> | RD Fall → D0 to D15 Input | | 2.5x - 24 | | 51 | ns | | 7 | t <sub>RR</sub> | RD Low Width | 2.5x - 15 | | 60 | | ns | | 8 | t <sub>HR</sub> | $\overline{RD}$ Rise $\rightarrow$ D0 to A15 Hold | 0 | | 0 | | ns | | 9 | $t_{WW}$ | WR Low Width | 2.0x - 15 | | 45 | | ns | | 10 | $t_{\mathrm{DW}}$ | D0 to D15 Valid $\rightarrow \overline{WR}$ Rise | 1.5x - 35 | | 10 | | ns | | 11 | $t_{\mathrm{WD}}$ | $\overline{\text{WR}}$ Rise $\rightarrow$ D0 to D15 Hold | x - 25 | | 5 | | ns | | 12 | $t_{AW}$ | A0 to A23 Valid $\rightarrow \overline{\text{WAIT}}$ Input <sup>(1WAIT+n)</sup> | | 3.5x - 60 | | 46 | ns | | 13 | t <sub>CW</sub> | $\overline{RD} / \overline{WR} \text{ Fall} \rightarrow \overline{WAIT} \text{ Hold}$ (1WAIT+n) | 2.5x + 0 | | 76 | | ns | | 14 | t <sub>APH</sub> | A0 to A23 Valid → PORT Input | | 3.5x - 89 | | 17 | ns | | 15 | t <sub>APH2</sub> | A0 to A23 Valid $\rightarrow$ PORT Hold | 3.5x | | 106 | | ns | | 16 | $t_{APO}$ | A0 to A23 Valid $\rightarrow$ PORT Valid | | 3.5x + 60 | | 166 | ns | ## AC Measuring Conditions • Output Level : High = 0.7 Vcc, Low = 0.3 Vcc, CL = 50 pF • Input Level : High = 0.9 Vcc, Low = 0.1 Vcc (note): Symbol " x " in the above table means the period of clock " $f_{FPH}$ ", it's half period of the system clock " $f_{SYS}$ " for CPU core. The period of $f_{FPH}$ depends on the clock gear setting or the selection of High / Low oscillator frequency. ### (2) $Vcc = 2.0 V \pm 10\%$ | No. | Symbol | Parameter | Var | iable | 10 | MHz | Unit | |-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------|-----|-----|-------| | NO. | Symbol | i arameter | Min | Max | Min | Max | Offic | | 1 | tFPH | $f_{FPH} Period (= x)$ | 100 | 31250 | 100 | | ns | | 2 | tAC | A0 to A15 Valid $\rightarrow \overline{RD} / \overline{WR}$ Fall | x -46 | | 54 | | ns | | 3 | tCAR | RD Rise → A0 to A23 Hold | 0.5x - 26 | | 24 | | ns | | 4 | tCAW | $\overline{\text{WR}}$ Rise $\rightarrow$ A0 to A23 Hold | x - 26 | | 74 | | ns | | 5 | tAD | A0 to A23 Valid $\rightarrow \overline{RD} / \overline{WR}$ Fall | | 3.5x - 48 | | 302 | ns | | 6 | tRD | RD Fall → D0 to D15 Input | | 2.5x - 48 | | 202 | ns | | 7 | tRR | RD Low Width | 2.5x - 30 | | 220 | | ns | | 8 | tHR | $\overline{\text{RD}}$ Rise $\rightarrow$ D0 to D15 Hold | 0 | | 0 | | ns | | 9 | tWW | WR Low Width | 2.0x - 30 | | 170 | | ns | | 10 | tDW | D0 to D15 Valid $\rightarrow \overline{WR}$ Rise | 1.5x - 70 | | 80 | | ns | | 11 | tWD | WR Rise →D0 to D15 Hold | x - 50 | | 50 | | ns | | 12 | tAW | A0 to A23 Valid $\rightarrow$ WAIT Input (1WAIT +n mode) | | 3.5x - 120 | | 230 | ns | | 13 | tCW | $\overline{\text{RD}} / \overline{\text{WR}} \text{ Fall} \rightarrow \overline{\text{WAIT}} \text{ Hold} \substack{\text{(1WAIT} \\ \text{+n mode)}}$ | 2.5x + 0 | | 250 | _ | ns | | 14 | tAPH | A0 to A23 Valid → PORT Input | | 3.5x - 50 | | 300 | ns | | 15 | tAPH2 | A0 to A23 Valid → PORT Hold | 3.5x | | 350 | _ | ns | | 16 | tAPO | A0 to A23 Valid → PORT Valid | | 3.5x + 60 | | 410 | ns | ## AC Measuring Conditions • Output Level: High = 0.7 V, Low = 0.3 V, CL = 50 pF • Input Level: High = 0.9 V, Low = 0.1 V (note): Symbol " x " in the above table means the period of clock " $f_{FPH}$ ", it's half period of the system clock " $f_{SYS}$ " for CPU core. The period of $f_{FPH}$ depends on the clock gear setting or the selection of High / Low oscillator frequency. # (1) Read Cycle # (2) Write Cycle # 4.4 A/D Conversion Characteristics AVcc = Vcc, AVss = Vss | Symbol | Parameter | Condition | Min | Typ. | Max | Unit | |----------------------|------------------------------------------------|--------------------------------------------|--------------------------|-------|-------------|------| | VREFH | Analas Defenens Valtars (1) | $V_{CC} = 3 \text{ V} \pm 10\%$ | $V_{CC} - 0.2 \text{ V}$ | Vcc | Vcc | | | VKEFH | Analog Reference Voltage (+) | $V_{CC} = 2 V \pm 10\%$ | $V_{CC}$ | Vcc | Vcc | V | | VREFL | Analog Reference Voltage (–) | $V_{CC} = 3 V \pm 10\%$ | $V_{SS}$ | Vss | Vss + 0.2 V | · | | VKEFL | Analog Reference Voltage (-) | $V_{CC} = 2 V \pm 10\%$ | $V_{SS}$ | Vss | Vss | | | VAIN | Analog Input Voltage Range | | $V_{REFL}$ | | $V_{REFH}$ | | | | Analog Current for Analog<br>Reference Voltage | $V_{CC} = 3 V \pm 10\%$ | | 0.94 | 1.20 | | | IREF<br>(VREFL = 0V) | <vrefon> = 1</vrefon> | $V_{CC} = 2 V \pm 10\%$ | | 0.65 | 0.90 | mA | | (1222 01) | <VREFON $>$ = 0 | $V_{CC} = 1.8 \text{ V to } 3.3 \text{ V}$ | | 0.02 | 5.0 | μΑ | | | Error | $V_{CC} = 3 V \pm 10\%$ | | ± 1.0 | ± 4.0 | I ab | | = | (not including quantizing errors) | $V_{CC} = 2 V \pm 10\%$ | | ± 1.0 | ± 4.0 | LSB | (note1): 1 LSB = (VREFH - VREFL)/1024 [V] (note2): The operation above is guaranteed for $f_{\mbox{\scriptsize FPH}}\!\geq\!4\mbox{\ MHz}.$ (note3): The value for $I_{\mbox{\footnotesize{CC}}}$ includes the current which flows through the $AV_{\mbox{\footnotesize{CC}}}$ pin. # 4.5 Serial Channel Timing (I/O Internal Mode) ## (1) SCLK Input Mode | Symbol | Daram | neter | Variable | ) | 10 M | IHz | 27 N | 1Hz | Unit | |------------------|-------------------------------|-----------------------------------|------------------------|---------------|------|------|------|-----|------| | Symbol | 1 ar arr | Parameter Min | | Max | Min | Max | Min | Max | Om | | T <sub>SCY</sub> | SCLK Period | | 16X | | 1.6 | | 0.59 | | μs | | $T_{OSS}$ | Output Data<br>→SCLK | Vcc=3V ± 10% | $t_{SCY}/2 - 4X - 110$ | | 290 | | 38 | | ns | | 1 088 | Rising/Falling<br>Edge* | Vcc=2V ± 10% | $t_{SCY}/2 - 4X - 180$ | | 220 | | | | ns | | $T_{OHS}$ | SCLK Rising/F $\rightarrow$ O | Falling Edge*<br>Output Data Hold | $t_{SCY}/2 + 2X + 0$ | | 1000 | | 370 | | ns | | T <sub>HSR</sub> | SCLK Rising/F → I | Falling Edge* Input Data Hold | 3X + 10 | | 310 | | 121 | | ns | | T <sub>SRD</sub> | SCLK Rising/F → V | Falling Edge*<br>Valid Data Input | | $t_{SCY} - 0$ | | 1600 | | 592 | ns | | $T_{RDS}$ | Valid Data<br>SCLK Rising/F | - | 0 | | 0 | | 0 | | ns | ## (2) SCLK Output Mode | Symbol | Parameter | Varia | able | 10 M | IHz | 27 N | 1Hz | Unit | |------------------|---------------------------------------------------------|------------------|---------------------------|------|------|------|-----|------| | Symbol | r ai ainetei | Min | Max | Min | Max | Min | Max | Om | | T <sub>SCY</sub> | SCLK Period | 16X | 8192X | 1.6 | 819 | 0.59 | 303 | μs | | T <sub>OSS</sub> | Output Data $\rightarrow$ SCLK Rising /Falling Edge* | $t_{SCY}/2 - 40$ | | 760 | | 256 | | ns | | T <sub>OHS</sub> | SCLK Rising/Falling Edge* → Output Data Hold | $t_{SCY}/2 - 40$ | | 760 | | 256 | | ns | | T <sub>HSR</sub> | SCLK Rising/Falling Edge* $\rightarrow$ Input Data Hold | 0 | | 0 | | 0 | | ns | | T <sub>SRD</sub> | SCLK Rising/Falling Edge* → Valid Data Input | | t <sub>SCY</sub> -1X -180 | | 1320 | | 375 | ns | | $T_{RDS}$ | Valid Data Input → SCLK Rising/Falling Edge* | 1X + 180 | | 280 | | 217 | | ns | (note): SCLK Rinsing/Falling Edge: The rising edge is used in SCLK Rising Mode. The falling edge is used in SCLK Falling Mode. 27MHz and 10MHz values are calculated from $t_{SCY}$ =16X case. # 4.6 Event Counter (TA0IN) | Cymah al | Parameter | Varia | 10 M | ИHz | 27 MHz | | Unit | | |-------------------|------------------------|----------|------|-----|--------|-----|------|-----| | Symbol | rarameter | Min | Max | Min | Max | Min | Max | Omi | | t <sub>VCK</sub> | Clock Period | 8X + 100 | | 900 | | 396 | | ns | | t <sub>VCKL</sub> | Clock Low Level Width | 4X + 40 | | 440 | | 188 | | ns | | t <sub>VCKH</sub> | Clock High Level Width | 4X + 40 | | 440 | | 188 | | ns | # 4.7 Interrupt, Capture # (1) $\overline{\text{NMI}}$ , INT0 to INT3 Interrupts | | Parameter | Varia | able | 10 N | ИHz | 27 N | ИHz | Unit | |--------------------|------------------------------------|---------|------|------|-----|------|-----|------| | Symbol | Parameter | Min | Max | Min | Max | Min | Max | Cint | | t <sub>INTAL</sub> | NMI , INTO to INT3 Low level width | 4X + 40 | | 440 | | 188 | | ns | | t <sub>INTAH</sub> | NMI, INTO to INT3 High level width | 4X + 40 | | 440 | | 188 | | ns | **TOSHIBA** ### 4.8 SCOUT Pin AC Characteristics | Cumbal | Daramatar | Variable | | 4 MHz | | 16 N | MHz | Condition | Unit | |------------------|-------------------|-------------------|--|-------|-----|------|-----|-------------|-------| | Symbol | Farameter | Parameter Min Max | | Min | Max | Min | Max | Colldition | Oilit | | tagy | Low level Width | 0.5T - 10 | | 90 | | 27 | | Vcc 2.7 V | ns | | t <sub>SCH</sub> | Low level width | 0.5T - 30 | | 70 | | - | | Vcc < 2.7 V | 115 | | t <sub>SCL</sub> | High level Width | 0.5T - 10 | | 90 | | 27 | | Vcc 2.7 V | ns | | SCL | ingii ievei widdi | 0.5T - 30 | | 70 | | - | | Vcc < 2.7 V | 113 | Note: T = Period of SCOUT **Measuring Conditions** • Output Level: High = 0.7 V, Low = 0.3 V, CL = 10 pF ## 4.9 Bus Request/Bus Acknowledge | Symbol | Parameter | Variable | | $f_{\text{FPH}} = 4 \text{ MHz}$ | | f <sub>FPH</sub> = | Unit | | |-----------|--------------------------------|----------|-----|----------------------------------|-----|--------------------|------|------| | Symbol | Parameter | | Max | Min | Max | Min | Max | Oint | | $t_{ABA}$ | Output Buffer Off to BUSAK Low | 0 | 80 | 0 | 80 | 0 | 80 | ns | | $t_{BAA}$ | BUSAK High to Output Buffer On | 0 | 80 | 0 | 80 | 0 | 80 | ns | Note 1: Even if the $\overline{\text{BUSRQ}}$ Signal foes Low, the bus will not be released while the $\overline{\text{WAIT}}$ signal is Low. The bus will only be released when $\overline{\text{BUSRQ}}$ goes Low while $\overline{\text{WAIT}}$ is High. Note 2: This line shows only that the output buffer is in the off state. It does not indicate that the signal level is fixed. Just after the bus is released, the signal level set before the bus was released is maintained dynamically by the external capacitance. Therefore, to fix the signal level using an external resister during bus release, careful design is necessary, since fixing of the level is delayed. The internal programmable pull-up/pull-down resistor is switched between the Active and Non-Active states by the internal signal. TOSHIBA # 4.10 Recommended Crystal Oscillation Circuit TMP91C824 is evaluated by below oscillator vender. When selecting external parts, make use of this information.. (note): Total loads value of oscillator is sum of external loads(C1 and C2) and floating loads of actual assemble board. There is a possibility of miss-operating using C1 and C2 value in below table. When designing board, it should design minimum length pattern around oscillator. And we recommend that oscillator evaluation try on your actual using board. ### (1) Connection example High frequency oscillator Low frequency oscillator ## (2) TMP91C824F recommended ceramic oscillator: MURATA co. LTD; JAPAN Circuit parameter recommended | MCU | Oscillation | | | Running Condition | | | | | |--------------|--------------------|--------------------------------------|------------|-------------------|-----------|-----------|----------------------------|------------| | | Frequency<br>[MHZ] | Item of Oscillator | C1<br>[pF] | C2<br>[pF] | Rf<br>[ ] | Rd<br>[ ] | Voltage<br>of Power<br>[V] | Tc [ ] | | | 2.00M | CSTLS2M00G56-B0 | (47) | (47) | Open | 0 | | | | | 2.50M | CSTLS2M50G56-B0 | (47) | (47) | Open | 0 | | | | TMP91C824 | 10.00M | CSTS1000MG03<br>*CSTLS10M0G53-B0 | (15) | (15) | Open | 0 | 1.8 to 2.2 | -40 to +85 | | 1311 91 0024 | | CSA12.5MTZ093<br>*CSALA12M5T55093-B0 | 30 | 30 | Open | 0 | 1.0 to 2.2 | | | | 12.50M | CST12.0MTW093<br>*CSTLA12M5T55093-B0 | (30) | (30) | Open | 0 | | | | MCU | Oscillation | | P | aramete | r of eler | nents | Running ( | Condition | |-----------|--------------------|----------------------------------|------------|------------|-----------|-----------|----------------------------|------------| | | Frequency<br>[MHZ] | Item of Oscillator | C1<br>[pF] | C2<br>[pF] | Rf<br>[ ] | Rd<br>[ ] | Voltage<br>of Power<br>[V] | Tc [ ] | | | 4.00M | CSTS0400MG06<br>*CSTLS4M00G56-B0 | (47) | (47) | Open | 0 | | | | | 6.750M | CSTS0675MG06<br>*CSTLS6M75G56-B0 | (47) | (47) | Open | 0 | | | | | 12.50M | CSA12.5MTZ<br>*CSALA12M5T55-B0 | 30 | 30 | Open | 0 | | -40 to +85 | | TMP91C824 | 12.50M | CST12.0MTW<br>*CSTLA12M5T55-B0 | (30) | (30) | Open | 0 | 2.7 to 3.6 | -40 10 +83 | | | 20.0014 | CSALS20M0X53-B0 | 5 | 5 | Open | 0 | | | | | 20.00M | CSTLS20M0X51-B0 | (5) | (5) | Open | 0 | | | | | 27.00M | CSALS27M0X51-B0 | Open | Open | 10K | 0 | | | | | 32.00M | CSALA32M0X51-B0 | 3 | 3 | Open | 0 | | | NOTE: In CST \*\*\*type oscillator, Capacitance C1,C2 is built in <sup>\*</sup>After 2001/06,new products will be made, and the old products(now in production) will not be made in MURATA Co LTD ,JAPAN <sup>\*</sup>The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are being changed as occasion arises. For details, visit the company's home page at http://www.murata.co.jp/search/index.html TOSHIBA TMP91C824 #### 5. Table of SFRs (SFR; special function register) The SFRs include the I/O ports and peripheral control registers allocated to the 4K bytes address space from 000000H to 000FFFH. - (1) I/O Port - (2) I/O Port Control - (3) Interrupt Control - (4) Chip Select / Wait Control - (5) Clock Gear - (6) DFM (Clock Doubler) - (7) 8-bit Timer - (8) UART/Serial Channel - (9) I<sup>2</sup>CBUS/Serial Channel - (10) A/D Converter - (11) Watchdog Timer - (12) RTC (Real-Time Clock) - (13) Melody/Alarm Generator - (14) MMU ## Table layout Note: "Prohibit RMW" in the table means that you cannot use RMW instructions on these register. Example: When setting bit0 only of the registerP0CR, the instruction "SET 0, (0002G)" cannot be used. The LD (transfer) instruction must be used to write all eight bits. #### Read/Write R/W; Both read and write are possible. R; Only read is possible. W; Only write is possible. W\*; Both read and write are possible (when this bit is read as1) Prohibit RMW; Read-Modify-Write instructions are prohibited. (The EX, ADD, ADC, BUS, SBC, INC, DEC, AND, OR, XOR, STCF, RES, SET, CHG, TEST, RLC, RRC, RL, RR, SLA, SRA, SLL, SRL, RLD and RRD instruction are read-modify-write instructions.) Prohibit RMW\*; Read-modify-write instructions are prohibited when controlling the pull-up resistor. TOSHIBA TMP91C824 Table 5.1 Address map SFRs [1], [2] PORT | Address | Name | |---------|---------------| | 0000H | - 1,,,,,,,,,, | | 1H | P1 | | 2H | | | 3H | | | 4H | P1CR | | 5H | | | 6H | P2 | | 7H | | | 8H | | | 9H | P2FC | | AH | P5CR | | BH | P5FC | | CH | | | DH | P5 | | EH | | | FH | | | Address | Name | |---------|-------| | 0010H | | | 1H | | | 2H | P6 | | 3H | P7 | | 4H | | | 5H | P6FC | | 6H | P7CR | | 7H | P7FC | | 8H | P8 | | 9H | | | AH | | | BH | P6FC | | CH | P7CR | | DH | | | EH | | | FH | P7ODE | | Address | Name | |---------|-------| | 0022H | | | 1H | | | 2H | PB | | 3H | PC | | 4H | PBCR | | 5H | PBFC | | 6H | PCCR | | 7H | PCFC | | 8H | PCODE | | 9H | PD | | AH | PDFC | | ВН | | | CH | | | DH | | | EH | | | FH | | Address Name 0070H 1H 2H 3H 4H 5H 6H 7H 8H 9H AH BH CH DH PZ EH PZCR FH PZFC | [3] INTC | | |----------|--------| | Address | Name | | H0800 | DMA0V | | 1H | DMA1V | | 2H | DMA2V | | 3H | DMA3V | | 4H | | | 5H | | | 6H | | | 7H | | | 8H | INTCLR | | 9H | DMAR | | AH | DMAB | | BH | | | CH | IIMC | | DH | | | EH | | | FH | | | Address | Name | | |---------|-----------|--| | 0090H | INTE0AD | | | 1H | INTE12 | | | 2H | INTE3ALM4 | | | 3H | INTEALM01 | | | 4H | INTEALM23 | | | 5H | INTETA01 | | | 6H | INTETA23 | | | 7H | INTERTC | | | 8H | INTES0 | | | 9H | INTES1 | | | AH | INTES2 | | | BH | INTETC01 | | | CH | INTETC23 | | | DH | INTEP01 | | | EH | | | | FH | | | [4] CS/WAIT | Name | |-------| | B0CS | | B1CS | | B2CS | | B3CS | | | | | | | | BEXCS | | MSAR0 | | MAMR0 | | MSAR1 | | MAMR1 | | MSAR2 | | MAMR2 | | MSAR3 | | MAMR3 | | | [5], [6] CGEAR,DFM | Address | Name | |---------|--------| | 00E0H | SYSCR0 | | 1H | SYSCR1 | | 2H | SYSCR2 | | 3H | SYSCR0 | | 4H | SYSCR1 | | 5H | SYSCR2 | | 6H | SYSCR3 | | 7H | | | 8H | DFMCR0 | | 9H | DFMCR1 | | AH | | | ВН | | | CH | | | DH | | | EH | | | FH | | Note: Do not access to the unnamed addresses, i.e. addresses to which no register has been allocated. Table 5.2 Address map SFRs [7] TMRA | Address | Name | |---------|----------| | 0100H | TA01RUN | | 1H | | | 2H | TA0REG | | 3H | TA1REG | | 4H | TA01MOD | | 5H | TA01FFCR | | 6H | | | 7H | | | 8H | TA23RUN | | 9H | | | AH | TA2REG | | BH | TA3REG | | CH | TA23MOD | | DH | TA3FFCR | | EH | | | FH | | # [8] UART/SIO | Address | Name | |---------|---------| | 0200H | SC0BUF | | 1H | SC0CR | | 2H | SC0MOD0 | | 3H | BR0CR | | 4H | BR0ADD | | 5H | SCMOD1 | | 6H | | | 7H | SIRCR | | 8H | SC1BUF | | 9H | SC1CR | | AH | SC1MOD0 | | BH | BR1CR | | CH | BR1ADD | | | | SC1MOD1 [9] I2CBUS/SIO | Address | Name | |---------|----------------| | 0240H | SBI0CR1 | | 1H | SBI0DBR | | 2H | I2C0AR | | 3H | SBI0CR2/SBI0SR | | 4H | SBI0BR0 | | 5H | SBI0BR1 | | 6H | | | 7H | | | 8H | | | 9H | | | AH | | | BH | | | СН | | | DH | | | EH | | | FH | | [10] 10bit ADC DH EH FH | Address | Name | |---------|----------| | 02A0H | ADREG04L | | 1H | ADREG04H | | 2H | ADREG15L | | 3H | ADREG15H | | 4H | ADREG26L | | 5H | ADREG26H | | 6H | ADREG37L | | 7H | ADREG37H | | 8H | | | 9H | | | AH | | | BH | | | СН | | | DH | | | EH | | | FH | | | Address | Name | |---------|--------| | 02B0H | ADMOD0 | | 1H | ADMOD1 | | 2H | | | 3H | | | 4H | | | 5H | | | 6H | | | 7H | | | 8H | | | 9H | | | AH | | | ВН | | | CH | | | DH | | | EH | | | FH | | Note: Do not access to the unnamed addresses, i.e. addresses to which no register has been allocated. Table 5.3 Address map SFRs [11] WDT [12] RTC | Address | Name | Address | Name | |---------|-------|---------|--------| | 0300H | WDMOD | 0320H | SECR | | 1H | WDCR | 1H | MINR | | 2H | | 2H | HOURR | | 3H | | 3H | DAYR | | 4H | | 4H | DATER | | 5H | | 5H | MONTHR | | 6H | | 6H | YEWRR | | 7H | | 7H | PAGER | | 8H | | 8H | RESTR | | 9H | | 9H | | | AH | | AH | | | BH | | BH | | | CH | | СН | | | DH | | DH | | | EH | | EH | | | FH | | FH | | [13] MLD [13] MMU | Address | Name | Address | Name | |---------|---------|---------|--------| | 0330H | ALM | 0350H | LOCAL0 | | 1H | MELALMC | 1H | LOCAL1 | | 2H | MELFL | 2H | LOCAL2 | | 3H | MELFH | 3H | LOCAL3 | | 4H | ALMINT | 4H | | | 5H | | 5H | | | 6H | | 6H | | | 7H | | 7H | | | 8H | | 8H | | | 9H | | 9H | | | AH | | AH | | | BH | | BH | | | СН | | СН | | | DH | | DH | | | EH | | EH | | | FH | | FH | | Note: Do not access to the unnamed addresses, i.e. addresses to which no register has been allocated. (1) I/O Ports | P1 PORT1 01H | | l / O I OILS | | | I | ı | | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------|---------|-----|-----|-----|-------|----------|-------|------|-----| | PORTI OIH | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | P1 PORT1 01H 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | P17 | P16 | P15 | | • | P12 | P11 | P10 | | P2 PORT2 | P1 | PORT1 | 01H | | 1 | | | | | • | | | P2 PORT2 O6H | | | | 0 | 0 | 0 | | | 0 | 0 | 0 | | PORT | | | | | | | | | | | | | P2 PORT2 06H | | | | P27 | P26 | P25 | | | P22 | P21 | P20 | | Port | | | | | | | | • | | • | • | | PS PORTS ODH | P2 | PORT2 | 06H | 1 | | | | | | | | | P5 PORTS ODH | | | | | | | Input | Mode | | | | | P5 PORTS ODH | | | | | | | | | Input | Mode | | | PS PORTS ODH | | | | | P56 | | P54 | | | | | | Port | P5 | PORT5 | 0DH | | | | | | | | | | P6 PORT6 | | | | | | | | | | | | | P6 PORT6 12H | | | | | | | | <u> </u> | | | | | PORTO PORTO 13H | | | | P67 | P66 | P65 | | | P62 | P61 | P60 | | P7 PORT7 13H | P6 | PORT6 | 12H | | | | R/ | /W | | | | | P7 PORT7 13H | | | | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | P7 PORT7 13H | | | | | | | | | P72 | P71 | P70 | | P8 PORT8 18H | P7 | P7 PORT7 13H | 13H | | | | R | W | | | | | P8 PORT8 18H | 1 / | TORTY | 1311 | | | | | | 1 | 1 | 1 | | PORTS | | | | | | | Input | Mode | | | | | PB | | | | | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | PB PORTB 22H | P8 | PORT8 | 18H | | | | I | R | | | | | PB PORTB 22H | | | | | | | | | | | | | PB PORTB 22H | | | | | PB6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | | PC PORTC 23H | PR | PORTR | 2211 | | | | R/ | W . | | | | | PC PORTC 23H | 1 1 | TOKID | 2211 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | PC PORTC 23H R/W I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I | | | | | | | Input | Mode | | | | | PC PORTC 23H | | | | | | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | | PD PORTD 29H PD7 PD6 PD5 R/W 1 1 1 1 1 1 1 1 1 PZ PORTZ 7DH PD7 PD6 PD5 R/W 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | DC. | DODTC | 2211 | | | | | R/ | W | | | | PD PORTD 29H PD7 PD6 PD5 R/W 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | rC | FURIC | 23П | | | 1 | 1 | 1 | 1 | 1 | 1 | | PD PORTD 29H R/W 1 1 1 1 PZ PORTZ 7DH PZ3 PZ2 RDE R/W R/W R/W R/W R/W | | | | | | | | Input 1 | Mode | | | | PD PORTD 29H R/W 1 1 1 1 PZ PORTZ 7DH PZ3 PZ2 RDE R/W R/W R/W R/W R/W | | | | PD7 | PD6 | PD5 | | | | | | | PZ PORTZ 7DH PZ3 PZ2 RDE R/W R/W | PD | PORTD | 29H | | | | R | /W | | | | | PZ PORTZ 7DH R/W R/W | | | | 1 | 1 | 1 | | | | | | | PZ PORTZ 7DH R/W R/W | | | | | | | | PZ3 | PZ2 | | RDE | | | PZ | PORTZ | 7DH | | | | | R/W | | | | | | | | | | | | | 1 | 1 | | 1 | ## (2) I/O Port Control (1/2) | | | | | | | - | | | | - | |--------|-----------|-------------------|------------------|------------------|------------------|------------------|-----------------|------------------|------------------|---------------| | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 04H | P17C | P16C | P15C | P14C | P13C | P12C | P11C | P10C | | P1CR | PORT1 | (Prohibit | | | | V | V | | | | | TICK | Control | RWM) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | K W WI) | | | | 0: IN | 1: OUT | | | | | | | 0011 | P27F | P26F | P25F | P24F | P23F | P22F | P21F | P20F | | P2FC | PORT2 | 09H | | | | 7 | V | | | | | PZFC | Function | (Prohibit<br>RWM) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | K W WI) | | | 0: Po | ort, 1:Address | s bus (A23 to . | A16) | | | | | | 0.4.11 | | P56C | P55C | P54C | | | | | | P5CR | PORT5 | 0AH<br>(Prohibit | | | | V | V | | | | | 1 JCK | Control | RWM) | | 0 | 0 | 0 | | | | | | | | KWW) | | | | 0 : IN | 1:OUT | | | | | | | 0BH | | | P55F | P54F | | | | | | | PORT5 | υвп | | | | V | V | | | | | P5FC | Function | (Prohibit | | | 0 | 0 | | | | | | | Tunction | RWM) | | | 0: PORT | 0: PORT | | | | | | | | 11,,1,1, | | | 1:BUSAK | 1: BUSRQ | | | | | | | | 1511 | | | P65F | P64F | P63F | P62F | P61F | P60F | | | PORT6 | 15H | | | | | V | V | | | | P6FC | Function | (Prohibit | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Tunction | RWM) | A leviavia | rrmita O | 0: PORT | 0: PORT | 0: PORT | 0: PORT | 0: PORT | 0: PORT | | | | . , | Always | write 0 | 1: EA25 | 1: EA24 | 1: /CS3 | 1: /CS2 | 1: /CS1 | 1:/CS0 | | | | | P67F2 | P66F2 | P65F2 | P64F2 | | P62F2 | | | | | | 1BH | | V | V | | | W | | | | P6FC2 | PORT6 | | | ( | ) | | | 0 | | | | | Function2 | (Prohibit | 0: <p67f></p67f> | 0: <p66f></p66f> | 0: <p65f></p65f> | 0: <p64f></p64f> | Always write | 0: <p62f></p62f> | | | | | | RWM) | 1:/CS2E | 1: /CS2D | 1:/CS2C | 1: /CS2B | 0 | 1: /CS2A | Always | write 0 | | | | | 1.7002E | 1.70020 | | | Ů | | | | | | | 16H | | | | | | P72C | P71C | P70C | | P7CR | PORT7 | (Prohibit | | | | | V | | | | | 0.1. | Control | RWM) | | | | | | 0 | 0 | 0 | | | | , | | | | 0 : IN | 1 : OUT | | | | | | | 17H | | | | | | P72F | P71F | P70F | | | PORT7 | | | | | | V | | | | | P7FC | Function | | | | | | | 0 | 0 | 0 | | | | (Prohibit | | | | | | 0: PORT | 0: PORT | 0: PORT | | | | RWM) | | | | | | 1: SCL | 1: SDA/SO | 1: SCK | | | | 1CH | | | | | | P72F2 | P71F2 | P70F2 | | | | 1011 | | | | | V | | | | | P7FC2 | PORT7 | | | | | | | 0 | 0 | 0 | | | Function2 | (Prohibit | | | | | | | 0: <p71f></p71f> | PIN SELECT | | | | RWM) | | | | | | | 1: OPTTX0 | 0: RXD0(PC1) | | | | | | | | | | | 01 11110 | 1: PTRX0(P70) | # I/O Port Control (2/2) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2. | 1 | 0 | | | | | | |--------|-------------------------|-----------------------|---------|-----------|-----------|---------|---------|----------|-----------|---------|--|-------|--------|--|--| | | | | | | | | | ODEP72 | ODEP71 | | | | | | | | | PORT7 | 1FH | | | | | | | W | | | | | | | | P7ODE | Open | | | | | | | 0 | 0 | | | | | | | | | Drain | (Prohibit | | | | | | | TATE | | | | | | | | | | RWM) | | | | | | | n Drain | | | | | | | | | | | | PR6C | PB5C | PB4C | PB3C | PB2C | PB1C | PR0C | | | | | | | | PORTB | 24H | | T TAK | T T T X | V | | 111/4 | | TINK | | | | | | | PBCR | Control | (Prohibit | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | RWM) | | | | 0: IN | 1: OUT | | | | | | | | | | | | 2511 | | PR6F | PR5F | PR4F | PR3F | PR2F | PR1F | | | | | | | | | DODED | 25H | | W | W | W | W | W | W | | | | | | | | PBFC | PORTB | /D 1.11.4 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | Function | (Prohibit | | 0: PORT | 0: PORT | 0: PORT | 0: PORT | 0: PORT | 0: PORT | | | | | | | | | | RWM) | | 1: INT3 | 1: INT2 | 1: INT1 | 1: INT0 | 1:TA3OUT | 1: TA1OUT | | | | | | | | | | 26H | | | PC5C | PC4C | PC3C | PC2C | PC1C | PC0C | | | | | | | PCCR | PORTC | (Prohibit | | | | V | V | | | | | | | | | | FCCK | Control | RWM) | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | K W WI) | | | | 0: IN | 1: OUT | | | | | | | | | | | | 27H | | | PC5F | | PC3F | PC2F | | PC0F | | | | | | | | PORTC | 2/11 | | | W | | W | W | | W | | | | | | | PCFC | | | | | 0 | | 0 | 0 | | 0 | | | | | | | | Function | RWM) | | | 0: PORT | | 0: PORT | 0: PORT | | 0: PORT | | | | | | | | | 10,1111) | | | 1 : SCLK1 | | 1: TXD1 | 1:SCLK0 | | 1: TXD0 | | | | | | | | | | | | | | ODEPC3 | | | ODEPC0 | | | | | | | | PORTC | 28H | | | | | W | | | W | | | | | | | PCODE | Open | | | | | | 0 | | | 0 | | | | | | | TCODE | Drain | (Prohibit | | | | | 0: CMOS | | | 0: CMOS | | | | | | | | Dium | RWM) | | | | | 1:Open | | | 1:Open | | | | | | | | | | | | | | Drain | | | Drain | | | | | | | | | | PD7F | PD6F | PD5F | | | | | | | | | | | | | | 2AH | W | W | W | | | | | | | | | | | | PDFC | PORTD | | 0 | 0 | 0 | | | | | | | | | | | | | Function | (Prohibit | 0: PORT | 0: PORT | 0: PORT | | | | | | | | | | | | | | RWM) | | 1: /ALARM | | | | | | | | | | | | | | | 7011 | | | | | D72C | D72C | | | | | | | | | | DODTT | 7DH | | | | | | PZ2C | | | | | | | | | PZCR | PORTZ Control (Brobibit | | | | | | V | | | | | | | | | | | | (Prohibit | | | | | 0 | 0 | | | | | | | | | | RMW) | | | | | | 1:OUT | | | | | | | | | | | | | | | | PZ3F | PZ2F | | | | | | | | | | | PORTZ | ,,,,, | | | | | V | V | | | | | | | | | PZFC | | (Prohibit | | | | | 0 | 0 | | | | | | | | | | Function | nction (Prohibit RMW) | | | | | 0:PORT | 0:PORT | | | | | | | | | | | | | | | | | | | | | 1:R/W | 1:/HWR | | | (3) Interrupt Control (1/3) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------|-----------|-------------|----------------|--------|---------------------|--------|----------------|----------|---------------------|--------| | Symeor | Titalio | Tradress | | | rad | | | IN | | Ů | | INTE- | Interrupt | 90H | IADC | IADM2 | IADM1 | IADM0 | I0C | IOM2 | IOM1 | I0M0 | | 0AD | Enable | <b>7011</b> | R | | R/W | | R | | R/W | | | | 0 & A/D | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTAD | | Interrupt leve | el | 1: INT0 | ] | Interrupt leve | 1 | | | | | | IN | T2 | | | IN | T1 | | | INTE12 | Interrupt | 91H | I2C | I2M2 | I2M1 | I2M0 | I1C | I1M2 | I1M1 | I1M0 | | | Enable | | R | | R/W | | R | | R/W | | | | 2/1 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INT2 | | Interrupt leve | el | 1: INT1 | ] | Interrupt leve | 1 | | | | | | INTA | ALM4 | | | IN | T3 | | | INTE3-A | Interrupt | 92H | IA4C | IA4M2 | IA4M1 | IA4M0 | I3C | I3M2 | I3M1 | I3M0 | | LM4 | Enable | | R | | R/W | | R | | R/W | | | | 3 & ALM4 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1:INTALM4 | | Interrupt leve | el | 1: INT3 | ] | Interrupt leve | 1 | | | | | | INTA | ALM1 | - | | INTA | LM0 | | | INTE-A | Interrupt | 93H | IA1C | IA1M2 | IA1M1 | IA1M0 | IA0C | IA0M2 | IA0M1 | IA0M0 | | LM01 | Enable | | R | | R/W | | R | | R/W | | | | ALM0/1 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1:INTALM1 | | Interrupt leve | el | 1:INTALM0 | | Interrupt leve | l | | | | | INTALM3 | | | | | INTA | LM2 | | | INTE-A | Interrupt | 94H | IA3C | IA3M2 | IA3M1 | IA3M0 | IA2C | IA2M2 | IA2M1 | IA2M0 | | LM23 | Enable | | R | | R/W | | R | | R/W | | | | ALM2/3 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1:INTALM3 | | Interrupt leve | el | 1:INTALM2 | ] | Interrupt leve | 1 | | | Interrupt | | | | (TMRA1) | • | | INTTA0 ( | (TMRA0) | | | INTE- | Enable | 95H | ITA1C | ITA1M2 | ITA1M1 | ITA1M0 | ITA0C | ITA0M2 | ITA0M1 | ITA0M0 | | TA01 | Timer A | | R | | R/W | | R | | R/W | | | | 1/0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTTA1 | | Interrupt leve | el | 1: INTTA0 | | Interrupt leve | l | | | Interrupt | | | | (TMRA5) | T | | INTTA2 ( | | | | INTE- | Enable | 96H | ITA3C | ITA3M2 | ITA3M1 | ITA3M0 | ITA2C | ITA2M2 | ITA2M1 | ITA2M0 | | TA23 | Timer A | | R | 0 | R/W | 1 0 | R | 0 | R/W | | | | 3/2 | | 0<br>1: INTTA3 | 0 | 0<br>Interrupt leve | 0 | 0<br>1: INTTA2 | 0 | 0<br>Interrupt leve | 0 | | | | | 1. IIVI IA3 | | mierrupt ieve | -1 | 1. IIN1 1A2 | | - | 1 | | INITE DE | Interrupt | 0.5** | | | | | IDC | INT | IRM1 | IDMO | | INTE-RT<br>C | Enable | 97H | | | I | 1 | IRC<br>R | IRM2 | | IRM0 | | | RTC & | | | | • | 1 | 0 | 0 | R/W<br>0 | 0 | | | KEY | | | | | 1 | 1: INTRTC | | nterrupt level | • | | | | | 1 | | | | 1; INTRIC | ı | merrupt ievel | | (3) Interrupt Control (2/3) | (3 | / | · · · · · · · · · · · · · · · · · · · | Ontrol (2/3) | <u></u> | | | | | | | |---------|---------------------|---------------------------------------|--------------|---------|----------------|--------|-----------|--------|----------------|--------| | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | INT | TX0 | | | INT | RX0 | | | INTES0 | Interrupt | 98H | ITX0C | ITX0M2 | ITX0M1 | ITX0M0 | IRX0C | IRX0M2 | IRX0M1 | IRX0M0 | | | Enable | | R | | R/W | | R | | R/W | | | | Serial 0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: INTTX0 | | Interrupt leve | 1 | 1: INTRX0 | | Interrupt leve | 1 | | | | | | INT | TX1 | | | INT | RX1 | | | INTES1 | Interrupt | 99H | ITX1C | ITX1M2 | ITX1M1 | ITX1M0 | IRX1C | IRX1M2 | IRX1M1 | IRX1M0 | | | Enable | | R | | R/W | | R | | R/W | | | | Serial 1 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1:INTTX1 | | Interrupt leve | 1 | 1:INTRX1 | | Interrupt leve | 1 | | | Intomont | | | | | | | IN | ΓS2 | | | | Interrupt<br>Enable | 9AH | | | | | IS2C | IS2M2 | IS2M1 | IS2M0 | | INTES2 | Serial 2 | | | | | | R | | R/W | | | | /LCD | | | | | | 0 | 0 | 0 | 0 | | | 7202 | | | | | | 1:INTS2 | | Interrupt leve | 1 | | | Interrupt | | | INTTC1 | | | | INT | TC0 | | | INTETC- | Enable | 9BH | ITC1C | ITC1M2 | ITC1M1 | ITC1M0 | ITC0C | ITC0M2 | ITC0M1 | ITC0M0 | | 01 | TC0/1 | | R | | R/W | | R | | R/W | | | | 100/1 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Interrupt | | | INT | TC3 | | | ITC | 2M0 | | | INTETC- | Enable | 9CH | ITC3C | ITC3M2 | ITC3M1 | ITC3M0 | ITC2C | ITC2M2 | ITC2M1 | ITC2M0 | | 23 | TC2/3 | | R | | R/W | | R | | R/W | _ | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Interrupt | | | IN | ГР1 | _ | | IP0 | M0 | | | INTEP01 | Enable | 9DH | IP1C | IP1M2 | IP1M1 | IP1M0 | IP0C | IP0M2 | IP0M1 | IP0M0 | | | Enable PC0/1 | | R | | R/W | | R | | R/W | | | | - 05,1 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | (3) Interrupt Control (3/3) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------------------|-----------|---------|---|------------|---------------|-----------------|----------------|-----------------|--------------| | | | | | | DMA0V5 | DMA0V4 | DMA0V3 | DMA0V2 | DMA0V1 | DMA0V0 | | DMA0 | DMA 0 | 80H | | | | | R/ | W | • | • | | V | Request<br>Vector | 80H | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Vector | | | | | | DMA0 Sta | art vector | | | | | D14.1 | | | | DMA1V5 | DMA1V4 | DMA1V3 | DMA1V2 | DMA1V1 | DMA1V0 | | DMA1 | DMA 1 | 81H | | | | | R/ | W | | | | V | Request<br>Vector | отп | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Vector | | | | | | DMA1 Sta | art vector | | | | | DMAA | | | | DMA2V5 | DMA2V4 | DMA2V3 | DMA2V2 | DMA2V1 | DMA2V0 | | DMA2 | DMA 2<br>Request | 82H | | | | | R/ | W | | | | V | Vector | 62H | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Vector | | | | | | DMA2 Sta | art vector | | | | | DMA 2 | | | | DMA3V5 | DMA3V4 | DMA3V3 | DMA3V2 | DMA3V1 | DMA3V0 | | DMA3 | DMA 3 | 9211 | | | | | R/ | W | | | | V | Request 83H<br>Vector | озп | | | 0 | 0 | 0 | 0 | 0 | 0 | | | VCCtor | | | | | | DMA3 Sta | art vector | | | | | Intownet | | | | CLRV5 | CLRV4 | CLRV3 | CLRV2 | CLRV1 | CLRV0 | | INTCLR | Interrupt<br>Clear | 88H | | | | | W | Į | | | | INTCLK | Control | (Prohibit | | | - | - | - | - | - | - | | | Control | RMW) | | | Cle | ars interrupt | request flag by | y writing to D | MA start vec | tor | | | DMA | | | | | | DMAR3 | DMAR2 | DMAR1 | DMAR0 | | DMAR | Software | 89H | | | | | R/W | R/W | R/W | R/W | | DWAK | Request | 6911 | | | | | 0 | 0 | 0 | 0 | | | Register | | | | | | 1 | : DMA reque | est in software | <u> </u> | | | DMA | | | | | | DMAB3 | DMAB2 | DMAB1 | DMAB0 | | DMAB | Burst | 8AH | | | | | R/W | R/W | R/W | R/W | | DMAD | Request | OAH | | | | | 0 | 0 | 0 | 0 | | | Register | | | | | | 1: | DMA request | on Burst Mo | de | | | | | | | I3EDGE | I2EDGE | I1EDGE | I0EDGE | I0LE | NMIREE | | | | | W | | W | w | W | W | W | W | | | Interrupt | 8CH | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | IIMC | Input Mode | | Always | | INT3 | INT2 | INT1 | INT0 | INT0 | 1: operation | | | Control | | write 0 | | edge | edge | edge | edge | 0: edge | even on | | | | (Prohibit | | | 0: Rising | 0: Rising | 0: Rising | 0: Rising | 1:level | NMI rising | | | | RMW) | | | 1: Falling | 1: Falling | 1: Falling | 1: Falling | | edge | # (4) Chip Select/Wait Control (1/2) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----------------------|-----------|--------|---------|--------------|---------------|----------------|-------------|--------------|--------| | | | | B0E | | B00M1 | B00M0 | B0BUS | B0W2 | B0W1 | B0W0 | | B0CS | Block 0 | СОН | W | | W | W | W | W | W | W | | | CS/WAIT | | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | control | | 0: DIS | | 00: ROM/S | RAM | Data bus | 000: 2WAI | 100: Re | served | | | Register | (Prohibit | 1: EN | | 01: | | width | 001: 1WAI | T 101: 3W | AIT | | | | RMW) | | | 10: | eserved | 0: 16 bit | 010: 1 + NV | VAIT 110: 4V | VAIT | | | | | | | 11: J | | 1: 8 bit | 011: 0WAI | 111: 8W | AIT | | | | | B1E | | B10M1 | B10M0 | B1BUS | B1W2 | B1W1 | B1W0 | | B1CS | Block 1 | C1H | W | | W | W | W | W | W | W | | | CS/WAIT | | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | control | | 0: DIS | | 00: ROM/S | RAM | Data bus | 000: 2WAI | T 100: Re | served | | | Register | | 1: EN | | 01: | | width | 001: 1WAI | T 101: 3W | AIT | | | | (Prohibit | | | 10: \ R | eserved | 0: 16 bit | | VAIT 110: 4V | VAIT | | | | RMW) | | | 11: J | | 1: 8 bit | 011: 0WAI | 111: 8W | AIT | | | | | B2E | B2M | B20M1 | B20M0 | B2BUS | B2W2 | B2W1 | B2W0 | | B2CS | Block 2 | С2Н | W | W | W | W | W | W | W | W | | | CS/WAIT | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | control | | 0: DIS | 0: 16 M | 00: ROM/S | RAM | Data bus | 000: 2WAI | Г 100: Re | served | | | Register | | 1: EN | Area | 01: | | width | 001: 1WAI | T 101: 3W | AIT | | | | (Prohibit | | 1: Area | 10: | eserved | 0: 16 bit | 010: 1 + NV | VAIT 110: 4V | VAIT | | | | RMW) | | set | 11: J | | 1: 8 bit | 011: 0WAI | 111: 8W | AIT | | | | | B3E | | B30M1 | B30M0 | B3BUS | B3W2 | B3W1 | B3W0 | | B3CS | Block 3 | СЗН | W | | W | W | W | W | W | W | | | CS/WAIT | | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | control | | 0: DIS | | 00: ROM/S | RAM | Data bus | 000: 2WAI | Г 100: Re | served | | | Register | | 1: EN | | 01: | | width | 001: 1WAI | T 101: 3W | AIT | | | | (Prohibit | | | 10: | eserved | 0: 16 bit | 010: 1 + NV | VAIT 110: 4V | VAIT | | | | RMW) | | | 11: J | | 1: 8 bit | 011: 0WAI | 111: 8W | AIT | | | | | | | | | BEXBUS | BEXW2 | BEXW1 | BEXW0 | | BEXCS | External | С7Н | | | ļ | | W | W | W | W | | | CS/WAIT | | | | | | 0 | 0 | 0 | 0 | | | control | | | | | | Data bus | 000: 2WAI | Г 100: Re | served | | | Register | | | | | | width | 001: 1WAI | | | | | | (Prohibit | | | | | 0: 16 bit | 7 | VAIT 110: 4V | VAIT | | | | RMW) | | | | | 1: 8 bit | 011: 0WAI | 111: 8W | AIT | | | Memory | | S23 | S22 | S21 | S20 | S19 | S18 | S17 | S16 | | MSAR0 | Start | C8H | | | | | W | | | | | | Address | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | Reg0 | | | , | | | A23 to A16 | | | | | | Memory | | V20 | V19 | V18 | V17 | V16 | V15 | V14~9 | V8 | | MAMR0 | Address | С9Н | | | | R/ | W | | | | | | Mask Reg0 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | CS0 area siz | e 0: ena | ble to address | comparison | | | | | Memory | ] | S23 | S22 | S21 | S20 | S19 | S18 | S17 | S16 | | MSAR1 | Start | CAH | | | | R | W | | | | | | Address | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | Reg1 | | | | | Start address | A23 to A16 | | | | | | | | V21 | V20 | V19 | V18 | V17 | V16 | V15~9 | V8 | | MAMR1 | Memory | СВН | | | | | W | | | | | 1417 11411 | Address<br>Mask Boot | CDII | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | Mask Reg1 | | | • | CS0 area siz | e 0: ena | ble to address | comparison | | | | | i . | 1 | 1 | | J a. ou blz | J. CHu | | | | | # Chip Select/Wait Control (2/2) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----------|-----------------------------------|--------------------------|-----|-----|--------------|---------------|----------------|------------|-----|-----|--|--| | | Memory | | S23 | S22 | S21 | S20 | S19 | S18 | S17 | S16 | | | | MSAR2 | Start | ССН | | R/W | | | | | | | | | | MSAK2 | Address | ССН | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | Reg2 | | | | | Start address | A23 to A16 | | | | | | | | | | V22 | V21 | V20 | V19 | V18 | V17 | V16 | V15 | | | | MAMR2 | Memory | CDII | | | | R/ | W | | | | | | | WANKZ | | Address CDH<br>Mask Reg2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | Mask Reg2 | | | | CS0 area siz | e 0: ena | ble to address | comparison | | | | | | | Memory | | S23 | S22 | S21 | S20 | S19 | S18 | S17 | S16 | | | | MSAR3 | Start | CEH | | | | R/ | W | | | | | | | WSAKS | Address | CEH | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | Reg3 | | | | | Start address | A23 to A16 | | | | | | | | | | V22 | V21 | V20 | V19 | V18 | V17 | V16 | V15 | | | | MAMR3 | R3 Memory<br>Address<br>Mask Reg3 | CEH | | | | R/ | W | • | | | | | | IVIAIVIKS | | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | Wask Regs | | | | CS0 area siz | e 0: ena | ble to address | comparison | | | | | (5) Clock Gear (1/2) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------------|---------|-----------------|---------------------|---------------------|------------------|------------------|---------------|----------------------|--------------| | | | | XEN | XTEN | RXEN | RXTEN | RSYSCK | WUEF | PRCK1 | PRCK0 | | SYSCR0 | System Clock | E0H | | | - | R/ | W | - | - | | | | Control Register | | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | 0 | | High- | Low- | High-frequenc | Low-frequenc | Select clock | Warm-up | Select prescale | r clock | | | | | frequency | frequency | y oscillator (fc) | y oscillator (fs | after release of | timer | 00: f <sub>FPH</sub> | | | | | | oscillator (fc) | oscillator (fs) | after release | after release of | STOP Mode | 0 write: | 01: reserved | | | | | | 0: stopped | 0: stopped | of STOP Mode | STOP Mode | 0: fc | Don't care | 10: fc/16 | | | | | | 1: oscillation | 1: oscillation | 0: stopped | 0: stopped | 1: fs | 1 write: | 11: reserved | | | | | | | | 1: oscillation | 1: oscillation | | start timer | | | | | | | | | 1 | | | 0 read: end | | | | | | | | | | | | warm-up | | | | | | | | | | | | 1 read: | | | | | | | | | 1 | | | not end | | | | | | | | | | | | warm-up | | | | | | | | | | | SYSCK | GEAR2 | GEAR1 | GEAR0 | | SYSCR1 | System Clock | E1H | | | | | | R/ | W | | | | Control | | | 1 | | | 0 | 1 | 0 | 0 | | | Register 1 | | | | | | System | High-frequer | 1cy gear value | selection | | | | | | 1 | | | clock | (fc) | , , | | | | | | | | | | selection | 000: fc | | | | | | | | | | | 0: fc | 001: fc/2 | | | | | | | | | | | 1: fs | 010: fc/4 | | | | | | | | | | | (Note 2) | 011: fc/8 | | | | | | | | | | | | 100: fc/16 | | | | | | | | | | | | 101: (reserve | ed) | | | | | | | | | | | 110: (reserve | ed) | | | | | | | | | | | 111: (reserve | ed) | | | | | | | SCOSEL | WUPTM1 | WUPTM0 | HALTM1 | HALTM0 | | DRVE | | SYSCR2 | System Clock | E2H | | R/W | R/W | R/W | R/W | R/W | | R/W | | | Control | | | 0 | 1 | 0 | 1 | 1 | | 0 | | | Register 2 | | | 0: fs | Warming-up | time | 00: reserved | | <drive></drive> | 1: Drive the | | | | | | 1: f <sub>FPH</sub> | 00: reserved | | 01: STOP M | ode | Mode | pin in | | | | | | -1711 | 01: 28/inputt | | 10: IDLE1 M | | Select | STOP/ | | | | | | | 10: 214 | | 11: IDLE2 M | Iode | 0:STOP | Mode | | | | | | 1 | 11: 2 <sup>16</sup> | | | | 1:IDLE | | TOSHIBA TMP91C824 (5) Clock Gear (2/2) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------------------------|---------|------------|--------------|----------------------------|-----------------------|------------|------------------|----------------|----------------| | | | | PROTECT | TA3LCDE | | | | EXTIN | DRVOSCH | DRVOSCL | | EMCCR0 | EMC | ЕЗН | R | R/W | | Control | | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | | | Register 0 | | Protection | LCDC | Always write | Always | e | 1: fc is | fc oscillator | fs oscillator | | | | | flag | Source clk | 1 | write 0 | | external | drivability | drivability | | | | | 0: OFF | 0: 32KHz | | | | clock. | 1: Normal | 1: Normal | | | | | 1: ON | 1: TA3OUT | | | | | 0: Weak | 0: Weak | | EMCCR1 | EMC<br>Control<br>Register 1 | Е4Н | Follows | | n writes in 1 <sup>s</sup> | T-KEY:EMC | , | | | | | EMCCR2 | EMC<br>Control<br>Register 2 | Е5Н | | Continuation | n writes in 2 <sup>N</sup> | <sup>D</sup> -KEY:EMC | CR1=A5H, E | MCCR2=5A | Н. | | | | | | | ENFROM | ENDROM | ENPROM | | FFLAG | DFLAG | PFLAG | | EMCCR3 | EMC | Е6Н | | R/W | R/W | R/W | | R/W | R/W | R/W | | | Control | | | 0 | 0 | 0 | | 0 | 0 | 0 | | | Register 3 | | | CS1A | CS2B-2G | CS2A | | CS1A | CS2B-2G | CS2A | | | | | | area detect | area detect | area detect | | Write | Write | Write | | | | | | enable | Enable | enable | | operation flag | operation flag | operation flag | | | | | | 0:disable | 0:disable | 0:disable | | When reading | When | writing | | | | | | 1:enable | 1:enable | 1:enable | | "0": not written | "0": | clear flag | | | | | | | | | | "1": written | | | Note: EMCCR1 If protection is on, write operations to the following SFRs are not possible. 1. CS/WAIT control B0CS, B1CS, B2CS, B3CS, BEXCS, MSAR0, MSAR1, MSAR2, MSAR3, MAMR0, MAMR1, MAMR2, and MAMR3 2. MMU LOCAL0/1/2/3 - 3. Clock Gear (EMCCR1, 2 can be written to) SYSCR0, SYSCR1, SYSCR2 and EMCCR0 - 4. DFM DFMCR0, DFMCR1 ### (6) DFM (clock doubler) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------|---------|---------|------------------------|----------------|---------------------------------------|--------------|--------------|-----|-----| | | | | ACT1 | ACT0 | DLUPFG | DLUPTM | | | | | | DFMCR0 | DFM | E8H | R/W | R/W | R | R/W | | | | | | | Control | | 0 | 0 | 0 | 0 | | | | | | | Register 0 | | DFM | LUP f <sub>FPH</sub> | Lock-up falg | Lock-up time | | | | | | | | | 00 STOP | STOP fosch | 0: End LUP | 0: 2 <sup>12/</sup> f <sub>OSCH</sub> | | | | | | | | | 01 RUN | RUN fosch | 1: Do not end | 1: 2 <sup>10/</sup> f <sub>OSCH</sub> | | | | | | | | | | STOP f <sub>DFM</sub> | LUP | | | | | | | | | | 11 RUN | STOP f <sub>OSCH</sub> | ļ | | | | | | | | | | | | | | | | | | | DFMCR1 | DFM | E9H | R/W | | Control | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | | | Register 1 | | | | | DFM co | rrection | | | | | | | | | Ir | nput frequency | y 4 ~ 6.75MH | z (@2.7-3.6\ | ): write 0Bl | Н | | | | | | | In | put frequency | 1 ~ 2.5MHz | (@2.0V ±10° | %): write 1B | Н | | # (7) 8-Bit Timer (7-1) TMRA01 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------|-----------|---------------|--------|-----------------|----------|--------------------|-------------|------------------|-----------| | | | | TA0RDE | | | | I2TA01 | TA01PRUN | TA1RUN | TA0RUN | | TA01- | Timer | 100H | R/W | | | | R/W | R/W | R/W | R/W | | RUN | RUN | | 0 | | | | 0 | 0 | 0 | 0 | | | | | Double | | | | IDLE2 | 8-Bit Timer | Run/Stop co | ntrol | | | | | Buffer | | | | 0: Stop | 0: Stop & | clear | | | | | | 0: Disable | | | | 1: Operate | 1: Run (c | count up) | | | | | | 1: Enable | | | | | | | | | | 8-Bit | 102H | | | | | _ | | | | | TA0REG | Timer | (Prohibit | | | | | W | | | | | | Register 0 | RMW) | | | | Uno | defined | | | | | | 8-Bit | 103H | | | | | - | | | | | TA1REG | Timer | (Prohibit | | | | | W | | | | | | Register 1 | RMW) | | | | Uno | defined | | | | | | | | TA01M1 | TA01M0 | PWM01 | PWM00 | TA1CLK1 | TA1CLK0 | TA0CLK1 | TA0CLK0 | | | 8-Bit | | | | | I | R/W | | | | | TA01- | Timer | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | MOD | Source | 104H | 00: 8-Bit Tir | ner | 00: Reserve | | 00: TA0TR0 | 3 | 00: TA0IN p | oin | | | CLK & | | 01: 16-Bit T | imer | $01: 2^6 - 1$ F | WM cycle | 01: φT1 | | 01: φT1 | | | | MODE | | 10: 8-Bit PP | G | $10: 2^7 - 1$ | | 10: фT16 | | 10: <b></b> | | | | | | 11: 8-Bit PW | /M | $11: 2^8 - 1$ | | 11: <b>\$</b> T256 | • | 11: <b>¢</b> T16 | | | | | | | | | | TAFF1C1 | TAFF1C0 | TAFF1IE | TAFF1IS | | TA1FFCR | 8-Bit | 105H | | | | | W | * | R | /W | | | Timer | | | | | | 1 | 1 | 0 | 0 | | | Flip-Flop | | | | | | 00: Invert T | | 1: TA1FF | 0: TMRA0 | | | Control | | | | | | 01: Set TA1 | | Invert | 1: TMRA1 | | | | | | | | | 10: Clear TA | | Enable | inversion | | | | | | | | | 11: Don't ca | ire | | | (7-2) TMRA23 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------|---------|---------------|--------|-----------------|----------|------------------|-------------|------------------|-----------| | | | | TA2RDE | | | | I2TA23 | TA23PRUN | TA3RUN | TA2RUN | | TA23-R | Timer | 108H | R/W | | | | R/W | R/W | R/W | R/W | | UN | RUN | | 0 | | | | 0 | 0 | 0 | 0 | | | | | Double | | | | IDLE2 | 8-Bit Times | r Run/Stop co | ntrol | | | | | Buffer | | | | 0: Stop | 0: Stop & | k Clear | | | | | | 0: Disable | | | | 1: Operate | 1: Run (c | count up) | | | | | | 1: Enable | | | | | | | | | | 8-Bit | | | | | | - | | | | | TA2REG | Timer | 10AH | | | | | W | | | | | | Register 0 | (RMW 禁) | | | | U | ndefined | | | | | | 8-Bit | | | | | | - | | | | | TA3REG | Timer | 10BH | | | | | W | | | | | | Register 1 | (RMW 禁) | | | | U | ndefined | | | | | | | | TA23M1 | TA23M0 | PWM21 | PWM20 | TA3CLK1 | TA3CLK0 | TA2CLK1 | TA2CLK0 | | TA23-M | 8-Bit | 10CH | | | | | R/W | | | | | OD | Timer | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Source | | 00: 8-Bit Tir | ner | 00: Reserved | | 00: TA2TRG | | 00: Reserved | l | | | CLK & | | 01: 16-Bit T | | $01: 2^6 - 1$ P | WM cycle | 01: φT1 | | 01: φT1 | | | | MODE | | 10: 8-Bit PP | | $10: 2^7 - 1$ | | 10: <b>¢</b> T16 | | 10: <b>¢</b> T4 | | | | | | 11: 8-Bit PV | VM | $11: 2^8 - 1$ | _ | 11: φT256 | , | 11: <b>¢</b> T16 | | | | 8-Bit | | | | | | TAFF3C1 | TAFF3C0 | TAFF3IE | TAFF3IS | | TA3FFCR | Timer | 10DH | | | ļ | ļ | | /* | | /W | | | Flip-Flop | | | | | | 1 | 1 | 0 | 0 | | | Control | | | | | | 00: Invert TA | | 1: TA3FF | 0: TMRA2 | | | | | | | | | 01: Set TA3F | - | Invert | 1: TMRA3 | | | | | | | | | 10: Clear TA | | Enable | inversion | | | | | | | | | 11: Don't car | e | | | # (8) UART/Serial Channel (1/2) ### (8-1) UART/SIO Channel 0 | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------|-----------|---------|--------------|-------------------|------------|---------------|----------------|---------|--------------|------------------------| | | Serial | | RB7/TB7 | RB6/TB6 | RB5/TB5 | RB4/TB4 | RB3/TB3 | RB2/TB2 | RB1/TB1 | RB0/TB0 | | SC0BUF | Channel 0 | 200H | | | R ( | (Receiving)/W | V (Transmissi | on) | | | | | Buffer | | | | | Unde | efined | | | | | | | | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC | | | Serial | | R | R/ | W | R (Cle | ared to 0 by r | eading) | R/ | W | | SC0CR | Channel 0 | 201H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Control | | Receiving | Parity | 1: Parity | | 1: Error | , | 0:SCLK0↑ | 1: Input | | | | | data bit 8 | 0: Odd<br>1: Even | Enable | Over Run | Parity | Framing | 1:SCLK0↓ | SCLK0 pin | | | | | TB8 | CTSE | RXE | WU | SM1 | SM0 | SC1 | SC0 | | | | | | | | R/ | W | | | | | | Serial | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | SC0- | Channel 0 | 202H | Transmission | 1: CTS | 1: Receive | 1: Wake-up | 00: I/O Inter | face | 00: TA0TR | 3 | | MOD0 | Mode0 | 20211 | data bit 8 | Enable | Enable | Enable | 01: UART 7 | -Bit | 01: baud rat | e generator | | | | | | | | | 10: UART 8 | -Bit | 10: internal | clock f <sub>SYS</sub> | | | | | | | | | 11: UART 9 | -Bit | 11: external | clock | | | | | | | | | | | SCLK0 | | | | | | | BR0ADD | BR0CK1 | BR0CK0 | BR0S3 | BR0S2 | BR0S1 | BR0S0 | | | | | | | | R/ | W | | | | | | Baud Rate | | 0 | 0 | | ) | 0 | 0 | 0 | 0 | | BR0CR | Control | 203H | | 1: (16-K)/16 | 00: φΤ0 | | | | diing value. | | | | | | write 0. | divided | 01: φΤ2 | | | 0 t | o F | | | | | | | Enable | 10: фТ8 | | | | | | | | | | | | 11: | | | • | | | | | Serial | | | | | | BR0K3 | BR0K2 | BR0K1 | BR0K0 | | BR0-AD | Channel 0 | 20.477 | | | | | | | W<br>I | ! | | D | K setting | 204H | | | | | 0 | 0 | 0 | 0 | | | Reg | | | | | | | | Rate0 K | | | | | | | | | | | 1 t | o F | | | | | | I2S0 | FDPX0 | | | | | | | | 000 140 | Serial | | R/W | R/W | | | | | <u> </u> | | | SC0-MO<br>D1 | Channel 0 | 205H | 0 | 0 | | | | | | | | וע | Mode1 | | IDLE2 | I/O interface | | | | | | | | | | | 0: Stop | 1: Full Duplex | | | | | | | | | | | 1: Operate | 0: Half Duplex | | | | | | | (8-2) IrDA | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|----------|---------|--------------|--------------|--------------|------------|---------------------------------------------------------------|-------------|-------------|--------|--| | | | | PLSEL | RXSEL | TXEN | RXEN | SIRWD3 | SIRWD2 | SIRWD1 | SIRWD0 | | | | | | R/W | R/W | R/W | R/W | | R | W | | | | | IrDA | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | SIRCR | Control | 207H | Transmission | Receiving | Transmission | Receiving | Set the effec | tive SIRRxD | pulse width | | | | | Register | | pulse width | Data | 0: Disable | 0: Disable | Pulse width more than " $2x \times (\text{set value} + 1")$ " | | | | | | | | | 0: 3/16 | 0: "H" pulse | 1: Enable | 1: Enable | Possible | : 1 to 14 | | | | | | | | 1: 1/16 | 1: "L" pulse | | | Not possible | : 0, 15 | | | | # UART/Serial Channel (2/2) ## (8-3) UART/SIO Channel1 | SCIENT Channel 1 Buffer | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|--------------|--------------|---------|------------|---------------|-----------------|---------|------------|-----------| | Serial Scilar Serial Scilar S | | Serial | | RB7/TB7 | RB6/TB6 | RB5/TB5 | RB4/TB4 | RB3/TB3 | RB2/TB2 | RB1/TB1 | RB0/TB0 | | Scial Sci | SC1BUF | Channel 1 | 208H | | | R | (Receiving)/W | / (Transmissi | on) | | | | Scrial Channel 1 Control | | Buffer | | | | | Unde | fined | | | | | Scriat Channel 1 Control Channel 1 Control Channel 1 | | | | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC | | SCICR Channel Control Contro | | Corio1 | | R | R/ | W | R (Cle | ared to 0 by re | eading) | R/ | W | | Receiving data bit 8 O. Odd Enable Over Run Parity Framing I: SCLK1 I: Input | SC1CR | | 209H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Scrial Channel 1 Always write 1: (16-K)/16 O. 0 | Berek | | 20711 | Receiving | Parity | 1: Parity | | 1: Error | , | 0: SCLK1↑ | 1: Input | | Scrial Channel 1 20AH 20 | | | | data bit 8 | 0: Odd | Enable | Over Run | Parity | Framing | 1: SCLK1↓ | SCLK1 pin | | Scrial Channel Mode | | | | | 1: Even | | | | | | | | SCI-MODO | | | | TB8 | CTSE | RXE | WU | SM1 | SM0 | SC1 | SC0 | | SC1- MODO | | | | | | | R/ | W | | | | | MODO | SC1- | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | BRICR Baud Rate Control 20BH 20BH 20CH BRI-ADD BRI- | MOD0 | | 20AH | Transmission | 1: CTS | 1: Receive | 1: Wake up | 00: I/O Interf | ace | 00: TA0TRG | | | Baud Rate Control 20BH | | Mode | | data bit 8 | Enable | Enable | Enable | | | | | | Baud Rate Control 20BH 2 | | | | | | | | : | | | | | Baud Rate Control 20BH | | | | | | | | | | | | | BR1CR Baud Rate Control 20BH | | | | _ | BR1ADD | BR1CK1 | | | BR1S2 | BR1S1 | BR1S0 | | BR1CR Baud Rate Control Cont | | | | | | | | | | | | | Control O. divided O1: \$\phi T2 O to F | DD1CD | Baud Rate | 20011 | | | | 0 | 0 | | | 0 | | Enable 10: \$\phi T8\$ 11: \$\phi T32\$ BR1K3 BR1K2 BR1K1 BR1K0 | BRICK | Control | 20 <b>BH</b> | | | | | | | _ | | | Serial Channel 1 20CH | | | | 0. | | | | | 0 to | o F | | | Serial Channel 1 Channel 1 K setting Reg Reg Serial Channel 1 20CH Serial Channel 1 20DH IDLE2 1/0 interface Channel 1 20DH IDLE2 1/0 interface Channel 1 20DH 20D | | | | | Enable | | | | | | | | Serial Channel 1 | | | | | | 11: ψ132 | | DD11/2 | DD1V2 | DD 11/21 | DD11//O | | D Channel 1 20CH | | Serial | | | | | | BKIKS | | | BKIKU | | Note | BR1-AD | | 20CH | | | | | 0 | | | 0 | | Neg | D | K setting | 20011 | | | | | | | | | | 12S1 FDPX1 R/W R/W Serial Channel 1 20DH IDLE2 I/O interface IDLE2 I | | Reg | | | | | | , | _ | - | • | | R/W R/W | | | | 1251 | FDPX1 | | | | | | | | SC1-MO D1 | | | | | | | | | | | | | SC1-MO Channel 1 20DH IDLE2 I/O interface | | Serial | | | | | | | | | | | | | | 20DH | | · | | | | | | | | I IV. SIUD I I III III I III III III III III II | D1 | Mode1 | | | mode | | | | | | | | 1: Operate 1: full Duplex | | | | • | | | | | | | | | 0: Half Duplex | | | | 1 | - | | | | | | | # (9) I<sup>2</sup>CBUS/Serial Interface | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|------------|-----------------------|----------------|-------------|------------------------|------------------|----------------------------|-----------------------------------|-----------------|--------------| | Symbol | Ivanie | Address | BC2 | BC1 | BC0 | ACK | | SCK2 | SCK1 | SCK0 | | SBI0CR1 | Serial Bus | 240H | BC2 | вст | всо | ACK | | SCK2 | SCKI | /SWRMON | | SBIOCKI | Interface | (I2C Bus | | W<br>W | <u> </u> | R/W | | W | W | R/W | | | Control | Mode) | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | Register 1 | Wiodc) | Number of tr | | <u> </u> | Acknowledge | | Setting for the o | | 0 | | | register | | 000: 8, 001: | | | Mode | | 000: 4, 001: 5, | | | | | | (Prohibit | 011: 3, 100: | | | 0: Disable | | 011: 7, 100: 8, | | | | | | RMW) | 110: 6, 111: | 7 | | 1: Enable | | 110: 10, 111: ( | reserved) | | | | | 240H | SIOS | SIOINH | SIOM1 | SIOM0 | | SCK2 | SCK1 | SCK0 | | | | (SIO | | | | | | | | /SWRMON | | | | Mode) | W | W | W | W | | W | W | R/W | | | | | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | | | Transfer | Transfer | Transfer mod | e | | Setting for the o | livisor value n | | | | | (Prohibit | 0: Stop | 0: Continue | 00: 8-Bit Trar | nsmit Mode | | 000: 3, 001: 4, | | | | | | RMW) | 1: Start | 1: Abort | | ransmit/Receive | | 011: 6, 100: 7, | | | | | | | | | Mode<br>11: 8-Bit rece | 4 M - 4 - | | 110: 9, 111: SO | CK pin | | | SBI0- | SBI | 241H | RB7/TB7 | RB6/TB6 | RB5/TB5 | RB4/TB4 | RB3/TB3 | RB2/TB2 | RB1/TB1 | PB0/TB0 | | DBR | Buffer | (Prohibit | KD//ID/ | KD0/1D0 | KD3/1D3 | | | | KD1/1D1 | PDU/IDU | | DBK | Register | RMW) | | | | R (receiving)/ | defined | 1011) | | | | | Register | Kivi vv) | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 | SA0 | ALS | | I2C0AR | I2CBUS | 242H | W | W | W W | W | R/W | R/W | R/W | R/W | | 12COAK | Address | 24211 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Register | | 0 | . 0 | . 0 | 0 | U | 0 | U | Address | | | register | (Prohibit | | | | | | | | recognition | | | | RMW) | | | S | setting slave ad | dress | | | 0: Enable | | | | , | | | | | | | | 1: Disable | | | | | MST | TRX | BB | PIN | AL/SBIM1 | AAS/SBIM0 | AD0/ | LRB/ | | SBIO- | Serial Bus | 243H | | | | | | | SWRST | SWRST0 | | CR2 | Interface | (I <sup>2</sup> C bus | R/W | | Control | Mode) | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | (SBI0SR) | Register 2 | | 0: Slave | 0: receiver | Bus status | INTS2 request | Arbitration lost | Slave address | GENERAL | Lost receive | | | | | 1: Master | 1: transmit | monitor | monitor | detection | | CALL detection | | | | | (Prohibit | | | 0: Free | 0: Request | monitor | monitor | monitor | 0: 0<br>1: 1 | | | | RMW) | | | 1: Busy | 1: Cancel | 1: Detect | 1: Detect | 1: Detect | 1; 1 | | | | 243H | | | | | SIOF | SEF | | | | | | (SIO | | | | | R | R | | | | | | Mode) | | | | | 0 | 0 | | | | | | Wiodc) | | | | | Transfer status<br>monitor | Shift operation<br>status monitor | | | | | | (Prohibit | | | | | 0: stopped | 0: stopped | | | | | | RMW) | | | | | | 1: terminated in | | | | | | | | | | | process | process | | | | | | | | I2SBI0 | | | | | | | | SBI0- | Serial Bus | 244H | | R/W | | | | | | | | BR0 | Interface | | | 0 | | | | | | | | | Baud Rate | | Always | IDLE2 | | | | | | | | | Register 0 | | write 0. | 0: Abort | | | | | | | | | | | | 1: Operate | | | | | | | | | | | P4EN | | | | | | | | | SBI0- | Serial Bus | 245H | R/W | | | | | | | | | BR1 | Interface | | 0 | | | | | | | | | | Baud Rate | | Internal Clock | | | | | | | | | | Register 1 | | 0: Abort | | | | | | | | | 1 | I | | 1: Operate | I | 1 | 1 | | l | | | # (10) A/D Converter | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----------------|---------|---------|------------|--------|----------------|---------------|-------------|------------------------------------|-----------------------| | | A/D | | EOCF | ADBF | - | ITM1 | ITM0 | REPEAT | SCAN | ADS | | ADMOD | MODE | 2B0H | I | ₹ | R/W | R/W | R/W | R/W | R/W | R/W | | 0 | Reg0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1: End | 1: busy | | Interrupt in R | epeat Mode | 1: Repeat | 1: Scan | 1: Start | | | A/D | | VREFON | I2AD | | | ADTRGE | ADCH2 | ADCH1 | ADCH0 | | ADMOD | MODE | 2B1H | R/W | R/W | | | R/W | | R/W | | | 1 | Reg1 | | 0 | 0 | | | 0 | 0 | 0 | 0 | | | | | 1: VREF | IDLE2 | | | 1: Enable for | | Input channel | | | | | | On | 0: Abort | | | external | 000: AN0 AN | NO | | | | | | | 1: Operate | | | start | 001: AN1 AN | NO →AN1 | | | | | | | | | | | 010: AN2 AN | $N0 \rightarrow AN1 \rightarrow A$ | AN2 | | | | | | | | | | 011: AN3 AN | $N0 \rightarrow AN1 \rightarrow A$ | $AN2 \rightarrow AN3$ | | | | | | | | | | 100: AN4 AN | N4 | | | | | | | | | | | 101: AN5 AN | | | | | | | | | | | | | $N4 \rightarrow AN5 \rightarrow A$ | | | | 1 D D 1 | | 10001 | 10000 | | | | 111: AN7 AN | $N4 \rightarrow AN5 \rightarrow A$ | | | AD<br>DEGG (Y | AD Result | 2 4 011 | ADR01 | ADR00 | | | | | | ADR0RF | | REG04L | Reg 0/4 low | 2A0H | | <u> </u> | | - | | | | R | | A.D. | ADD 1 | | | efined | 4 DD07 | ADDOC | 4 DD05 | 4 DD04 | 4 DD02 | 0 | | AD<br>REG04H | AD Result | 2A1H | ADR09 | ADR08 | ADR07 | ADR06 | ADR05 | ADR04 | ADR03 | ADR02 | | REGU4H | Reg 0/4<br>high | ZAIH | | | | | efined | | | | | AD | AD Result | | ADR11 | ADR10 | | | | | | ADR1RF | | REG15L | Reg 1/5 low | 2A2H | | λ. | | | | | | R | | | | | | efined | | | | | | 0 | | AD | AD Result | | ADR19 | ADR18 | ADR17 | ADR16 | ADR15 | ADR14 | ADR13 | ADR12 | | REG15H | Reg 1/5 | 2A3H | | | | · | ₹ | | | | | | high | | | | | Unde | efined | | | | | AD | AD Result | | ADR21 | ADR20 | | | | | | ADR2RF | | REG26L | Reg 2/6 low | 2A4H | I | 2 | | | | | | R | | | | | Unde | efined | | | | | | 0 | | AD | AD Result | | ADR29 | ADR28 | ADR27 | ADR26 | ADR25 | ADR24 | ADR23 | ADR22 | | REG26H | Reg 2/6 | 2A5H | | | | I | ₹ | | | | | | high | | | | | Unde | efined | | | | | AD | AD Result | | ADR31 | ADR30 | | | | | _ | ADR3RF | | REG37L | Reg 3/7 low | 2A6H | I | ? | | | | | | R | | | | | Unde | efined | | | | | | 0 | | AD | AD Result | | ADR39 | ADR38 | ADR37 | ADR36 | ADR35 | ADR34 | ADR33 | ADR32 | | REG37H | Reg 3/7 | 2A7H | | | | - I | ? | | | | | | high | | | | | Unde | efined | | | | # (11) Watchdog Timer | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|--------|--------------------------------------------------------------------------------|--------|-------------|---------|------------|------------|--------------| | | | | WDTE | WDTP1 | WDTP0 | | | I2WDT | RESCR | _ | | | WDT | | R/W | R/W | R/W | | | R/W | R/W | R/W | | WDMOD | MODE | 300H | 1 | 0 | 0 | | | 0 | 0 | 0 | | | Reg | | 1: WDT | 00: 215/f <sub>sys</sub> | | | | IDLE2 | 1: RESET | Always write | | | | | Enable | 01: 2 <sup>17</sup> /f <sub>sys</sub> | | | | 0: Abort | connect | 0. | | | | | | 10: 2 <sup>19</sup> /f <sub>sys</sub><br>11: 2 <sup>21</sup> /f <sub>sys</sub> | | | | 1: Operate | internally | | | | | | | 11: 2 <sup>21</sup> /f <sub>sys</sub> | | | | | WDT out | | | | | | | | | | | | to Reset | | | | | | | | | | | | pin | | | | | | | | | _ | _ | | | | | WDCR | WD | 301H | | | | V | V | | | | | | Control | | | | | _ | _ | | | | | | | | | | B1H: V | VDT Disable | 4EH: WD | T Clear | | | # (12) RTC (Real-Time Clock) | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|---------|---------|---------|----------|----------|-----------|-----------|-----------|--------------| | | | | | SE6 | SE5 | SE4 | SE3 | SE2 | SE1 | SE0 | | SECR | Second | 320H | | | ~~~ | ~=: | R/W | | ~ | ~=- | | | Reg | | | | | | Undefined | | | | | | | | "0" | 40 sec. | 20 sec. | 10 sec. | 8 sec. | 4 sec. | 2 sec. | 1 sec. | | | | | | MI6 | MI5 | MI4 | MI3 | MI2 | MI1 | MI0 | | MINR | Minute | 321H | | | | | R/W | | | | | | Reg | | | | | | Undefined | | | | | | | | "0" | 40 min. | 20 min. | 10 min. | 8 min. | 4 min. | 2 min. | 1min. | | | | | | | HO5 | HO4 | НО3 | HO2 | HO1 | HO0 | | HOURR | Hour | 322H | | | | | R/ | | • | | | | Reg | | | | | | Unde | | | | | | | | "0" | "0" | 20 hour | 10 hour | 8 hour | 4 hour | 2 hour | 1 hour | | | | | | | (PM/AM) | | | | | | | | | | | | | | | WE2 | WE1 | WE0 | | DAYR | Day | 323H | | | | | | | R/W | | | | Reg | | | | | | | | Undefined | | | | | | "0" | "0" | "0" | "0" | "0" | WE2 | WE1 | WE0 | | | | | | | DA5 | DA4 | DA3 | DA2 | DA1 | DA0 | | DATER | Date | 324H | | | | | R/ | W | | | | | Reg | | | | | | Unde | fined | | | | | | | "0" | "0" | 20 day | 10 day | 8 day | 4 day | 2 day | 1 day | | | | | | | | MO4 | MO3 | MO2 | MO1 | MO0 | | MONTHR | Month | 325H | | | | | | R/W | | | | | Reg | | | | | | | Undefined | | | | | | PAGE0 | "0" | "0" | "0" | 10 month | 8 month | 4 month | 2 month | 1 month | | | | PAGE1 | | | | | | | | 0: Indicator | | | | | | | | | | | | for 12 hours | | | | | | | | | | | | 1: Indicator | | | | | | | | | | | | for 24 hours | | | | | YE7 | YE6 | YE5 | YE4 | YE3 | YE2 | YE1 | YE0 | | YEARR | Year | 326H | | | | R/ | W | | | | | | Reg | | | | | Unde | fined | | | , | | | | PAGE0 | 80 year | 40 year | 20 year | 10 year | 8 year | 4 year | 2 year | 1 year | | | | PAGE1 | | | | | | | Leap ye | ar setting | | | | | INTRTC | | | ADJUST | ENATMR | ENAALM | | PAGE | | PAGER | Page | 327H | R/W | | | W | R/ | W | | R/W | | | Reg(Prohi | | 0 | | | | Unde | fined | | Undefined | | | bit RMW) | | INT | | | ADJUST | TIMER | ALARM | | PAGE | | | | | ENABLE | | | | ENABLE | ENABLE | <u> </u> | setting | | | | | DIS1HZ | DIS16HZ | RSTTMR | RSTALM | RE3 | RE2 | RE1 | RE0 | | RESTR | Reset | 328H | | | | V | | | | | | | Reg(Prohi | | | | 1 | Unde | fined | | | | | | bit RMW) | | 0: 1HZ | 0: 16HZ | 1: RESET | 1:RESET | !<br>! | Always | write 0. | | | | | | | | TIMER | ALARM | | | | | # (13) Melody/Alarm Generator | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |------------|------------------------------|---------|-----------------------------------|-----|-----------|-------------------------------------------|----------------------------------|--------|-----------|--------------|--|--| | | | | AL8 | AL7 | AL6 | AL5 | AL4 | AL3 | AL2 | AL1 | | | | | Alarm – | | R/W | | | | | | | | | | | ALM | Pattern | 330H | 0 | | | | | | | | | | | | Reg | | Alarm –Pattern set | | | | | | | | | | | | | | FC1 | FC0 | ALMINV | | | | | MELALM | | | | MEL-A | Melody/ | | R/ | W | R/W | | | | | R/W | | | | LMC | Alarm | trol | 0 | | 0 | | | | | 0 | | | | | Control | | Free-run counter Control | | Alarm | Always write 0 Outpu | | | | Output | | | | | Reg | | 00: Hold | | Frequency | | | | | Frequency 0: | | | | | | | 01: Restart | | Invert | | | | | Alarm | | | | | | | 10: Clear | | 1: Invert | 1: N | | | 1: Melody | | | | | | | | 11: Clear & Sta | | | | | | | | | | | | 34.1.1 | | ML7 ML6 ML5 ML4 ML3 ML2 ML1 ML0 | | | | | | | | | | | MELFL | Melody | 332Н | R/W | | | | | | | | | | | WIELIL | Frequency<br>L-Reg | | 0 Melody Frequency set (low 8bit) | | | | | | | | | | | | 2105 | | MELON | | | relouy Freque | ML11 | ML10 | ML9 | ML8 | | | | | Melody<br>Frequency<br>H-Reg | 333Н | R/W | | | | R/W | | | | | | | MELFH | | | 0 | | | | 0 | | | | | | | IVILIZE II | | | Melody | | | | Melody Frequency set (high 4bit) | | | | | | | | | r reg | | | | | Melody Frequency set (high 4bit) | | | | | | | | | | counter<br>Control | | | | | | | | | | | | | | 0: Stop and | | | | | | | | | | | | | | Clear | | | | | | | | | | | | | | 1: Start | | | | | | | | | | | | | | | | | IALM4E | IALM3E | IALM2E | IALM1E | IALM0E | | | | | Alarm | 334H | | | | | R/W | | | | | | | ALMINT | Interrupt | | | | | 0 | | | | | | | | | Enable | | | | Always | INTALM4 to INTALM0 Alarm Interrupt Enable | | | | | | | | | Reg | | | | write 0 | | | | | | | | ## (14) MMU | Symbol | Name | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|----------------------------|---------|------------|---|---|----------------------|--------|----------------------|--------|--------|--| | | | | L0E | | | | | L0EA22 | L0EA21 | L0EA20 | | | LOCAL | LOCAL0 | | R/W | | | | | | R/W | | | | 0 | Control<br>Reg | 350H | 0 | | | | | 0 | | | | | | | | 0: Disable | | | | | LOCAL0 area BANK set | | | | | | | | 1: Enable | | | | | | | | | | | LOCAL LOCAL1 1 Control Reg | 351H | L1E | | | | | L1EA23 | L1EA22 | L1EA21 | | | LOCAL | | | R/W | | | | | R/W | | | | | 1 | | | 0 | | | | | 0 | | | | | | | | 0: Disable | | | | | LOCAL1 area ANK set | | | | | | | | 1: Enable | | | | | | | | | | | | | L2E | | | | | L2EA23 | L2EA22 | L2EA21 | | | LOCAL | LOCAL2 | 352Н | R/W | | | | | R/W | | | | | 2 | Control<br>Reg | | 0 | | | | | 0 | | | | | | | | 0: Disable | | | | | LOCAL2 area BANK set | | | | | | | | 1: Enable | | | | | | | | | | | LOCAL3<br>Control<br>Reg | 353H | L3E | | | L3EA26 | L3EA25 | L3EA24 | L3EA23 | L3EA22 | | | LOCAL | | | R/W | | | | | R/W | | | | | 3 | | | 0 | | | | | 0 | | | | | | | | 0: Disable | | | LOCAL3 area BANK set | | | | | | | | | | 1: Enable | | | | | | | | | TOSHIBA TMP91C824 ## 6. Points to Note and Restrictions - (1) Notation - 1. The notation for built-in / I/O registers is as follows register symbol <br/> bit symbol> - e.g.) TA01RUN < TA0RUN > denotes bit TA0RUN of register TA01RUN. - 2. 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 bit 3 of TA01RUN. Example 2) INC 1, (100H) ... Increment the data at 100H. ``` • Examples of read-modify-write instructions on the TLCS-900 Exchange instruction ``` EX (mem), R ``` #### Arithmetic operations ``` ADD (mem), R/# ADC (mem), R/# SUB (mem), R/# SBC (mem), R/# INC #3, (mem) DEC #3, (mem) ``` #### Logic operations ``` AND (mem), R/# OR (mem), R/# XOR (mem), R/# ``` #### Bit manipulation operations ``` STCF #3/A, (mem) RES #3, (mem) SET #3, (mem) CHG #3, (mem) TSET #3, (mem) ``` #### Rotate and shift operations | RLC | (mem) | RRC | (mem) | |-----|-------|-----|-------| | RL | (mem) | RR | (mem) | | SLA | (mem) | SRA | (mem) | | SLL | (mem) | SRL | (mem) | | RLD | (mem) | RRD | (mem) | #### 3. fc, fs, $f_{\text{FPH}}$ , $f_{\text{SYS}}$ and one state The clock frequency input on ins X1 and 2 is called $f_{OSCH}$ . The clock selected by DFMCR0 <ACT1~ACT0> is called 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. #### (2) Points to note #### a) AM0 and AM1 pins This pin is connected to the VCC or the VSS pin. Do not alter the level when the pin is active. #### b) EMU0 and EMU1 Open pins. #### c) Reserved address areas The TMP91C815 does not have any reserved areas. #### 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 resistance The programmable pull-up 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. Px) are used to turn the pull-up/-down resistors ON/OFF. Consequently read-Modify-write instructions are prohibited. #### f) Bus release function It is described note point in "3.5 Port Function" that pin's condition at bus release condition. Please refer that. #### g) Watchdog timer The watchdog timer starts operation immediately after a Reset is released. When the watchdog timer is not to be used, disable it. #### h) AD converter The string resistor between the VREFH and VREFL pins can be cut by a program so as to reduce power consumption. When STOP Mode is used, disable the resistor using the program before the HALT instruction is executed. #### i) 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)). #### i) Undefined SFR The value of an undefined bit in an SFR is undefined when read. #### k) POP SR instruction Please execute the POP SR instruction during DI condition. # 8. 100 pin QFP (Flat Package) PACKAGE NAME: P-LQFP100-P-1414-0.5D