# CMOS 16-Bit Microcontrollers TMP91FY12AF # Outline and Features TMP91FY12AF is a high-speed 16-bit microcontroller designed for the control of various mid- to large-scale equipment. TMP91FY12AF comes in a 100-pin flat package. Listed below are the features. - (1) High-speed 16-bit CPU (900/L1 CPU) - Instruction mnemonics are upward-compatible with TLCS-90/900 - 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: 148 ns (at 27 MHz) - (3) Built-in RAM: 4 Kbytes Built-in ROM: 256 Kbytes Flash memory 2 Kbytes mask ROM (used for booting) - (4) External memory expansion - Expandable up to 16 Mbytes (shared program/data area) - Can simultaneously support 8-/16-bit width external data bus - · · · Dynamic data bus sizing - (5) 8-bit timers: 8 channels - (6) 16-bit timer/event counter: 2 channels - (7) General-purpose serial interface: 2 channels - UART/Synchronous mode: 2 channels - IrDA ver 1.0 (115.2 kbps) supported: 1 channel 000707EBP1 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 reliability of its products. Nevertheless, semiconductor devices in general - TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property. - In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc.. - Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc... The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. - The products described in this document are subject to the foreign exchange and foreign trade laws. The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by - 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. 91FY12A-1 2001-08-31 - (8) Serial bus interface: 1 channel - I<sup>2</sup>C bus mode/clock synchronous select mode - (9) 10-bit AD converter (sample-hold circuit is built in): 8 channels - (10) Watchdog timer - (11) Timer for real-time clock (RTC) - (12) Chip Select/Wait controller: 4 channels - (13) Interrupts: 45 interrupts - 9 CPU interrupts: Software interrupt instruction and illegal instruction 91FY12A-2 - 26 internal interrupts: 7-level priority can be set. - 10 external interrupts: 7-level priority can be set. - (14) Input/output ports: 81 pins - (15) Standby function Three Halt modes: Idle2 (programmable), Idle1, Stop - (16) Triple-clock controller - Clock Doubler (DFM) - Clock Gear (fc to fc/16) - Slow mode (fs = 32.768 kHz) - (17) Operating voltage - $V_{CC} = 2.7 \text{ V to } 3.6 \text{ V (fc max} = 27 \text{ MHz)}$ - (18) Package - 100-pin QFP: P-QFP100-1414-0.50E Figure 1.1 TMP91FY12AF Block Diagram # 2. Pin Assignment and Pin Functions The assignment of input/output pins for the TMP91FY12AF, their names and functions are as follows: # 2.1 Pin Assignment Diagram Figure 2.1.1 shows the pin assignment of the TMP91FY12AF. Figure 2.1.1 Pin assignment diagram (100-pin QFP) # 2.2 Pin Names and Functions The names of the input/output pins and their functions are described below. Table 2.2.1 Pin names and functions. Table 2.2.1 Pin names and functions (1/3) | | | Tubic 2.2. | Fin names and functions (1/3) | |--------------------------|----------------|------------|-------------------------------------------------------------------------| | Pin Name | Number of Pins | I/O | Functions | | P00 to P07 | 8 | I/O | Port 0: I/O port that allows I/O to be selected at the bit level | | AD0 to AD7 | | Tri-state | Address and data (lower): Bits 0 to 7 of address and data bus | | P10 to P17 | 8 | I/O | Port 1: I/O port that allows I/O to be selected at the bit level | | AD8 to AD15 | | Tri-state | Address and data (upper): Bits 8 to 15 for address and data bus | | A8 to A15 | | Output | Address: Bits 8 to 15 of address bus | | P20 to P27 | 8 | I/O | Port 2: I/O port that allows I/O to be selected at the bit level | | | | | (with pull-down resistor) | | A0 to A7 | | Output | Address: Bits 0 to 7 of address bus | | A16 to A23 | | Output | Address: Bits 16 to 23 of address bus | | P30 | 1 | Output | Port 30: Output port | | RD | | Output | Read: Strobe signal for reading external memory | | P31 | 1 | Output | Port 31: Output port | | WR | | Output | Write: Strobe signal for writing data to pins AD0 to AD7 | | P32 | 1 | I/O | Port 32: I/O port (with pull-up resistor) | | HWR | | Output | High Write: Strobe signal for writing data to pins AD8 to AD15 | | P33 | 1 | I/O | Port 33: I/O port (with pull-up resistor) | | WAIT | | Input | Wait: Pin used to request CPU bus wait | | P34 | 1 | I/O | Port 34: I/O port (with pull-up resistor) | | BUSRQ | | Input | Bus Request: Signal used to request Bus Release | | P35 | 1 | I/O | Port 35: I/O port (with pull-up resistor) | | BUSAK | | Output | Bus Acknowledge: Signal used to acknowledge Bus Release | | P36 | 1 | I/O | Port 36: I/O port (with pull-up resistor) | | R/ W | | Output | Read/Write: 1 represents Read or Dummy cycle; 0 represents Write cycle. | | P37 | 1 | I/O | Port 37: I/O port (with pull-up resistor) | | BOOT | | Input | This pin sets single boot mode. | | P40 | 1 | I/O | Port 40: I/O port (with pull-up resistor) | | <del>CS0</del> | ' | Output | Chip Select 0: Outputs 0 when address is within specified address area | | P41 | | I/O | Port 41: I/O port (with pull-up resistor) | | <u>CS1</u> | 1 | Output | Chip Select 1: Outputs 0 if address is within specified address area | | P42 | | I/O | Port 42: I/O port (with pull-up resistor) | | <u>CS2</u> | 1 | Output | Chip Select 2: Outputs 0 if address is within specified address area | | P43 | | I/O | Port 43: I/O port (with pull-up resistor) | | <u>CS3</u> | 1 | | Chip Select 3: Outputs 0 if address is within specified address area | | | | Output | · | | P50 to P57<br>AN0 to AN7 | 8 | Input | Port 5: pin used to input port | | ANU to AN7 ADTRG | | Input | Analog input: Pin used to input to AD converter | | | | Input | AD Trigger: Signal used to request start of AD converter | | P60 | 1 | 1/0 | Port 60: I/O port | | SCK | | 1/0 | Serial bus interface clock in SIO Mode | | P61 | 1 | I/O | Port 61: I/O port | | SO | | Output | Serial bus interface output data in SIO Mode | | SDA | | I/O | Serial bus interface data in I <sup>2</sup> C bus Mode | | P62 | 1 | I/O | Port 62: I/O port | | SI | | Input | Serial bus interface input data in SIO Mode | | SCL | | I/O | Serial bus interface clock in I <sup>2</sup> C bus Mode | | P63 | 1 | I/O | Port 63: I/O port | | INT0 | | Input | Interrupt Request Pin 0: Interrupt request pin with programmable | | | | | level / rising edge / falling edge | | P64 | 1 | I/O | Port 64: I/O port | | SCOUT | | Output | System Clock Output: Outputs f <sub>FPH</sub> or fs clock. | Table 2.2.1 Pin names and functions (2/3) | Pin Name | Number of Pins | I/O | Functions | |----------|----------------|--------|------------------------------------------------------------------------------| | P65 | 1 | I/O | Port 65: I/O port | | P66 | 1 | I/O | Port 66: I/O port | | P70 | 1 | I/O | Port 70: I/O port | | TA0IN | | Input | Timer A0 Input | | P71 | 1 | I/O | Port 71: I/O port | | TA1OUT | | Output | Timer A1 Output | | P72 | 1 | I/O | Port 72: I/O port | | TA3OUT | | Output | Timer A3 Output | | P73 | 1 | I/O | Port 73: I/O port | | TA4IN | | Input | Timer A4 Input | | P74 | 1 | I/O | Port 74: I/O port | | TA5OUT | | Output | Timer A5 Output | | P75 | 1 | I/O | Port 75: I/O port | | TA7OUT | | Output | Timer A7 Output | | P80 | 1 | I/O | Port 80: I/O port | | TB0IN0 | | Input | Timer B0 Input 0 | | INT5 | | Input | Interrupt Request Pin 5: Interrupt request pin with programmable rising edge | | | | · | / falling edge. | | P81 | 1 | I/O | Port 81: I/O port | | TB0IN1 | | Input | Timer B0 Input 1 | | INT6 | | Input | Interrupt Request Pin 6: Interrupt request on rising edge | | P82 | 1 | I/O | Port 82: I/O port | | TB0OUT0 | | Output | Timer B0 Output 0 | | P83 | 1 | I/O | Port 83: I/O port | | TB0OUT1 | | Output | Timer B0 Output 1 | | P84 | 1 | I/O | Port 84: I/O port | | TB1IN0 | | Input | Timer B1 Input 0 | | INT7 | | Input | Interrupt Request Pin 7: Interrupt request pin with programmable rising edge | | | | · | / falling edge. | | P85 | 1 | I/O | Port 85: I/O port | | TB1IN1 | | Input | Timer B1 Input 1 | | INT8 | | Input | Interrupt Request Pin 8: Interrupt request on rising edge | | P86 | 1 | I/O | Port 86: I/O port | | TB1OUT0 | | Output | Timer B1 Output 0 | | P87 | 1 | I/O | Port 87: I/O port | | TB1OUT1 | | Output | Timer B1 Output 1 | | P90 | 1 | I/O | Port 90: I/O port | | TXD0 | | Output | Serial Send Data 0 (Programmable open-drain) | | P91 | 1 | I/O | Port 91: I/O port | | RXD0 | | Input | Serial Receive Data 0 | | P92 | 1 | I/O | Port 92: I/O port | | SCLK0 | | 1/0 | Serial Clock I/O 0 | | CTS0 | | Input | Serial Data Send Enable 0 (Clear to Send) | | P93 | 1 | 1/0 | Port 93: I/O port | | TXD1 | | Output | Serial Send Data 1 (Programmable open-drain) | | P94 | 1 | 1/0 | Port 94: I/O port (with pull-up resistor) | | RXD1 | | Input | Serial Receive Data 1 | | P95 | 1 | 1/0 | Port 95: I/O port (with pull-up resistor) | | SCLK1 | | 1/0 | Serial Clock I/O 1 | | CTS1 | | Input | Serial Data Send Enable 1 (Clear to Send) | | P96 | 1 | I/O | Port 96: I/O port (Open-drain output) | | XT1 | ' | Input | Low-frequency oscillator connection pin | Table 2.2.1 Pin names and functions (3/3) | Pin Name | Number of Pins | I/O | Functions | |--------------|----------------|--------|-----------------------------------------------------------------------------------------------------| | P97 | 1 | I/O | Port 97: I/O port (Open-drain output) | | XT2 | | Output | Low-frequency oscillator connection pin | | PA0 to PA3 | 4 | I/O | Ports A0 to A3: I/O ports | | INT1 to INT4 | | Input | Interrupt Request Pins 1 to 4: Interrupt request pins with programmable rising edge / falling edge. | | PA4 to PA7 | 4 | I/O | Ports A4 to A7: I/O ports | | ALE | 1 | Output | Address Latch Enable | | | | | Can be disabled to reduce noise. | | NMI | 1 | Input | Non-Maskable Interrupt Request Pin: Interrupt request pin with | | | | | programmable falling edge or both edge. | | AM0 to 1 | 2 | Input | Address Mode: The Vcc pin should be connected. | | EMU0/EMU1 | 1 | Output | Test Pins: Open pins | | RESET | 1 | Input | Reset: initializes TMP91FY12A. (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 connected with the power supply | | | | | pin.) | | DVSS | 3 | | GND pins (0 V) (All VSS pins should be connected with the power supply | | | | | pin.) | Note: An external DMA controller cannot access the device's built-in memory or built-in I/O devices using the BUSRQ and BUSAK signal. # 3. Functional Description This section shows the hardware configuration of the TMP91FY12A and explains how it operates. This device is a version of the created by replacing the predecessor's internal mask ROM with a 256-Kbyte internal flash memory. The configuration and the functionality of this device are the same as those of the TMP91CW12A. For the functions of this device that are not described here, refer to the TMP91CW12A data sheet. # 3.1 Outline of operation modes There are single-chip and single-boot modes. Which mode is selected depends on the device's pin state after a reset (including when the watchdog timer output is connected to reset (inside the chip)). • Single Chip Mode: The device normally operates in this mode. After a reset, the device starts executing the internal flash memory program. • Single Boot Mode: This mode is used to rewrite the internal flash memory by serial transfer (UART). After a reset, the internal boot ROM starts up, executing a on-board rewrite program. Table 3.1.1 Operation Mode Setup table | | | • | • | | | | | | | | | |------------------------------|-------|----------------------|-----|-----|--|--|--|--|--|--|--| | O a construction of the last | | Mode Setup Input Pin | | | | | | | | | | | Operation Mode | RESET | BOOT (P37) | AM0 | AM1 | | | | | | | | | Single-chip mode | 1 | Н | | 11 | | | | | | | | | Single-boot mode | / | L | П | П | | | | | | | | # 3.2 Memory Map The memory map of this device differs from that of the TMP91CW12A. Figure 3.2.1 shows a memory map of the device in single-chip mode and its memory areas that can be accessed in each addressing mode of the CPU. Figure 3.2.1 Memory Map (Single-chip Mode) # 3.3 Flash memory The TMP91FY12A contains an electrically erasable and programmable flash memory using a single 3 V power supply. The standard JEDEC commands are used to electrically erase and program this flash memory. Once commands are entered, programming and erasure are automatically performed inside the chip. In addition, there are several methods for erasing the flash memory, so that it can be erased the entire chip collectively, one block at a time, of multiple blocks together. #### Features: • Program/Erase power supply voltage $$Vcc = 2.7 \text{ to } 3.6 \text{ V}$$ • Structure Functions Automatic program Automatic erase Automatic multiblock erase Data Polling/toggle bit • Block erase architecture ``` 16 Kbytes x 1/8 Kbytes x 2/ 32 Kbytes x 1/64 Kbytes x 3 ``` Mode control Based on standard JEDEC commands General-purpose flash memory type Equivalent to 29LV400T \* Some functions such as block protect are not supported, however. #### Block structure: xx: Depends on the microcomputer's operation mode. Figure 3.3.1 Block structure of the Flash Memory Command Sequence: Flash memory access by the internal CPU (Single-boot and user-boot modes) | <u> </u> | single boot and door boot modes) | | | | | | | | | | | | | |---------------------|----------------------------------|------------------|------|------------------------|------|---------------------|------|--------------------------------|------|------------------------|------|------------------------|------| | Command<br>Sequence | Bus<br>cycle | 1st b<br>write c | | 2nd bus<br>write cycle | | 3rd bus write cycle | | 4th bus<br>read/write<br>cycle | | 5th bus<br>write cycle | | 6th bus<br>write cycle | | | | , | Addr. | Data | Addr. | Data | Addr. | Data | Addr. | Data | Addr. | Data | Addr. | Data | | Read/Reset | 1 | xXXXXH | F0H | | | | | | | | | | | | Read/Reset | 3 | хААААН | AAH | x5554H | 55H | xAAAAH | F0H | RA | RD | | | | | | Auto-<br>program | 4 | хААААН | ААН | x5554H | 55H | хААААН | A0H | PA | PD | | | | | | Auto-Chip erase | 6 | хААААН | ААН | x5554H | 55H | хААААН | 80H | хААААН | ААН | x5554H | 55H | хААААН | 10H | | Auto-Block erase | 6 | хААААН | ААН | x5554H | 55H | хААААН | 80H | хААААН | ААН | x5554H | 55H | ВА | 30H | The addresses viewed from the CPU side are shown in the table below. | Command address | | CPUaddress: A23 to A0 | | | | | | | | | | | | | | | | |-----------------|--------------|-------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---| | Addr. | A23 to A16 | 23 to A16 A15 A14 A13 A12 A11 A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 | | | | | | | | | | | | | | | | | xXXXXH | Flash | Х | Х | Х | Х | Х | Х | Χ | Χ | Х | Χ | Х | Χ | Х | Χ | Х | 0 | | хААААН | memory | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | x5554H | address area | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | F0H, AAH, 55H, A0H, 80H, 10H, 30H: Command data. Write to DQ7 to DQ0. RA: Read address RD: Read data output Data is read out in units of bytes/words. PA: Program address PD: Program data output Data is written to every even address in units of words. BA: Block address. Each individual block is selected by a combination of A17, A16, A15, A14 and A13. # Hardware sequence Flag List: Flash memory access by the internal CPU | | Status | DQ7 | DQ6 | DQ5 | DQ3 | |------------------------|----------------------------------|-----------------|--------|-----|-----| | Automatic | Auto program | DQ7<br>inverted | toggle | 0 | 0 | | operation under | Auto erase(on erasing hold time) | 0 | toggle | 0 | 0 | | execution | Auto erase | 0 | toggle | 0 | 1 | | Time-out<br>(automatic | Auto program | DQ7<br>inverted | toggle | 1 | 1 | | operation failed) | Auto erase | 0 | toggle | 1 | 1 | Note: DQ8 to DQ15, DQ0 to DQ2 are Don't care. <sup>\*:</sup> The two reset commands each can reset the device to read mode. **TOSHIBA** | Dlook | Ad | ldress i | n Sing | le Moc | le | Address | s Range | Cizo | |-------|-----|----------|--------|--------|-----|--------------------|--------------------|----------| | Block | A17 | A16 | A15 | A14 | A13 | Single chip | Single boot | Size | | BA0 | L | L | Х | Х | Х | FC0000H to FCFFFFH | 010000H to 01FFFFH | 64 Kbyte | | BA1 | L | Н | х | х | х | FD0000H to FDFFFFH | 020000H to 02FFFFH | 64 Kbyte | | BA2 | Н | L | х | х | х | FE0000H to FEFFFFH | 030000H to 03FFFFH | 64 Kbyte | | BA3 | Н | Н | L | Х | х | FF0000H to FF7FFFH | 040000H to 047FFFH | 32 Kbyte | | BA4 | Н | Н | Н | L | L | FF8000H to FF9FFFH | 048000H to 049FFFH | 8 Kbyte | | BA5 | Н | Н | Н | L | Н | FFA000H to FFBFFFH | 04A000H to 04BFFFH | 8 Kbyte | | BA6 | Н | Н | Н | Н | х | FFC000H to FFFFFH | 04C000H to 04FFFFH | 16 Kbyte | Block erase address Table: Flash memory access by the internal CPU Basic operation: Flash memory access by the internal CPU Broadly classified, this flash memory has two operation modes. These are "Read Mode" in which memory data is read out and "Automatic Operation Mode" in which memory data are automatically erased/ rewritten. Automatic operation mode can be entered by executing a command sequence in read mode. No memory data can be read out during automatic operation mode. ### (1) Read To read data from the flash memory, place it in read mode. Immediately after power-on or when automatic operation has terminated normally, the flash memory goes to read mode. When automatic operation has terminated abnormally or you want read mode to be restored from the other mode, use the reset command that is described later. #### (2) Command write This flash memory users JEDEC-compliant command control method provided for standard E<sup>2</sup>PROMs. Writing to the command register is accomplished by issuing a command sequence to the flash memory. The flash memory latches the entered address and date into the command register as it executes instructions. To enter command data, use DQ0 to DQ7. Inputs to DQ8 to DQ15 are ignored. If you want to cancel commands in the middle of a command sequence being entered, issue the reset command. Upon accepting the reset command, the flash memory resets the command register and enters read mode. Also, when an incorrect command sequence is entered, the flash memory resets the command register and enters read mode. #### (3) Reset (reset command) When automatic operation has terminated abnormally, the flash memory does not return to read mode. In this case, use the read/reset command to have the flash memory return to read mode. Also, if you want to cancel a command in the middle while entering it, you can use the read/reset command. It clears the content of the command register. ### (4) Auto program Write to the flash memory is performed every even address in units of words. In Auto program operation, the program address and program data are latched every even addresses in units of words in the 4th bus write cycle of the command cycle. Upon latching the program data, the flash memory starts auto-programming. Once this operation begins, programming and program verification are automatically performed inside the chip. The status of Auto program operation can be confirmed by checking the hardware sequence flag. During Auto program operation, command sequences you enter cannot be accepted. In Writing to the flash memory, the cells that contain data 1 can be turned to data 0, but the cells that contain data 0 cannot be turned to data 1. To change the data 0 cells to data 1, you need to perform an erase operation. If Auto program fails, the flash memory is locked in that mode and does not return to read mode. This status can be confirmed by checking the hardware sequence flag. When in this state, the flash memory needs to be reset by the reset command. Since in this case writing to the address concerned has failed, the memory block that includes this address is faulty. Therefore, make sure this block will not be used. ### (5) Auto chip erase Auto chip erase begins from the 6th bus write cycle of the command cycle ended. Once Auto chip erase starts, all addresses of the flash memory are preprogrammed with data 0, with the contents then erased and verified for erasure. All this operation is performed automatically inside the chip. The status of Auto chip ease operation can be confirmed by checking the hardware sequence flag. During Auto chip erase operation, command sequences you enter cannot be accepted. If Auto chip erase fails, the flash memory is locked in that mode and does not return to read mode. This status can be confirmed by checking the hardware sequence flag. Reset the flash memory by using the reset command. The block in which the failure occurred cannot be detected. Therefore, you need to stop using the device or locate the faulty block by executing block erase. Make sure the faulty block thus found will not be used. #### (6) Auto block erase and Auto multiblock erase Auto block erase begins from the 6th bus write cycle of the command cycle ended after an elapse of the erase hold time. Once Auto block erase starts, all address of selected block are preprogrammed with data 0, with the contents then erased and verified for erasure. All this operation is performed automatically inside the chip. To erase multiple blocks, repeat the 6th bus write cycle and while so doing, enter each block address and the Auto block erase command within the erase hold time. If any other command sequence than Auto block erase is entered during the erase hold time, the flash memory is reset and placed in read mode. The erase hold time is $50~\mu s$ , and count starts each time the 6th bus write cycle has ended. The status of Auto block erase operation can be confirmed by checking the hardware sequence flag. During Auto block erase, command sequences you enter cannot be accepted. If Auto block erase fails, the flash memory is locked in that mode and does not return to read mode. This status can be confirmed by checking the hardware sequence flag. Reset the flash memory by using the reset command. If multiple blocks have been selected, the block in which the failure occurred cannot be detected. Therefore, you need to stop using the device or locate the faulty block by executing block erase for each block individually. Make sure the faulty block thus found will not e used. ## (7) Hardware sequence flags The hardware sequence flag allows you to confirm the status of the flash memory automatic operation being executed. During automatic operation, data can read from memory at the same timing as in read mode. When the flash memory finishes automatic operation, it automatically returns to read mode. The operating status when automatic operation is being executed can be confirmed by checking the hardware sequence flag, and the status after automatic operation is completed can be confirmed by checking whether the data read from memory matches its cell data. ## 1) DQ7 (DATA polling) The DATA polling function allows you to confirm the status of the flash memory automatic operation. The DATA polling output begins from the last bus write cycle of the automatic operation command sequence ended. During Auto program operation, the data that has been written to DQ7 is output after being inverted; after the operation is completed, the cell data in DQ7 is output. By reading data out of DQ7, you can identify the operating status. During Auto erase operation, data 0 is output from DQ7; after the operation is completed, data 1 (cell data) is output. If the automatic operation resulted in failure, DQ7 continues outputting the same data that was written to it during automatic operation. The flash memory frees address latch upon completion of operation, so that when you read data from memory you must enter the address to which data has been written or any block address being erased. ### 2) DQ6 (toggle bit) In addition to the DATA polling, you can use a toggle bit output function to recognize the status of automatic operation. Toggle output begins from the last bus write cycle of the automatic operation command sequence ended. This toggle is output to DQ6, with data 1 and 0 output alternately for each read cycle performed. When the automatic operation is complete, DQ6 stops outputting the toggle and instead, outputs its cell data. If the automatic operation has failed, DQ6 continues outputting the toggle. ### 3) DQ5 (internal timer overtime) When performing automatic operation normally, the flash memory outputs a 0 to DQ5. If the automatic operation exceeds the flash memory's internally predetermined time, the DQ5 output changes to a 1. This means that the automatic operation did not terminate normally, and that the flash memory probably is faulty. However, when data 1 is written to the data 0 cell, DQ5 outputs a 1, providing misleading information that the flash memory is faulty. (The flash memory is designed in such a way that although the data 1 cells can be turned to data 0 in program mode, the data 0 cells cannot be turned to data 1.) In the above case, DQ5 is not showing that flash memory is faulty, but that the method of command usage is incorrect. If the automatic operation did not terminate normally, the flash memory is locked and does not return to read mode. Therefor, reset the flash memory using the reset command. ### 4) DQ3 (block erase timer) Auto block erase begins from the 6th bus write cycle of the command cycle ended after an elapse of the erase hold time (80 $\mu s$ ). The flash memory outputs a 0 to DQ3 when in the erase hold time and a 1 when it starts erasing. When you want to add a block to be erased, enter it during the block erase hold time. Every time you enter the erase command for each block, the flash memory resets the block erase hold time and starts counting over again. If the automatic operation resulted in failure, DQ3 outputs a 1. ### 5) RDY/BSY (ready/busy) \* This function cannot be used because the flash memory is not connected to the internal CPU. ### (8) Flash memory rewrite by the internal CPU Flash memory rewrite by the internal CPU is accomplished by using the command sequence and hardware sequence flags described above. However, since the built-in flash memory does not read data from its memory cells during automatic operation mode, the rewrite program must be executed external to the flash memory. There are two methods for flash memory rewrite by the internal CPU. One method uses the single-boot mode prepared in advance; the other method runs the user's original protocol in single-chip mode (user boot). ## 1) Single boot: In this method, the micorocomputer is started in single-boot mode and the flash memory is rewritten using the internal boot ROM program. In this mode, the internal boot ROM is mapped into an area that includes the interrupt vector table, and the boot ROM program is executed in that area. The flash memory is mapped into another address space separately from the boot ROM area. The boot ROM program mainly performs two operations: taking in the rewrite data by serial transfer and rewriting the flash memory. Single boot needs to be performed while interrupts are disabled. Make sure nonmaskable interrupts (e.g., NMI) also are disabled before performing single boot. For details, refer to Section 3.4, "Single Boot Mode." #### 2) User boot: This method runs the user's original flash memory rewrite program. Execute the program in single-chip mode (regular operation mode). In this mode too, the flash memory rewrite program must be executed in another address space separately from that of the flash memory. As in the case of single boot, nonmaskable and all other interrupts must be disabled before performing user boot. The flash memory rewrite program including routines for taking in the rewrite data and rewriting the flash memory needs to be prepared in advance. When in the main program, switch from regular operation to the flash memory rewrite operation, then execute the flash memory rewrite program you've prepared after expanding it into somewhere outside the flash memory area. For example, you can execute the flash memory rewrite program after expanding it from flash memory into internal RAM or after preparing it in external memory. Flowchart: Flash memory access by the internal CPU ### Auto program command sequence (address/command) # Auto erase Auto Chip erase command sequence (Address/Command) Auto Block/Multi Block erase command sequence (Address/Command) # DQ7 DATA polling # DQ6 Toggle bit VA: Programmed address at auto program. Flash memory address at auto chip erase. Selected block address at auto block erase. # 3.4 Single Boot Mode ## (1) Outline TMP91FY12A has single-boot mode available as an on-board programming operation mode. When in single-boot mode, the boot ROM is mapped into memory space. This boot ROM is a mask ROM that contains a program to rewrite the flash memory on-board. On-board programming is accomplished by first connecting the device's SIO (channel 1) and programming tool (controller) and then sending commands from the controller to the target board. The boot program included in the boot ROM also has the function of a loader, so it can transfer program data from an external source into the device's internal RAM. Figure 3.4.1 shows an example of how to connect the programming controller and the target board. Figure 3.4.1 Example for Connecting Units for On-board Programming Note: One of the programming controllers supported for the TMP91FY12A is the AF210, AF220, AF110, AF120 (Advanced On-board Flash Microcomputer Programmer) from YDC Co. For details, refer to the manual included with the AF210, AF220, AF110, AF120. Where to contact: YDC Co. Instruments Business Division, Instruments Development Center TEL: 81-42-333-6224 ### (2) Mode setting To execute on-board programming, start the TMP91FY12A in Single Boot mode as follows: $\begin{array}{ccc} AM0 & = & H \\ AM1 & = & H \\ \hline BOOT & (P37) & = & L \\ \hline RESET & = & \checkmark \end{array}$ After setting the AM0, AM1, and $\overline{BOOT}$ pins each to the above conditions, drive the signal input to the $\overline{RESET}$ pin high. The TMP91FY12A starts up in single-boot mode. ### (3) Memory map Figure 3.4.2 compares memory maps in single-chip and the single-boot modes. When in single boot mode, the internal flash memory is mapped into addresses 1000H through 4FFFFH, as shown here. You'll also find that the boot ROM (MROM) is mapped into addresses FFF800H through FFFFFFH. Figure 3.4.2 Comparison of Memory Maps ### (4) Interface specifications The following shows the SIO communication format used in single-boot mode. Before on-board programming can be executed, the communication format on the programming controller side must also be set up in the same way as for the TMP91FY12A. Note that although the default baud rate is 9,600 bps, it can be changed to other values as shown in Table 3.4.1. Communication channel: SIO channel 1 Serial transfer mode : UART(asynchronous communication) mode, full-duplex communication Data length : 8 bits Parity bit : None Stop bit : 1 bit Baud rate (default) : 9600bps ## (5) Data transfer format Table 3.4.1 through Table 3.4.7 show the baud rate modification data, operation commands, and data transfer format in each operation mode, respectively. Also refer to the description of boot program operation in the latter pages of this manual as you read these tables. Table 3.4.1 Baud rate modification data | Baud rate modification data | 04H | 05H | 06H | 07H | 0AH | 18H | 28H | |-----------------------------|-------|-------|-------|-------|-------|-------|------| | Baud rate(bps) | 76800 | 62500 | 57600 | 38400 | 31250 | 19200 | 9600 | Note: The baud rates currently supported by the AF200 are 9600, 19200, 31250, and 62500 bps only. Table 3.4.2 Operating command data | Operation command data | Operation mode | |------------------------|----------------------| | 30H | Flash memory rewrite | | 60H | RAM Loader | | 90H | Flash memory SUM | Table 3.4.3 Operating frequency and baud rate in Single Boot mode: TMP91FY12A | _ | | ıau | ole 3 | 5.4. | 3 ( | Jpe | erat | ıng | Tre | que | ency | / ar | ום ג | au | a ra | ite i | ın S | ing | ie i | 300 | ot m | oae | e: I | MP | |---------------------------|-----------------------|-----------------|--------------|--------------|-----------|--------------|--------------|--------------|--------|---------------|-------|----------------|-------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------------------------------|----------------|-----------------|---------------| | 76800 | 04h | (%) | 0 | +1.73 | | I | 1 | 1 | 0 | +1.73 | I | I | 1 | 0 | 1 | I | 0 | +1.73 | I | I | 0 | +1.73 | I | - | | 392 | 70 | (sdq) | 76800 | 78125 | 1 | 1 | 1 | 1 | 76800 | 78125 | 1 | 1 | 1 | 76800 | 1 | 1 | 76800 | 78125 | 1 | 1 | 76800 | 78125 | 1 | 1 | | 62500 | 05h | (%) | - | 1 | I | I | ı | 0 | I | 1 | 0 | +2.4 | +4.17 | I | 0 | I | 7.1- | 0 | I | I | +2.4 | +4.17 | I | 1 | | 62 | Ö | (sdq) | - | 1 | | 1 | I | 62500 | I | 1 | 62500 | 64000 | 65104 | | 62500 | I | 61440 | 62500 | 1 | 1 | 64000 | 65104 | I | 1 | | 27600 | 06h | (%) | — | _ | _ | _ | 0 | 1 | _ | 1 | _ | _ | 1 | 0 | _ | -2.34 | 1 | — | -4.24 | 0 | -4.76 | -3.12 | _ | 1 | | 929 | 90 | (sdq) | — | _ | — | _ | 27600 | _ | _ | _ | _ | _ | _ | 00929 | — | 26250 | _ | — | 55156 | 00929 | 54857 | 55804 | _ | 1 | | 38400 | 07h | (%) | 0 | +1.73 | — | _ | 0 | - | 0 | +1.73 | -2.34 | 0 | +1.73 | 0 | — | _ | 0 | +1.73 | 4.24 | 0 | 0 | +1.73 | <b>2</b> 9'0- | -0.13 | | 788 | <u> 1</u> 0 | (sdq) | 38400 | £906£ | — | _ | 38400 | _ | 38400 | 39063 | 37500 | 38400 | 39063 | 38400 | — | _ | 38400 | 89068 | 12298 | 38400 | 38400 | £906£ | 38182 | 38352 | | 31250 | 0Ah | (%) | | 1 | 0 | +2.4 | 1 | 0 | -1.7 | 0 | 0 | +2.4 | +4.17 | +5.3 | 0 | 0 | -1.7 | 0 | -3.73 | +0.54 | +2.4 | +4.17 | 4- | -3.57 | | 312 | /0 | (bps) | | 1 | 31250 | 32000 | 1 | 31250 | 30720 | 31250 | 31250 | 32000 | 32552 | 32914 | 31250 | 31250 | 30720 | 31250 | 30085 | 31418 | 32000 | 32552 | 30000 | 30134 | | 19200 | 18h | (%) | 0 | +1.72 | -2.34 | 0 | 0 | _ | 0 | +1.72 | -2.34 | 0 | +1.72 | 0 | +0.16 | -2.34 | 0 | +1.72 | 4.24 | 0 | 0 | +1.72 | 75.0- | -0.13 | | 761 | 18 | (sdq) | 19200 | 19531 | 18750 | 19200 | 19200 | 1 | 19200 | 19531 | 18750 | 19200 | 19531 | 19200 | 19231 | 18750 | 19200 | 19531 | 18385 | 19200 | 19200 | 19531 | 19061 | 19176 | | | | (%) | 0 | +1.73 | -2.34 | 0 | 0 | +0.16 | 0 | +1.73 | -2.34 | 0 | +1.73 | 0 | +0.16 | -2.34 | 0 | +1.73 | 4.24 | 0 | 0 | +1.73 | <b>29</b> '0- | -0.13 | | 0096 | 28h | Baud rate (bps) | 9600 | 9926 | 9375 | 0096 | 0096 | 9615 | 0096 | 9926 | 9375 | 0096 | 9926 | 0096 | 9615 | 9375 | 0096 | 9766 | 9193 | 0096 | 0096 | 9926 | 9545 | 9588 | | ate (bps) | ge data | Area (MHz) | 1 05 10 5 07 | 4.60 10 3.07 | 04 1-0 00 | 57.0 01 18.0 | 7.26 to 7.48 | 7.84 to 8.16 | 0.00 | 9.64 10 10.20 | | 11.76 to 12.75 | | 14.46 to 15.04 | 15.68 to 16.32 | 17.64 to 18.36 | 40 02 1- 00 40 | 19.27 10 20.40 | 03 00 -1 02 00 | 20.79 10 22.39 | 0 - 1 - 0 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | 74.09 to 25.50 | 7 2 20 27 30 30 | 40.72 U 27.34 | | Reference baud rate (bps) | Baud rate change data | Ref. Xtal (MHz) | 4.9152 | 5 | 9 | 6.144 | 7.3728 | 8 | 9.8304 | 10 | 12 | 12.288 | 12.5 | 14.7456 | 16 | 18 | 19.6608 | 20 | 21.18 | 22.1184 | 24.5760 | 25 | 26.88 | 27 | Reference frequency. High speed oscillator frequency supported in Single boot mode. When the Single boot mode is used for programming Flash memory, each of reference frequency should be used. Note: The Auto-detection of MCU operating frequency will be normally done when the total error between transmit baud rate (9600bps) of program controller, oscillator frequency and Area: Clock frequency area detected for reference frequency. The Single boot would not be executed at the others frequency. detecting timing of matching data is under +/-3%. Table 3.4.4 Boot Program Transfer format (For Flash Memory Rewrite) | | | | · · · · · · · · · · · · · · · · · · · | <u> </u> | |------|-----------------------------------|------------------------------------------------|---------------------------------------|----------------------------------------------------------------| | | Number of<br>Bytes<br>Transferred | Transfer Data from Controller<br>to TMP91FY12A | Baud rate | Transfer Data from TMP91FY12A to Controller | | воот | 1st byte | Matching data (5AH) | 9600 bps | <ul><li>(baud rate auto set)</li></ul> | | ROM | 2nd byte | _ | 9600 bps | OK: Echoback data (5AH) | | | - | | | NG: Nothing Transmitted. | | | 3rd byte | Baud rate modification data (See Table 3.4.1) | 9600 bps | - | | | 4th byte | (See Table 3.4.1) | 9600 bps | OK: Echoback data | | | 4tii byte | | 3000 bps | NG: A1H $\times$ 3, A2H $\times$ 3, A3H $\times$ 3 (Note 1) | | | 5th byte | Operation command data (30H) | Changed new baud rate | NO. ATT > 0, AZT > 0, AST > 0 (NOIC 1) | | | 1 | Operation command data (30H) | - | OK: Echahack data (20H) | | | 6th byte | _ | Changed new baud rate | OK: Echoback data (30H) NG: A1H × 3, A2H × 3, A3H × 3, 63H × 3 | | | 745 5.45 | | Chanada a suu b suud saks | | | | 7th byte | _ | Changed new baud rate | OK: C1H | | | 0.1.1.1 | | | NG: 64H×3 | | | 8th byte | Expanded | Changed new baud rate | _ | | | : | Intel Hex format (binary) (Note 2) | | | | | n'th – 2 byte | | | | | | n'th – 1 byte | _ | Changed new baud rate | OK: SUM (High) | | | | | | NG: Nothing Transmitted. (Note 3) | | | n'th byte | _ | Changed new baud rate | OK: SUM (Low) | | | | | | NG: Nothing Transmitted. (Note 3) | | | n'th + 1 byte | (Wait for next operation command data.) | Changed new baud rate | _ | - Note 1: $xxH \times 3$ denoes that operation stops after sending 3 bytes of xxH. - Note 2: Refer to the "Notes on Expanded Intel Hex Format (binary)" in the latter page of this manual. - Note 3: Refer to the "Notes on Sum" in the latter page of this manual. Table 3.4.5 Transfer Format for Boot Program: For RAM Loader | | Number of<br>Bytes<br>Transferred | Transfer Data from Controller to TMP91FY12A | Baud rate | Transfer Data from TMP91FY12A to Controller | |-------------|-----------------------------------|--------------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------| | BOOT<br>ROM | 1st byte<br>2nd byte | Matching data (5AH) - | 9600bps<br>9600bps | (baud rate auto set) OK: Echoback data (5AH) NG: Nothing Transmitted. | | | 3rd byte | Baud rate modification data (See Table 3.4.1) | 9600bps | _ | | | 4th byte | - | 9600bps | OK: Echoback data NG: A1H $\times$ 3, A2H $\times$ 3, A3H $\times$ 3, 62H $\times$ 3 (Note 1) | | | 5th byte | Operation command data (60H) | Changed new baud rate | - | | | 6th byte | _ | Changed new baud rate | OK: Echoback data (30H) NG: A1H × 3, A2H × 3, A3H × 3, 63H × 3 | | | 7th byte | Address 23-16 in which to store password count (Note 2) | Changed new baud rate | - | | | 8th byte | _ | Changed new baud rate | OK: Nothing Transmitted. NG: A1H × 3, A2H × 3, A3H × 3 (Note 1) | | | 9th byte | Address 15-08 in which to store password count (Note 2) | Changed new baud rate | _ | | | 10th byte | - (1818 2) | Changed new baud rate | OK: Nothing Transmitted. NG: A1H × 3, A2H × 3, A3H × 3 (Note 1) | | | 11th byte | Address 07-00 in which to store password count (Note 2) | Changed new baud rate | _ | | | 12th byte | _ | Changed new baud rate | OK: Nothing Transmitted. NG: A1H × 3, A2H × 3, A3H × 3 (Note 1) | | | 13th byte | Address 23-16 in which to store password comparison | Changed new baud rate | _ | | | 14th byte | _ | Changed new baud rate | OK: Nothing Transmitted. NG: A1H × 3, A2H × 3, A3h × 3 (Note 1) | | | 15th byte | Address 15-08 in which to store password comparison (Note 2) | Changed new baud rate | _ | | | 16th byte | - | Changed new baud rate | OK: Nothing Transmitted. NG: A1H × 3, A2H × 3, A3H × 3 (Note 1) | | | 17th byte | Address 07-00 in which to store password comparison (Note 2) | Changed new baud rate | _ | | | 18th byte | _ | Changed new baud rate | OK: Nothing Transmitted. NG: A1H × 3, A2H × 3, A3H × 3 (Note 1) | | | 19th byte | Password string (Note 2) | Changed new baud rate | - | | | m'th byte | | Changed new baud rate | OK: Nothing Transmitted. NG: A1H × 3, A2H × 3, A3H × 3 (Note 1) | | | m'th + 1 byte<br>: | Expanded Intel Hex format (binary) (Note 3) | | _ | | | n'th – 2 byte | _ | Changed new baud rate | OK: SUM (High) | | | n'th – 1 byte | | - | NG: Nothing Transmitted. (Note 4) | | | n'th byte | - | Changed new baud rate | OK: SUM (Low) NG: Nothing Transmitted. (Note 4) | | RAM | _ | Jump to user program's start address | SS | | - Note 1: $xxH \times 3$ denoes that operation stops after sending 3 bytes of xxH. - Note 2: Refer to the "Notes on Password" in the latter page of this manual. - Note 3: Refer to the "Notes on Expanded Intel Hex Format (binary)" in the latter page of this manual. - Note 4: Refer to the "Notes on Sum" in the latter page of this manual. Table 3.4.6 Transfer Format for Boot Program : For flash memory Sum | | Number of<br>Bytes<br>Transferred | Transfer Data from Controller to TMP91FY12A | Baud rate | Transfer Data from TMP91FY12A to Controller | |------|-----------------------------------|---------------------------------------------|-----------------------|-----------------------------------------------------| | воот | 1st byte | Matching data (5AH) | 9600bps | - (baud rate auto set) | | ROM | 2nd byte | _ | 9600bps | OK: Echoback data (5AH) | | | | | | NG: Nothing Transmitted. | | | 3rd byte | Baud rate modification data | 9600bps | - | | | | (See Table 3.4.1) | | | | | 4th byte | _ | 9600bps | OK: Echoback data | | | | | | NG: A1H $\times$ 3, A2H $\times$ 3, A3H $\times$ 3, | | | | | | 62H × 3 (Note 1) | | | 5th byte | Operating command data (90H) | Changed new baud rate | _ | | | 6th byte | _ | Changed new baud rate | OK: Echoback data (90H) | | | | | | NG: A1H $\times$ 3, A2H $\times$ 3, A3H $\times$ 3, | | | | | | 63H × 3 (Note 1) | | | 7th byte | _ | Changed new baud rate | OK : SUM (High) (Note 2) | | | | | | NG : - | | | 8th byte | _ | Changed new baud rate | OK : SUM (Low) (Note 2) | | | | | | NG : - | | | 9th byte | (Wait for next operation command | Changed new baud rate | _ | | | | data.) | | | Note 1: $xxH \times 3$ denoes that operation stops after sending 3 bytes of xxH. Note 2: Refer to the "Notes on SUM." ### (6) Description of boot program operation When you start the TMP91FY12A in single-boot mode, the boot program starts up. The boot program provides the functions described below. For details about these functions, refer to A Flash memory rewrite program through C Flash memory SUM command in the pages that follow. ### 1. Flash Memory rewrite The flash memory is erased the entire chip (256 Kbytes) collectively. Then data are written to the specified flash memory addresses. The controller should send the write data in the Extended Intel Hex format (binary). If no errors are encountered till the end record, the SUM of 256 Kbytes of flash memory is calculated and the result is returned to the controller. #### 2. RAM loader The RAM loader transfers the data into the internal RAM that has been sent from the controller in Extended Intel Hex format. When the transfer has terminated normally, the RAM loader calculates the SUM and sends the result to the controller before it starts executing the user program. The execution start address is the first address received. This RAM loader function provides the user's own way to control onboard programming. To execute on-board programming in the user program, you need to issue the flash memory command sequence described in the preceding section of this manual. (Must be matched to the flash memory addresses in single-boot mode.) The RAM loader command checks the result of password collation prior to program execution. If the passwords did not match, the program is not executed. ### 3. Flash memory SUM The SUM of 256 Kbytes of flash memory is calculated and the result is returned to the controller. The boot program does not support the operation commands to read data from the flash memory. Instead, it has this SUM command to use. By reading the SUM, it is possible to manage Revisions of application programs. ### A. Flash memory rewrite command (Table 3.4.4) 1. The receive data in the first byte is the matching data. When the boot program starts in single-boot mode, it goes to a state in which it waits for the matching data to receive. Upon receiving the matching data, it automatically adjusts the serial channel's initial baud rate to 9,600 bps. The matching data is 5AH. 2. The 2nd byte is used to echo back 5AH to the controller upon completion of the automatic baud rate setting in the first byte. If the device fails in automatic baud rate setting, it goes to an idle state. - 3. The receive data in the 3rd byte is the baud rate modification data. The seven kinds of baud rate modification data shown in Table 3.4.1 are available, Even when you do not change the baud rate, be sure to send the initial baud rate data (28h: 9,600 bps). - 4. The 4th byte is used to echo back the received data to the controller when the data received in the third byte is one of the baud rate modification data corresponding to the device's operating frequency. Then the baud rate is changed. If the received baud rate data does not correspond to the device's operating frequency, The device goes to an idle state after sending 3 bytes of baud rate modification error code (62H). - 5. The receive data in the 5th byte is the command data (30H) to rewrite the flash memory. - 6. The 6th byte is used to echo back the received data (in this case, 30H) to the controller when the data received int the 5th byte is one of the operation command data in Table 3.4.2. And the flash memory rewrite routine is called. If the received data is none of the operation command data, the device goes to an idle state after sending 3 bytes of operation command error code (63H). - 7. The transmit data in the 7th byte indicates whether collective erase (256 Kbytes) has terminated normally. When collective erase (256 Kbytes) has terminated normally, the device returns collective erase terminated normally code (C1H) to the controller. - If an erase error occurs, the device goes to an idle state after returning three bytes of erase error code (64H) to the controller. - The controller should send the next data to the device after receiving the collective erase terminated normally code (C1H). - 8. The receive data in the 8th byte through n'th-2byte are received as binary data in Extended Intel Hex format. No received data are echoed back to the controller. - The flash memory rewrite routine ignores the received data until it receives the start mark (3AH for ":") in Extended Intel Hex format. Nor does it send error code to the controller. After receiving the start mark, the routine receives a range of data from data length to checksum and writes the received write data to the specified flash memory addresses successively. Since bits 23 to 16 of the address pointer during write are by default 00H, the first record type must always be an extended record. After receiving one record of data from start mark to checksum, the routine goes to a start mark waiting state again. If a write error, receive error, or Extended Intel Hex format error occurs, the device goes to an idle state without returning error code to the controller. Because the flash memory rewrite routine executes a SUM calculation routine upon detecting the end record, the controller should be placed in a SUM waiting state after sending the end record to the device. - 9. The n'th 1 and the n'th bytes are the SUM value that is sent to the controller in order of the upper byte and the lower byte. For details on how to calculate the SUM, refer to "Notes on SUM" in the latter page of this manual. The SUM calculation is performed only when no write error, receive error, or Extended Intel Hex format error has been encountered after detecting the end record. The time required to calculate the SUM of the 256 Kbytes of flash memory area is approximately 400 ms at fc = 20 MHz. After SUM calculation, the device sends the SUM data to the controller. The controller should determine whether writing to the flash memory has terminated normally depending on whether the SUM value is received after sending the end record to the device. - 10. The receive data in the n'th + 1 byte, if rewriting terminated normally, places the device in a state waiting for the next operation command data. # B. RAM loader command (Table 3.4.5) - 1. The transmit/receive data in the 1st through the 4th bytes are the same as in the case of flash memory rewrite commands. - 2. The receive data in the 5th byte is the RAM loader command data (60H). - 3. The 6th byte is used to echo back the received data (in this case, 60H) to the controller when the data received in the 5th byte is one of the operation command data in Table 3.4.2. Then the RAM loader routine is called. If the received data is none of the operation command data, the device goes to an idle state after returning three bytes of operation command error code (63H) to the controller. - 4. The receive data in the 7th byte is the data for bits 23 to 16 of the address in which the password count is stored. Three bytes of password count storage address are required. The data indicated by this address is the password count. Note that if the password count is equal to or less than 8, the command is canceled. - 5. Nothing is sent in the 8th byte to the controller when the data received in the 7th byte has no error. If a receive error is encountered, the device goes to an idle state after returning three bytes of relevant error code to the controller. - 6. The 9th through the 12th bytes respectively are bits 15 to 8 and bits 7 to 0 of the password count storage address and are the data used when a receive error is encountered to return error code to the controller. For these operations, refer to paragraphs 4 and 5 above. - 7. The receive data in the 13th byte are bits 23 to 16 of the address at which the password comparison is started. Three bytes of password comparison start address are required. Passwords are compared beginning with this address. - 8. Nothing is sent in the 14th byte to the controller when the data received in the 13th byte has no error. If a receive error is encountered, the device goes to an idle state after returning three bytes of relevant error code to the controller. - 9. The 15th through the 18th bytes respectively are bits 15 to 8 and bits 7 to 0 of the password comparison start address and are the data returned to the controller. For these operations, refer to paragraphs 7 and 8 above. 10. The 19th through the m'th bytes are the password data. The number of passwords or the password count is the data (N) indicated by the password count storage address. The password data are compared for N entries beginning with the password comparison start address. The controller should send N bytes of password data to the device. If the passwords do not match, the device goes to an idle state without returning error code to the controller. 11. The receive data in the m'th + 1 through the n'th − 2 bytes are received as binary data in Extend Intel Hex format. No received data are echoed back to the controller. The RAM loader routine ignores the received data until it receives the start mark (3AH for ":") in Extended Intel Hex format. Nor does it send error code to the controller. After receiving the start mark, the routine receives a range of data from data length to checksum. The received write data are successively written to the specified flash memory addresses. Since bits 23 to 16 of the address pointer during write are by default 00H, the first record type does not always have to be an extended record. After receiving one record of data from start mark to checksum, the routine goes to a start mark waiting state again. If a receive error or Extended Intel Hex format error occurs, the device goes to an idle state without returning nothing to the controller. Because the RAM loader routine executes a SUM calculation routine upon detecting the end record, the controller should be placed in a SUM waiting state after sending the end record to the device. - 12. The n'th 1 and the n'th bytes are the SUM value that is sent to the controller in order of the upper byte and the lower byte. For details on how to calculate the SUM, refer to "Notes on SUM" in the latter page of this manual. The SUM calculation is performed only when no receive error or Extended Intel Hex format error has been encountered after detecting the end record. The time required to calculate the SUM is approximately proportional to the number of data written to RAM. The time required to calculate the SUM of a 4 Kbytes of RAM area, for example, is approximately 6 ms at fc = 20 MHz. After SUM calculation, the device sends the SUM data to the controller. The controller should determine whether writing to RAM has terminated normally depending of whether the SUM value is received after sending the end record to the device. - 13. The boot program jumps to the first address that is received as data in Extended Intel Hex format after sending the SUM to the controller. ### C. Flash memory SUM command (Table 3.4.6) - 1. The transmit/receive data in the 1st through the 4th bytes are the same as in the case of flash memory rewrite commands. - 2. The receive data in the 5th byte is the flash memory SUM command data (90H). - 3. The 6th byte is used to echo back the received data (in this case, 90H) to the controller when the data received in the 5th byte is one of the operation command data in Table 3.4.2. Then the flash memory SUM processing routine is called. If the received data is none of the operation command data, the device goes to an idle state after returning three bytes of operation command error code (63H) to the controller. - 4. The 7th and the 8th bytes are the SUM value that is sent to the controller in order of the upper byte and the lower byte. For details on how to calculate the SUM, refer to "Note on SUM" in the latter page of this manual. - 5. The receive data in the 9th byte places the device in a state waiting for the next operation command data. # D. Boot program transmit data The boot program sends the processing status to the controller using various code. The transmit data (processing code) are listed in the table below. Table 3.4.7 Boot Program Transmit Data | Transmit Data | Meaning of Transmit Data | | | | |---------------|------------------------------------------------------------|--|--|--| | C1H | Collective erase of flash memory chip terminated normally. | | | | | 62H, 62H, 62H | Baud rate modification error occurred. | | | | | 63H, 63H, 63H | Operating command error occurred. | | | | | 64H, 64H, 64H | Flash memory erase error occurred. | | | | | A1H, A1H, A1H | Framing error in received data occurred. (Note) | | | | | A2H, A2H, A2H | Parity error in received data occurred. (Note) | | | | | A3H, A3H, A3H | Overrun error in received data occurred. (Note) | | | | Note: When this receive error occurs when receiving data in Expanded Intel Hex format, the device does not send the receive error code to the controller. #### E. Notes on SUM # 1. Calculation method SUM consists of byte + byte .... + byte, the sum of which is returned in word as the result. Namely, data is read out in byte and sum of which is calculated, with the result returned in word. ## Example: The SUM returned when executing the flash memory rewrite command, RAM loader command, or flash memory SUM command is calculated in the manner shown above. # 2. Calculation data The data from which SUM is calculated are listed in Table 3.4.8 below. Table 3.4.8 Sum Calculation Data | Operating Mode | Calculation Data | Remarks | | |------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--| | Flash memory rewrite command | Data in the entire area (256 Kbytes) of flash memory | The received flash memory or RAM write data is not the only data to be calculated for SUM. | | | RAM loader command | Data written in an area ranging from<br>the first address received to the last<br>address received | Even when the received addresses are noncontiguous and there are some unwritten areas, data in the entire memory area is calculated. | | | Flash memory Sum command | Data in the entire area (256 Kbytes) of flash memory | _ | | - F. Notes of Extended Intel Hex Format (binary) - 1. For the flash memory rewrite command, always make sure the first record type is an extended record. This is because the internal flash memory of the TMP91FY12A is located in a memory space starting from address 10000H, so that bits 23 to 16 of the address pointer when writing to the flash memory are, by default, 00H. - 2. For the RAM loader command, the first record type does not always have to be an extended record. This is because bits 23 to 16 of the address pointer when writing to the flash memory are, by default, 00H. - 3. After receiving the checksum of a record, the device waits for the start mark (3AH for ":") of the next record. Therefore, the device ignores all data received between records during that time unless the data is 3AH. - 4. Make sure that once the controller program has finished sending the checksum of the end record, it does not send anything and waits for two bytes of data to be received (upper and lower bytes of SUM). This is because after receiving the checksum of the end record, the boot program calculates the SUM and returns the calculated SUM in two bytes to the controller. - 5. If a write error (for only the flash memory rewrite command), receive error, or Extended Intel Hex format error occurs, the device goes to an idle state without returning error code to the controller. In the following cases, an Extended Intel Hex format error is assumed: - When Type is not 00H,01H, or 02H - When a checksum error occurred - When the data length of an extended record (TYPE = 02H) is not 02H - When the address of an extended record (TYPE = 02H) is not 0000H - When the data in the 2nd byte of an extended record (TYPE = 02H) is not 00H - When the data length of the end record (TYPE = 01H) is not 00H - When the address of the end record (TYPE = 01H) is not 0000H Example: When writing to an area from address 1FFF8H to address 2002FH, the transfer format should be like the one shown in Table 3.4.9. | Direction of Data | Meaning of Data Extended Intel Hex Format (n'th – 2 byte in item 8 of Table 3.4.4) | Data | |--------------------------|------------------------------------------------------------------------------------|------------------------------------| | Controller to TMP91FY12A | Extended record | : 02 0000 02 1000 <u>EC zz</u> | | Controller to TMP91FY12A | Data record (data length: 08H) | : 08 FFF8 00 xxxxxx <u>CS zz</u> | | Controller to TMP91FY12A | Extended record | : 02 0000 02 2000 <u>DC zz</u> | | Controller to TMP91FY12A | Data record (data length: 30H) | : 30 0000 00 yyyyyyyy <u>CS zz</u> | | Controller to TMP91FY12A | End record | : 00 0000 01 FF <u>ww</u> | | TMP91FY12A to Controller | SUM (upper byte)<br>(n'th – 1 byte in Table 3.4.4) | SUM (upper byte) | | TMP91FY12A to Controller | SUM(lower byte) (n'th byte in Table 3.4.4) | SUM (lower byte) | | Controller to TMP91FY12A | Operation command (n'th + 1 byte in Table 3.4.4) | Next operation command data | Table 3.4.9 Example of Transfer Format for Flash memory overwrite command data Note: The colon ":" denotes the start mark (3AH). xx, yy denote the data written to flash memory CS, EC, DC, FF denote the checksum data. zz denotes the data that can be sent by the controller without causing a problem. ww denotes the data that cannot be sent by the controller. #### G. Notes on Passwords The area in which passwords can be specified is located at addresses 12000H to 4DFFFH. Figure 3.4.3 schematically shows the password area. 1. Password cont strage address (PNSA) The content of the address specified by PNSA is the password cont (N). In the following cases, a password error is assumed: - PNSA < address 12000H - Address 4DFFFH < PNSA</li> - N < 8 - 2. Password comparison start address (PCSA) The passwords are compared beginning with the address specified by PCSA. The specified password area is from PCSA to PCSA + N. In the following cases, a password error is assumed: - PCSA < address 12000H - Address 4DFFFH < PCSA + N 1 - When The specified password area contains three or more consecutive bytes of the same data. However, if alldata in the vector part (4FF00H to 4FFFFH) are FFH, the device is assumed to be a blank product, in which no check is made of the passwords. # 3. Password string A string of passwords in the received data are compared with the data in the flash memory. In the following cases, a password error is assumed: When the received data does not match the data in the flash memory # 4. Handling of password error When a password error occurs, the device goes to an idle state. Figure 3.4.3 Conceptual Diagram of Password Area # Single Boot General Flow # (1) SUM command ## (2) Overwrite command #### (3) RAM Loader command # (2) - 1 Writing HEX data (2) - 1 - 1 Data record (2) - 1 - 2 Expansion record (2) - 1 - 3 End record (2) - 1 - 1 - 1 Writing one word (2) - 2 Erasing Flash memory (2) - 2 - 1 Data polling # 4. Electrical Characteristics # 4.1 Absolute Maximum Ratings | Parameter | Symbol | Rating | Unit | |-------------------------------|-----------------|-------------------|-------| | Power Supply Voltage | Vcc | -0.5 to 4.0 | V | | Input Voltage | VIN | -0.5 to Vcc + 0.5 | V | | Output Current | IOL | 2 | mA | | Output Current | IOH | -2 | mA | | Output Current (total) | ΣΙΟL | 80 | mA | | Output Current (total) | ΣΙΟΗ | -80 | mA | | Power Dissipation (Ta = 85°C) | PD | 600 | mW | | Soldering Temperature (10 s) | TSOLDER | 260 | °C | | Storage Temperature | TSTG | -65 to 150 | °C | | Operating Temperature | TOPR | –20 to 70 | °C | | Number of Times Program Erase | N <sub>EW</sub> | 10000 | Cycle | Note: The absolute maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded. # 4.2 DC Characteristics (1/2) | | Parameter | Symbol | Cond | Min | Typ.<br>(Note 1) | Max | Unit | | |-----------------|-------------------------|------------------|-----------------------|--------------------|------------------|-----|-----------|---| | Pow | er Supply Voltage | | | | | | | | | (Avc | c = DVcc) | $V_{CC}$ | fc = 4 to 27 MHz | fs = 30 to 34 kHz | 2.7 | | 3.6 | V | | (Avs | s = DVss = 0 V) | | | | | | | | | | P00 to P17 (AD0 to 15) | V <sub>IL</sub> | Vcc = 2.7 to 3.6 V | | | | 0.6 | | | ge | P20 to PA7 (except P63) | $V_{IL1}$ | Vcc = 2.7 to 3.6 V | | | | 0.3 Vcc | | | t<br>Voltage | RESET, NMI, P63 (INT0) | V <sub>IL2</sub> | Vcc = 2.7 to 3.6 V | | -0.3 | | 0.25 Vcc | | | Input<br>Low Ve | AM0, 1 | $V_{IL3}$ | Vcc = 2.7 to 3.6 V | | | | 0.3 | | | Inpu | X1 | $V_{IL4}$ | Vcc = 2.7 to 3.6 V | | | | 0.2 Vcc | | | | P00 to P17 (AD0 to 15) | V <sub>IH</sub> | Vcc = 2.7 to 3.6 V | | 2.0 | | | V | | ge | P20 to PA7 (except P63) | V <sub>IH1</sub> | Vcc = 2.7 to 3.6 V | | 0.7 Vcc | | | | | Voltage | RESET, NMI, P63 (INT0) | V <sub>IH2</sub> | Vcc = 2.7 to 3.6 V | | 0.75 Vcc | | Vcc + 0.3 | | | ut<br>Jh V | AM0, 1 | V <sub>IH3</sub> | Vcc = 2.7 to 3.6 V | Vcc-0.3 | | | | | | Input<br>High ' | X1 | V <sub>IH4</sub> | Vcc = 2.7 to 3.6 V | | 0.8 Vcc | | | | | Outp | out Low Voltage | V <sub>OL</sub> | IOL = 1.6 mA | | | | 0.45 | | | Outp | out High Voltage | V <sub>OH</sub> | $IOH = -400 \mu A$ | Vcc = 2.7 to 3.6 V | 2.4 | | | V | Note 1: Typical values are for when $Ta = 25^{\circ}C$ and Vcc = 3.0 V unless otherwise noted. # 4.2 DC Characteristics (2/2) | Parameter | Symbol | Condition | Min | Typ.<br>(Note 1) | Max | Unit | |----------------------------------------------|--------|-----------------------------------------|-----|------------------|------|------| | Input Leakage Current) | ILI | 0.0 ≤ V <sub>IN</sub> ≤ Vcc | | 0.02 | ±5 | | | Output Leakage Current | ILO | 0.2 ≤V <sub>IN</sub> ≤Vcc – 0.2 | | 0.05 | ±10 | μΑ | | Power Down Voltage<br>(at STOP, RAM back-up) | VSTOP | V IL2 = 0.2 Vcc,<br>V IH2 = 0.8 Vcc | 2.7 | | 3.6 | V | | RESET Pull-up Resistor | RRST | Vcc = 3 V ± 10% | 100 | | 400 | ΚΩ | | Pin Capacitance | CIO | fc = 1 MHz | | | 10 | PF | | Schmitt Width RESET, NMI, INTO | VTH | Vcc = 2.7 to 3.6 V | 0.4 | 1.0 | | V | | Programmable Pull-up Resistor | RKH | Vcc = 3 V ± 10% | 100 | | 400 | ΚΩ | | Normal (Note 2) | Icc | N 0 N 1 400/ | | 30.0 | 45.0 | | | Idle2 | | $Vcc = 3 V \pm 10\%$<br>fc = 27 MHz | | 4.5 | 7.0 | mA | | Idle1 | | TC = 27 IVIMZ | | 2.0 | 4.0 | | | Slow (Note 2) | | 2 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | | 30.0 | 40 | | | Idle2 | | $Vcc = 3 V \pm 10\%$ | | 9.0 | 25 | μΑ | | Idle1 | | fs = 32.768 kHz | | 6.0 | 15 | | | Stop | | Vcc = 3 V ± 10% | | 1.0 | 15 | μА | Note 1: Typical values are for when $Ta = 25^{\circ}C$ and Vcc = 3.0 V unless otherwise noted. Note 2: Icc measurement conditions (Normal, Slow): All functions are operating; output pins are open and input pins are fixed. #### 4.3 AC Characteristics (1) $Vcc = 3.0 V \pm 10\%$ | No. | Parameter | Symbol | Vari | able | f <sub>FPH</sub> = 3 | 27 MHz | 11-:4 | |-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------|-----------|----------------------|--------|-------| | NO. | i alametei | Symbol | Min | Max | Min | Max | Unit | | 1 | f <sub>FPH</sub> Period (= x) | t <sub>FPH</sub> | 37.0 | 31250 | 37.0 | | ns | | 2 | A0 to A15 Vaild $\rightarrow$ ALE Fall | t <sub>AL</sub> | 0.5x - 6 | | 12 | | ns | | 3 | ALE Fall $\rightarrow$ A0 to A15 Hold | $t_{LA}$ | 0.5x - 16 | | 2 | | ns | | 4 | ALE High Width | t <sub>LL</sub> | x – 20 | | 17 | | ns | | 5 | ALE Fall $\rightarrow \overline{RD} / \overline{WR} Fall$ | t <sub>LC</sub> | 0.5x - 14 | | 4 | | ns | | 6 | $\overline{RD} \ Rise \to ALE \ Rise$ | t <sub>CLR</sub> | 0.5x - 10 | | 8 | | ns | | 7 | $\overline{WR}\ Rise \to ALE\ Rise$ | t <sub>CLW</sub> | x – 10 | | 27 | | ns | | 8 | A0 to A15 Valid $ ightarrow \overline{RD}$ / $\overline{WR}$ Fall | t <sub>ACL</sub> | x – 23 | | 14 | | ns | | 9 | A0 to A23 Valid $ ightarrow \overline{RD} / \overline{WR} $ Fall | t <sub>ACH</sub> | 1.5x - 26 | | 29 | | ns | | 10 | $\overline{\text{RD}} \ \ \text{Rise} \rightarrow \text{A0 to A23 Hold}$ | t <sub>CAR</sub> | 0.5x - 13 | | 5 | | ns | | 11 | $\overline{\text{WR}} \ \text{Rise} \rightarrow \text{A0 to A23 Hold}$ | t <sub>CAW</sub> | x – 13 | | 24 | | ns | | 12 | A0 to A15 Valid $\rightarrow$ D0 to D15 Input | t <sub>ADL</sub> | | 3.0x - 38 | | 73 | ns | | 13 | A0 to A23 Valid $\rightarrow$ D0 to D15 Input | t <sub>ADH</sub> | | 3.5x – 41 | | 88 | ns | | 14 | $\overline{\text{RD}} \text{ Fall} \rightarrow \text{D0 to D15 Input}$ | t <sub>RD</sub> | | 2.0x - 30 | | 44 | ns | | 15 | RD Low Width | t <sub>RR</sub> | 2.0x - 15 | | 59 | | ns | | 16 | $\overline{\text{RD}} \ \ \text{Rise} \rightarrow \text{D0 to A15 Hold}$ | t <sub>HR</sub> | 0 | | 0 | | ns | | 17 | $\overline{\text{RD}} \ \ \text{Rise} \rightarrow \text{A0 to A15 Output}$ | t <sub>RAE</sub> | x – 15 | | 22 | | ns | | 18 | WR Low Width | t <sub>WW</sub> | 1.5x – 15 | | 40 | | ns | | 19 | D0 to D15 Valid $\rightarrow \overline{\text{WR}} \; \text{Rise}$ | t <sub>DW</sub> | 1.5x - 35 | | 20 | | ns | | 20 | $\overline{\text{WR}} \ \text{Rise} \to \text{D0 to D15 Hold}$ | t <sub>WD</sub> | x - 25 | | 12 | | ns | | 21 | A0 to A23 Valid $\rightarrow \overline{\text{WAIT}}$ Input $\begin{bmatrix} 1 \text{ WAIT} \\ +n \text{ Mode} \end{bmatrix}$ | t <sub>AWH</sub> | | 3.5x - 60 | | 69 | ns | | 22 | A0 to A15 Valid $\rightarrow \overline{\text{WAIT}}$ Input $\begin{bmatrix} 1 \text{ WAIT} \\ +n \text{ Mode} \end{bmatrix}$ | t <sub>AWL</sub> | | 3.0x - 50 | | 61 | ns | | 23 | $\overline{\text{RD}} / \overline{\text{WR}} \text{ Fall} \to \overline{\text{WAIT}} \text{ Hold} \qquad \begin{bmatrix} 1 \text{ WAIT} \\ +n \text{ Mode} \end{bmatrix}$ | t <sub>CW</sub> | 2.0x + 0 | | 74 | | ns | | 24 | A0 to A23 Valid → Port Input | t <sub>APH</sub> | | 3.5x - 89 | | 40 | ns | | 25 | A0 to A23 Valid $\rightarrow$ Port Hold | t <sub>APH2</sub> | 3.5x | | 129 | | ns | | 26 | A0 to A23 Valid $\rightarrow$ Port Valid | t <sub>AP</sub> | | 3.5x + 80 | | 209 | ns | ### **AC Measuring Conditions** • Output Level: High = $0.7 \times Vcc$ , Low = $0.3 \times Vcc$ , CL = 50 pF • Input Level: High = $0.9 \times Vcc$ , Low = $0.1 \times Vcc$ Note: x used in an expression shows a frequency for the clock $f_{\text{FPH}}$ selected by SYSCR1<SYSCK>. The value of x changes according to whether a clock gear or a low-speed oscillator is selected. An example value is calculated for fc, with gear = 1/fc (SYSCR1<SYSCK,GEAR2 to 0> = 0000) . ### 4.4 AD Conversion Characteristics AVcc = Vcc, AVss = Vss | Parameter | Symbol | Condition | Min | Тур. | Max | Unit | |-------------------------------------------------------------------------|-----------------------|---------------------------------|-------------------------|-----------------|-------------------------|------| | Analog Reference Voltage (+) | VREFH | $V_{CC} = 3 V \pm 10\%$ | V <sub>CC</sub> – 0.2 V | V <sub>CC</sub> | V <sub>CC</sub> | | | Analog Reference Voltage (-) | VREFL | $V_{CC} = 3 \text{ V} \pm 10\%$ | V <sub>SS</sub> | V <sub>SS</sub> | V <sub>SS</sub> + 0.2 V | V | | Analog Input Voltage Range | VAIN | | $V_{REFL}$ | | $V_{REFH}$ | | | Analog Current for Analog<br>Reference Voltage<br><vrefon> = 1</vrefon> | IREF<br>(VREFL = 0 V) | $V_{CC} = 3 V \pm 10\%$ | | 0.94 | 1.20 | mA | | <vrefon> = 0</vrefon> | | $V_{CC} = 3 \text{ V} \pm 10\%$ | | 0.02 | 5.0 | μΑ | | Error (not including quantizing errors) | _ | $V_{CC} = 3 V \pm 10\%$ | | ±1.0 | ± 4.0 | LSB | Note 1: 1 LSB = (VREFH - VREFL)/1024 [V] Note 2: The operation above is guaranteed for $f_{\mbox{\scriptsize FPH}} \geq 4$ MHz. Note 3: The value for $I_{\text{CC}}$ includes the current which flows through the AVCC pin. # 4.5 Serial Channel Timing (I/O Internal Mode) # (1) SCLK Input Mode | Parameter | Cumbal | Varia | ble | 10 N | ЛHz | 27 [ | ИHz | Unit | |-----------------------------------------------------|------------------|------------------------------|----------------------|------|------|------|-----|------| | Parameter | Symbol | Min | Max | Min | Max | Min | Max | Unit | | SCLK Period | t <sub>SCY</sub> | 16X | | 1.6 | | 0.59 | | μs | | Output Data → SCLK Rising<br>/Falling Edge (Note) | t <sub>OSS</sub> | t <sub>SCY</sub> /2 – 4X-110 | | 290 | | 38 | | ns | | SCLK Rising/Falling Edge (Note) → Output Data Hold | t <sub>OHS</sub> | $t_{SCY}/2 + 2x + 0$ | | 1000 | | 370 | | ns | | SCLK Rising/Falling Edge (Note) → Input Data Hold | t <sub>HSR</sub> | 3x + 10 | | 310 | | 121 | | ns | | SCLK Rising/Falling Edge (Note) → Valid Data Input | t <sub>SRD</sub> | | t <sub>SCY</sub> - 0 | | 1600 | | 592 | ns | | Valid Data InputSCLK →Rising/Falling Edge (Note) | t <sub>RDS</sub> | 0 | | 0 | | 0 | | ns | Note: SCLK Rinsing/Falling Edge: The rising edge is used in SCLK Rising Mode. The falling edge is used in SCLK Falling Mode. ### (2) SCLK Output Mode | Parameter | Symbol | Va | 10 ľ | MHz | 27 I | Unit | | | |-------------------------------------|------------------|--------------------------|-----------------------------|-----|------|------|-----|-------| | Parameter | Symbol | Min | Max | Min | Max | Min | Max | Offic | | SCLK Period (programable) | t <sub>SCY</sub> | 16X | 8192X | 1.6 | 819 | 0.59 | 303 | μs | | Output Data →SCLK Rising Edge | toss | t <sub>SCY</sub> /2 - 40 | | 760 | | 256 | | ns | | SCLK Rising Edge → Output Data Hold | t <sub>OHS</sub> | t <sub>SCY</sub> /2 - 40 | | 760 | | 256 | | ns | | SCLK Rising Edge → Input Data Hold | t <sub>HSR</sub> | 0 | | 0 | | 0 | | ns | | SCLK Rising Edge → Valid Data Input | t <sub>SRD</sub> | | t <sub>SCY</sub> – 1x – 180 | | 1320 | | 375 | ns | | Valid Data Input → SCLK Rising Edge | t <sub>RDS</sub> | 1x + 180 | | 280 | | 217 | | ns | # 4.6 Event Counter (TA0IN, TA4IN, TB0IN0, TB0IN1, TB1IN0, TB1IN1) | Parameter | Cymphol | Varia | 10 N | ИНz | 27 I | Lloit | | | |------------------------|-------------------|----------|------|-----|------|-------|-----|------| | Parameter | Symbol | Min | Max | Min | Max | Min | Max | Unit | | Clock Perild | t <sub>VCK</sub> | 8X + 100 | | 900 | | 396 | | ns | | Clock Low Level Width | t <sub>VCKL</sub> | 4X + 40 | | 440 | | 188 | | ns | | Clock High Level Width | t <sub>VCKH</sub> | 4X + 40 | | 440 | | 188 | | ns | # 4.7 Interrupt and Capture ### (1) $\overline{\text{NMI}}$ , INT0 to INT4 Interrupts | Doromotor | Svmbol | Varia | 10 N | ИНz | 27 N | Unit | | | |------------------------------------|--------------------|---------|------|-----|------|------|-----|-------| | Parameter | Cymbol | Min | Max | Min | Max | Min | Max | Offic | | NMI, INTO to INT4 Low level width | t <sub>INTAL</sub> | 4X + 40 | | 440 | | 188 | | ns | | NMI, INT0 to INT4 High level width | t <sub>INTAH</sub> | 4X + 40 | | 440 | | 188 | | ns | ### (2) INT5 to INT8 Interrupts, Capture The INT5 to INT8 input width depends on the system clock and prescaler clock settings. | System Clock<br>Selected | Prescaler Clock<br>Selected | t <sub>INT</sub><br>(INT5 to INT8 L | BL<br>ow level Width) | t <sub>INTI</sub><br>(INT5 to INT8 Hiç | BH<br>gh Level Width) | Linit | |--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|---------------------------|----------------------------------------|---------------------------|-------| | <sysck></sysck> | <prck1,< td=""><td>Variable</td><td>f<sub>FPH</sub> = 27 MHz</td><td>Variable</td><td>f<sub>FPH</sub> = 27 MHz</td><td>OTIIL</td></prck1,<> | Variable | f <sub>FPH</sub> = 27 MHz | Variable | f <sub>FPH</sub> = 27 MHz | OTIIL | | 010011 | PRCK0> | Min | Min | Min | Min | | | 0 (fa) | 00 (f <sub>FPH</sub> ) | 8X + 100 | 396 | 8X + 100 | 396 | ns | | 0 (fc) | 10 (fc/16) | 128Xc + 0.1 | 4.8 | 128Xc + 0.1 | 4.8 | | | 1 (fs) | 00 (f <sub>FPH</sub> ) | 8X + 0.1 | 244.3 | 8X + 0.1 | 244.3 | μs | Note: Xc = Period of Clock fc ## 4.8 SCOUT Pin AC Characteristics | Daramatar | Cumbal | Variable | | 10 MHz | | 27 N | ИHz | Condition | Lloit | |------------------|------------------|-----------|-----|--------|-----|------|-----|--------------------|-------| | Parameter | Symbol | Min | Max | Min | Max | Min | Max | Condition | Unit | | Low level Width | t <sub>SCH</sub> | 0.5T – 13 | | 37 | | 5 | | Vcc = 2.7 to 3.6 V | ns | | High level Width | t <sub>SCL</sub> | 0.5T – 13 | | 37 | | 5 | | Vcc = 2.7 to 3.6 V | ns | Note: T = Period of SCOUT #### **Measrement Condition** • Output Level: High 0.7 Vcc/Low 0.3 Vcc, CL = 10pF ## 4.9 Bus Request/Bus Acknowledge | Paramter | Symbol | Variable | | f <sub>FPH</sub> = 10 MHz | | f <sub>FPH</sub> = 2 | 7 MHz | Condition | Unit | |--------------------------------|------------------|----------|-----|---------------------------|-----|----------------------|-------|--------------------|------| | 1 dramici | Cymbol | Min | Max | Min | Max | Min | Max | Condition | 5 | | Output Buffer Off to BUSAK Low | t <sub>ABA</sub> | 0 | 80 | 0 | 80 | 0 | 80 | Vcc = 2.7 to 3.6 V | ns | | BUSAK High to Output Buffer On | t <sub>BAA</sub> | 0 | 80 | 0 | 80 | 0 | 80 | Vcc = 2.7 to 3.6 V | ns | Note 1: Even if the $\overline{\text{BUSRQ}}$ Signal goes 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. #### 4.10 Recommended Oscillation Circuit The TMP91FY12AF has been evaluated by the following resonator manufacturer. The evaluation results are shown below for your information. Note: The load capacitance of the oscillation terminal is the sum of the load capacitances of C1 and C2 to be connected and the stray capacitance on the board. Even if the ratings of C1 and C2 are used, the load capacitance varies with each board and the oscillator may malfunction. Therefore, when designing a board, make the pattern around the oscillation circuit shortest. It is recommended that final evaluation of the resonator be performed on the board. #### (1) Examples of resonator connection Figure 4.10.1 High-frequency Oscillator Connection Figure 4.10.2 Low-frequency Oscillator Connection #### (2) Recommended ceramic resonators for the TMP91FY12AF: Murata Manufacturing Co., Ltd. $Ta = -40 \text{ to } 85^{\circ}\text{C}$ | Item | Oscillation frequency [MHz] | Recommended resonator | Recommended rating | | | | | |----------------------------------|-----------------------------|-----------------------|--------------------|---------|------------------|------------|---------| | | | | C1 [pF] | C2 [pF] | Rd [k $\Omega$ ] | VCC [V] | Remarks | | High-<br>frequency<br>oscillator | 4.0 | CSTS0400MG06 | (47) | (47) | 0 | 2.7 to 3.3 | _ | | | 6.75 | CSTS0675MG06 | (47) | (47) | | | | | | 12.5 | CSA12.5MTZ | 30 | 30 | | | | | | | CST12.5MTW | (30) | (30) | | | | | | 20.0 | CSA20.00MXZ040 | 7 | 7 | | | | | | 27.0 | CSA27.00MXZ040 | 5 | 5 | | | | | | | CST27.00MXW040 | (5) | (5) | | | | - The values enclosed in brackets in the C1 and C2 columns apply to the condenser built-in type. - The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following URL; http://www.murata.co.jp/search/index.html