# Part 2 # TMP68301AF-12 / TMP68301AF-16 TMP68301AFR-12 / TMP68301AFR-16 #### 1. Introduction TMP68301A uses the 68HC000, the CMOS version of the 68000, as its core processor. It also includes peripheral circuits such as a serial interface, parallel interface, timer, interrupt controller, and address decoder. In addition, TMP68301A can directly use 68000 development environments and software resources. - Core processor 68HC000 - Minimum instruction execution time: 240ns (with 16.67MHz-system clock) - 17 32-bit registers - 16M-byte direct addressing - 56 powerful basic instructions - 14 addressing modes - 3-channel asynchronous serial interface - 16-bit parallel I/O interface (supports a Centronics interface) - 3-channel, 16-bit timer/counter - 10-channel interrupt controller (3 external channels, 7 internal channels; can be extended by software to 10 external channels) - 2-channel chip-select signal output $(\overline{CS0}, \overline{CS1})$ - Automatic wait state insertion - Bus monitor function - Low power consumption (CMOS) - 2 types of package: 100-pin QFP and 100-pin RFP TMP68301A has two operating modes: normal operating mode, and emulation mode that enables use of an in-circuit emulator (ICE), a 68000 development tool. OIn emulation mode, the 68HC000 core built into TMP68301A is disconnected from the bus, and the internal peripheral circuits are controlled by address, data, and control signals from the development tool. The 68HC000 core built into TMP68301A is the same as the standard TMP68HC000, except that 8-bit peripheral device control signals E, $\overline{VPA}$ , and $\overline{VMA}$ are disabled. For 68HC000 operation and instructions, refer to your TLCS-68000 Data Book. Figure 1.1 is the TMP68301A block diagram. Note: Parentheses () indicate Centronics. Figure 1.1 TMP68301A Block Diagram # 2. Signal Description This section briefly describes input and output signals. The terms "assert" and "negate" appear frequently. These terms are used to avoid ambiguity when terms such as "active high" and "active low" are used. "Assert" is used to show that signals are active or true, irrespective of whether the signal is electrically high or low. "Negate" is used to show that signals are inactive or false. # 2.1 Pin Assignments Figure 2.1 shows the pin assignments. Figure 2.1 Pin Assignements (top view) (1/2) Figure 2.1 Pin Assignments (top view) (2/2) Figure 2.2 Normal Mode Input/Output Signals When Configured as Bus Master Figure 2.3 Normal Mode Input/Output Signals When Bus Mastership Released Figure 2.4 Emulation Mode Input/Output Signals # 2.2 Pin Names and Functions The following describes pin states and functions in normal and emulation modes. $NOR: \ \ Normal\ mode, \ \ EMU: \ Emulation\ mode, \\ O.D: \ \ Open\ drain\ output, \ \ O: \ \ Output, \ \ I: \ \ Input, \ \ I/O: \ \ Input/output$ | c. 1 | Pins | tatus | | | | | | |-----------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Signal name | NOR | EMU | Function | | | | | | A1 to A23 | 0 | ı | 23-bit address bus can directly access 16M bytes of memory. | | | | | | FC0 to FC2 | 0 | ı | These signals show the status of the processor and the current cycle type. For details, see Table 2.2. | | | | | | D0 to D15 | 1/0 | 1/0 | 16-bit general-purpose data bus. | | | | | | ĀS | 0 | 1 | This signal indicates that there is a valid address on the address bus. | | | | | | R/W | 0 | 1 | This signal indicates whether the data transfer is read (high) or write (low). | | | | | | UDS / LDS | 0 | ı | These signals control the data on the data bus. See Table 2.1 for details. | | | | | | DTACK | I | O.D | This signal indicates the end of a data transfer. | | | | | | BR<br>(IPLO) | ı | 0 | This signal is wire-ORed with all other devices that could become bus masters. The signal indicates that another device is requesting bus mastership. In emulation mode, this signal becomes the IPLO output. The IPL signal codes the priority level of a device requesting the interrupt. | | | | | | BG<br>(IPL1) | 0 | 0 | This signal indicates to devices that could become bus masters that the processor will release control of the bus at the end of the current bus cycle. In emulation mode, the signal becomes the IPL1 output. | | | | | | BGACK<br>(IPL2) | I | 0 | This signal indicates that another device has become the bus master. In emulation mode, the signal becomes the IPL2 output. | | | | | | BERR | 1 | O.D | This signal reports to the processor that there is a problem in the current cycle. | | | | | | RESET | O.D | ı | In combination with HALT, this signal resets the processor. If the RESET instruction is executed, this signal functions as a reset signal for external devices. | | | | | | HALT | O.D | I | As an input, this signal halts the processor when the current bus cycle ends. Also, the signal acts as an output when a double bus error exception occurs. | | | | | | CLK | ı | 1 | Clock input pin. | | | | | | INTO, INT1,<br>INT2 | ı | I | External interrupt request input. | | | | | | IACKO, IACK1<br>IACK2 | 0 | 0 | These signals indicate the interrupt acknowledge cycles corresponding to INTO, INT1, and INT2. | | | | | | NOR/EMU | | 1 | Normal mode/emulation mode switch signal. | | | | | NOR: Normal mode, EMU: Emulation mode, O: Output, I: Input, I/O: Input/output | Ciamal name | Pin | status | Function | | | | | |-------------------------------------------------|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Signal name | NOR | EMU | Function | | | | | | RxD0 / [INT3]<br>RxD1 / [INT4]<br>RxD2 / [INT5] | I | I | Serial interface data inputs. These signals also act as interrupt inputs according to the expansion interrupt register. | | | | | | TxD0, TxD1, TxD2 | 0 | 0 | Serial interface data output. | | | | | | BCLK | I | 1 | Reference clock input for generating the serial interface baud rate. | | | | | | RTS0 | 0 | 0 | RTS signal for serial interface channel 0. | | | | | | TIN<br>[INT7] | ı | ı | Signal input to each timer channel. This signal also acts as an interrupt input according to the expansion interrupt register. | | | | | | TOUT1, TOUT2 | 0 | 0 | Timer channel 1 and 2 output signals. | | | | | | IO0 to IO7<br>/ DATA1 to DATA8 | I/O | 1/0 | General-purpose I/O ports or data bus for Centronics interface. | | | | | | IO8/DSTB | 1/0 | 1/0 | General-purpose I/O port or strobe signal for Centronics interface. | | | | | | IO9/BUSY | 1/0 | 1/0 | General-purpose I/O port or busy signal for Centronics interface. | | | | | | IO10/ACK | 1/0 | 1/0 | General-purpose I/O port or acknowledge signal for Centronics interface. | | | | | | IO11/PRIME | 1/0 | 1/0 | General-purpose I/O port or prime signal for Centronics interface. | | | | | | IO12 / FAULT<br>[INT6] | I/O | 1/0 | General-purpose I/O port or fault signal for Centronics interface. This signal also acts as an interrupt input according to the expansion interrupt register. | | | | | | IO13/CTS0 | 1/0 | 1/0 | General-purpose I/O port or CTS signal for serial interface channel 0. | | | | | | IO14/DSRO<br>[INT8] | I/O | 1/0 | General-purpose I/O port or $\overline{\text{DSR}}$ signal for serial interface channel 0. This signal also acts as an interrupt input according to the expansion interrupt register. | | | | | | IO15 / DTRO<br>[INT9] | I/O | 1/0 | General-purpose I/O port or DTR signal for serial interface channel 0. This signal also acts as an interrupt input according to the expansion interrupt register. | | | | | | CSO, CS1 | 0 | 0 | These signals are used to access the memory area set by the address decoder. | | | | | | Vcc | - | - | Power input pin ( + 5V). | | | | | | GND | _ | _ | GND pin (0V). | | | | | Table 2.1 Data Bus Control By Data Strobe | UDS | <u>LDS</u> | R/W | D8 to D15 | D0 to D7 | |-----|------------|-----|----------------------------|-----------------------------| | Н | Н | - | Data invalid | Data invalid | | L | L | Н | Valid data bits<br>8 to 15 | Valid data bits<br>0 to 7 | | Н | L | Н | Data invalid | Valid data bits<br>0 to 7 | | L | н | Н | Valid data bits<br>8 to 15 | Data invalid | | L | L | L | Valid data bits<br>8 to 15 | Valid data bits<br>0 to 7 | | Н | L | L | Valid data bits<br>0 to 7* | Valid data bits<br>0 to 7 | | L | Н | L | Valid data bits<br>8 to 15 | Valid data bits<br>8 to 15* | L : LOW H : HIGH \* : This condition is a result of the current implementation and may not apply in the future. Table 2.2 Function Code Output | FC2 | FC1 | FC0 | Cycle type | |-----|-----|-----|-----------------------| | L | L | L | * | | L | L | Н | User data | | L | Н | L | User program | | L | Н | Н | * | | Н | L | L | * | | Н | L | Н | Supervisor data | | Н | Н | L | Supervisor program | | Н | Н | Н | Interrupt acknowledge | (Note) L : LOW H : HIGH \* : Undefined, for future use Note: If FC0, FC1, and FC2 are pulled up, when releasing the bus, the state is the same as an interrupt acknowledge cycle, and the interrupt controller malfunctions. To prevent this, pull down one of FC0, FC1, or FC2. # 2.3 Signal Summary Table 2.3 Signal Summary | Signal name | Mnemonic | Input/output | Active state | Tri-state<br>output | When<br>HALT<br>asserted | When BG<br>asserted | When RESET / HALT both asserted | |-----------------------------|-----------------|--------------------|-----------------------|---------------------|--------------------------|---------------------|---------------------------------| | Address bus | A1 to A23 | Out (In) | Н | Υ | Hi-Z | Hi-Z | Hi-Z | | Data bus | D0 to D15 | In/out<br>(Out/In) | Н | Y | Hi-Z | Hi-Z | Hi-Z | | Address strobe | ĀS | Out (In) | L | Υ | Н | Hi-Z | Hi-Z | | Read / write | R/W | Out (In) | H (read)<br>L (write) | Υ | н | Hi-Z | Hi-Z | | Upper and lower data strobe | UDS, LDS | Out (In) | L | Υ | Н | Hi-Z | Hi-Z | | Data transfer acknowledge | DTACK | In (Out) | L | O.D. | ı | _ | _ | | Bus request | BR (/ IPLO) | In (Out) | L | N | - | _ | - | | Bus grant | BG (/ IPL1) | Out | L | N | Н | L | Н | | Bus grant acknowledge | BGACK (/ IPL2) | In (Out) | L | N | - | - | - | | Bus error | BERR | In (Out) | L | O.D. | ı | _ | - | | Reset | RESET | In/out | L | O.D. | O.D. | O.D. | L | | Halt | HALT | In/out | L | O.D. | L | O.D. | L | | Function code | FC0, FC1, FC2 | Out (In) | Н | Υ | ı | Hi-Z | Hi-Z | | Clock | CLK | In | Н | _ | ı | _ | _ | | I/O port | IO0 to 15 | In/out | Н | _ | ı | _ | - | | Timer output | TOUT1, TOUT2 | Out | Н | N | ı | - | L | | Timer input | TIN | In | L | _ | - | _ | - | | Request to send | RTS0 | Out | L | N | ı | _ | Н | | Receive data | RxD0 to 2 | In | Н | _ | - | _ | - | | Transmit data | TxD0 to 2 | Out | Н | N | ı | _ | Н | | Baud rate clock | BCLK | In | Н | _ | - | _ | - | | Mode switch | NOR/EMU | In | | - | - | - | - | | Interrupt request | INT0 to 2 | In | Н | _ | - | _ | _ | | Interrupt acknowledge | ĪACK0 to 2 | Out | L | N | _ | _ | Н | | Chip select | CSO, CS1 | Out | L | N | _ | _ | Н | | Power input | V <sub>CC</sub> | In | - | - | - | _ | - | | Ground | GND | In | _ | _ | _ | _ | _ | The parentheses in the input $\!\!/$ output column indicate in emulation mode. Note: O.D.: Open drain Hi-Z: High impedance -: Optional In : Input # 2.4 Pin Input / Output Circuits | Pin | Input/output circuit | Remarks | |-------------------------------------------------------------------------|----------------------|------------------------| | A1 to A23, D0 to D15 FC0 to FC2, AS, UDS, LDS R/W | ENABLE1 ENABLE2 | Tri-state output | | RESET, HALT, DTACK, BERR | | Sink open drain output | | BG TOUT1, TOUT2 RTS0 TxD0, TxD1, TxD2 IACK0, IACK1, IACK2 CS0, CS1 | | Push/pull output | | CLK<br>TIN<br>RxD0, RxD1, RxD2<br>BCLK<br>INT0, INT1, INT2<br>NOR / EMU | | | | BR, BGACK<br>IO0~IO7<br>IO8~IO15 | ENABLE | | # 3. Address Decoder #### 3.1 Outline The address decoder generates two $\overline{CS}$ (chip select) signals to select memory or external devices. The registers in the address decoder can freely select the $\overline{CS}$ memory area from the 16M bytes of address space available to the core processor. The size of the memory area can also be modified. A $\overline{DTACK}$ signal can be internally generated to allow the insertion of between 0 and 7 wait cycles in each memory area. The address decoder can freely allocate, in boundary units of 1K byte, the internal peripheral circuit registers to the 16M bytes of address space. Moreover, to allow the decoder to monitor the bus cycles in all memory areas, the address decoder includes a function to automatically generate $\overline{BERR}$ (bus errors) after a set timeout time. #### 3.2 Area Selection The address decoder decodes the addresses output from the core processor at each bus cycle. The decoder checks for access to the two memory areas and access to the register area. When a memory area is accessed, the address decoder externally asserts the chip select signal $(\overline{CSn})$ , inserts the pre-set wait cycle, and outputs the internal $\overline{DTACK}$ signal, which is generated automatically, to the core processor. Depending on circumstances, it may be possible to control the wait cycle inserted using the externally generated $\overline{DTACK}$ signal. When a register area is accessed, the address decoder selects an associated internal peripheral circuit and transfers the data. An internal $\overline{DTACK}$ signal is automatically generated and output to the core processor. At this time, a $\overline{DTACK}$ signal from an external source is ignored. When a register area is accessed, a valid signal is output to the external pins same as when a memory area is accessed. In the read cycle, if external memory overlaps a register area, the data from the internal peripheral circuit are valid; the data from the external source are ignored. In the write cycle, take care when external memory overlaps a register area, as the data are written to both the register area and external memory. To avoid writing to both the register and external memory areas, either ensure that the register area and the external memory do not overlap, or select the external memory using the $\overline{\text{CSn}}$ signal. If the memory area selected using the $\overline{\text{CSn}}$ signal overlaps with the register area, the access area is determined according to the area priority in Table 3.1. When the register area is accessed, the $\overline{\text{CSn}}$ signal is not asserted, thus avoiding accessing the same memory area. | | -, | |-----------------------------------------------------------|----------| | Area | Priority | | Register area | High | | Memory area 0 (area selected by $\overline{\text{CSO}}$ ) | | | Memory area 1 (area selected by CS1) | Low | Table 3.1 Area and Access Priority In the interrupt acknowledge cycle (IACK cycle), the core processor starts loading the vector number. At this time, no area selection signal is generated, even when the address generated attempts to access an area. (No register area access signal or $\overline{CSn}$ signal is asserted.) This prevents inadvertently accessing areas during the IACK cycle. When the vector number is input from an external source, the address decoder can set the number of wait cycles for a IACK cycle independently of other areas. Figure 3.1 outlines $\overline{\text{CSn}}$ signal generation. Figure 3.1 Chip Select Signal Generation Figure 3.2 shows the output status of area selection signals for overlapping areas. Figure 3.2 Output Status of Area Selection Signals Figure 3.3 shows the relationship between the $\overline{\text{CSn}}$ signal and the AS signal. Figure 3.3 CS Signal and AS Signal Relationship #### 3.2.1 Memory Area The memory area register (AMAR) specifies the start address in the memory area. Two areas can be specified in the 16M-byte address space. Every bus cycle, the address decoder compares the bus address and the value in the address register. If the values match, the address decoder determines that the memory area is accessed. The address mask register determines the size of the memory area. Figure 3.2 shows the relationship between the size of the area and the value in the address mask register for contiguous address space. Table 3.2 Relationship Between Memory Area Size and Address Mask Register | Memory Size<br>Mask Register | 256 | 512 | 64K | 128K | 256K | 512K | 1M | 2M | 4M | |------------------------------|-----|-----|-----|------|------|------|----|----|----| | For CSO (AAMRO) | 00 | 01 | 03 | 07 | OF | 1F | 3F | 7F | FF | | For CS1 (AAMR1) | 00 | 01 | 03 | 07 | 0F | 1F | 3F | 7F | FF | The numeric values in the Table are hexadecimal. The address mask register addresses for masking are determined in units of bits. Therefore, depending on the setting, non-contiguous memory areas can be specified. For example, setting the memory address register to \$00 and the address mask register to \$5F specifies two memory areas, \$000000 - \$07FFFF and \$100000 - \$17FFFF. # 3.2.2 Register Area The register area contains internal peripheral circuit registers, including the address decoder registers. The size of the register area is 1K byte. The start address of the register area is specified by the relocation register. Accordingly, the register area can be freely allocated at 1K-byte boundaries within the 16M-byte address space. Figure 3.4 shows actual address generation methods for the registers. The register area after reset release is allocated to \$FFFC00 - \$FFFFFF (last part of address space). (See Figure 3.5.) Figure 3.4 Real Register Address Generation Figure 3.5 Memory Map After Reset Release #### 3.3 Automatic DTACK Generation The address decoder can generate a $\overline{DTACK}$ signal for each memory area. The register area automatically generates $\overline{DTACK}$ to operate the bus with a zero wait. The register area can select whether $\overline{DTACK}$ signal generated in an external circuit or that generated in the address decoder is valid, or whether both are valid for the memory area. When both are valid, the first signal asserted is the $\overline{DTACK}$ signal output to the core processor. The address decoder can control the $\overline{DTACK}$ signal output to the core processor by inserting 0 to 7 wait cycles. To control the $\overline{DTACK}$ signal, the address decoder can also insert wait cycles in the IACK cycle (which loads external exception vectors) the same as for the memory area. Figure 3.6 illustrates the $\overline{DTACK}$ signal generation circuit. The internal peripheral circuit registers of TMP68301A automatically generate the $\overline{DTACK}$ signal to enable access with no wait. Note: During assertion of signals marked with an asterisk (\*), the selection circuit inputs the set register values to the circuit in the dotted-line box. During the interrupt acknowledge cycle, \*EN is 1. When internal peripheral circuit registers are accessed, \*EN and \*ID are set to 1 and \*wait is set to 0. Figure 3.6 DTACK Signal Generation Circuit # 3.4 Bus Cycle Outline For an address with no memory allocated in the system, the bus cycle stops without returning the $\overline{DTACK}$ signal. If the length of the bus cycle is abnormal, an address decoder function generates a $\overline{BERR}$ (bus error) signal. The length of the bus cycle until bus error generation can be selected among 32, 64, 128, or 256 clocks. To use bus cycles above 256 clocks, an externally generated $\overline{BERR}$ signal can be validated by disabling generation of the $\overline{BERR}$ signal by the address decoder. Figure 3.7 illustrates the $\overline{BERR}$ signal generation circuit. Figure 3.8 shows the $\overline{BERR}$ signal generation timing. This bus cycle monitoring applies to all memory areas regardless of the memory area of $\overline{\text{CSx}}$ . Figure 3.7 BERR Signal Generation Circuit Figure 3.8 BERR Signal # 3.5 Register Configuration ## 3.5.1 Memory Address register (AMAR0, 1) This register specifies the start address of the memory area. Addresses are specified in upper eight bits, A23 to A16. The start address of the memory area can be set only within the boundary of the area determined by the address mask register. For example, if the size of the area is 4M bytes, only bits A23 and A22 of the memory address register are compared with the address, and four start addresses are available: \$000000, \$400000, \$800000, and \$C00000. (If the area is 256 or 512 bytes, the start address has a 64K-byte boundary because of the relationship with masked addresses.) After reset, AMAR0 (for $\overline{CS0}$ ) is \$00, and AMAR1 (for $\overline{CS1}$ ) is undefined. # 3.5.2 Address Mask Register (AAMRO, 1) This register sets the size of the memory area by masking the address output from the core processor. Addresses A21 to A8 can be masked. The following table lists address mask register bits and their corresponding addresses to be masked. | Mask register bit | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |----------------------|------|------|------|------|------|------|----------|------| | Address to be masked | A21 | A20 | A19 | A18 | A17 | A16 | A15 - A9 | A8 | Setting the bits to 1 masks the corresponding addresses; to 0 does not mask. After reset, AAMR0 (for $\overline{CS0}$ ) is \$FF, and AAMR1 (for $\overline{CS1}$ ) is undefined. #### 3.5.3 Area Control Register (AACR0, 1, 2) Registers AACR0 and AACR1 enable or disable memory areas in response to $\overline{CS0}$ and $\overline{CS1}$ signals, specify $\overline{DTACK}$ signal generation mode, and the number of waits to insert. When an area is disabled, the $\overline{\text{CS}}$ signal is not asserted although the specified memory area is accessed, and the address decoder does not generate a $\overline{\text{DTACK}}$ signal. Register AACR2 specifies $\overline{\text{DTACK}}$ generation mode in the interrupt acknowledge cycle, and the number of waits to insert. The setting in register AACR2 determines the $\overline{DTACK}$ generation mode in the IACK cycle when no vector number is automatically generated in an external interrupt. When a vector number is automatically generated due to an interrupt from an internal device or an external interrupt, a zero wait $\overline{DTACK}$ is generated regardless of the setting of register AACR2. After a hardware reset, AACR0 is set to \$3D (area enable, both external and internal $\overline{DTACK}$ enable, up to five wait clocks) and AACR1 is set to \$18 (area disable, both external and internal $\overline{DTACK}$ enable, no wait clocks). AACR2 is set to \$18 (both external and internal DTACK enable, no wait clocks). EN: Area control 0: Area disable (CSn signal not output, no internal DTACK generated) 1: Area enable (CSn signal output, internal DTACK generated) $ED, ID : \overline{DTACK}$ selection | ED | ID | DTACK Used | |----|----|---------------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | Use prohibited (even when set, $ED = 0$ , $ID = 1$ ) | | 0 | 1 | Use internal $\overline{\text{DTACK}}$ (even when $\overline{\text{DTACK}}$ pin asserted, external $\overline{\text{DTACK}}$ ignored) | | 1 | 0 | Use external DTACK (no DTACK generated by address decoder) | | 1 | 1 | Use both internal and external $\overline{DTACK}$ (the first asserted is valid) | Wait: Number of waits to be inserted When using internal DTACK, set the number of waits to be inserted. Settings are from 0 to 7 clocks. #### 3.5.4 Timeout Register This register specifies the time until $\overline{BERR}$ generation. The time can be selected from among 32, 64, 128, or 256 clocks. If more than one bit is set, only the bit corresponding to the longest time remains set and the other bits are cleared. If no bit is set, no $\overline{BERR}$ is generated by the address decoder. After a hardware reset, the timeout register is set to \$08 (256 clocks). R: Read only | | Set value | | | Time until BERR generation | | | | |-----|-----------|----|----|----------------------------|--|--|--| | 256 | 128 | 64 | 32 | Time until BERR generation | | | | | 0 | 0 | 0 | 0 | No BERR generation | | | | | 0 | 0 | 0 | 1 | Generated after 32 clocks | | | | | 0 | 0 | 1 | Х | Generated after 64 clocks | | | | | 0 | 1 | х | х | Generated after 128 clocks | | | | | 1 | Х | Х | Х | Generated after 256 clocks | | | | X: Any value # 3.5.5 Relocation Register This register specifies the start address of the internal register block. Specifiable addresses are A23 to A10. Accordingly, the register block can only specify in 1K-byte boundaries. After a hardware reset, the relocation register is set to \$FFFC. R : Read only #### 3.6 Bus Cycles Based on External Bus Master When an external device other than the core processor becomes the bus master, the address decoder functions as if the core processor was the bus master. As a result, the external bus master can access the internal registers of the address decoder. The timing of the bus cycle generated by the external bus master must match the specifications of the bus cycle generated by the core processor. If the timing does not match these specifications, the internal register contents may be overwritten in the write cycle generated by the external bus master. #### 3.7 Cautions - 1. While area control register 2 is for the interrupt acknowledge cycle, the settings here are valid only for reading external vector numbers by external interrupts. - 2. When both the internal and external DTACK (ED=1, ID=1) are selected in the area control register, accessing an area under the conditions specified below prevents normal execution of the next cycle. This occurs with either CS0 or CS1. For example, if the conditions are satisfied in a CS1 cycle followed by a CS0 cycle, CS0 cycle becomes an abnormal cycle. In the reverse case, even if the CS0 or CS1 access is repeated and the conditions are satisfied, then the next cycle becomes an abnormal cycle. | | | External wait set value | | | | | | | | | | | |-------------------|---|-------------------------|---|---|---|---|---|---|---|--|--|--| | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | | | l<br>n | 0 | 0 | - | - | _ | _ | - | _ | - | | | | | n<br>t<br>e | 1 | ×а | 0 | _ | - | _ | _ | _ | 1 | | | | | r<br>n | 2 | ×а | × | 0 | - | _ | _ | _ | - | | | | | a<br>I<br>s | 3 | 0 | × | × | 0 | _ | - | _ | - | | | | | w e | 4 | 0 | 0 | × | × | 0 | - | _ | - | | | | | a t<br>i v<br>t a | 5 | 0 | 0 | 0 | × | × | 0 | _ | - | | | | | u<br>u | 6 | 0 | 0 | 0 | 0 | × | × | 0 | _ | | | | | ě | 7 | 0 | 0 | 0 | 0 | 0 | × | × | 0 | | | | - O: If the bus cycle ends at this condition, the next bus cycle receives the set number of waits and operates normally (no problem). - ×: If the bus cycle ends at this condition, the next bus cycle generates the following: - When the set number of waits for the next bus cycle is one or two and the cycle is the read cycle, this read cycle has no-wait access. If the read cycle is repeated, all subsequent cycles have no-wait access. (Because the Xa status shown in the table above continues.) - When the set number of waits for the next bus cycle is other than one or two and the cycle is a read cycle, this read cycle has no-wait access. - If the read cycle is repeated, only the first cycle has no-wait access. (Because when the actual number of waits is 0, the status is 0.) - When the next bus cycle is a write cycle, the set number of waits is inserted as normal. - When the next bus cycle is an internal peripheral circuit register read or write cycle, ends normally. For example, if the wait setting for CS0 is 1 or 2, the wait setting for CS1 is 4, the actual cycle for CS1 ends at wait 3, and the immediate next cycle is CS0, then there is no wait. If, at this time, CS0 uses only the internal DTACK (ED=0, ID=1), there is still no wait. If an interrupt vector is written from an external source, the number of waits can be set in the interrupt acknowledge cycle. However, if prior to the acknowledge cycle, the bus cycle ends in an X state as shown in the table above, there is no wait. If the above conditions are satisfied, the next cycle may not operate normally. Therefore, do not make settings which result in combinations marked with "x" in the table. # 4. Interrupter Controller #### 4.1 Overview The interrupt controller provides 10 interrupt channels. Seven of the channels are for internal peripheral circuits, while the other three are for external interrupts from interrupt request input pins INTO, 1, and 2. Interrupt request levels input to the core processor (the pattern of "0"s and "1"s input to the core processor IPLO, 1, and 2) can be set for each channel. Priorities can be set independently. Interrupt request input mode (input level, rising / falling edge) for external interrupts can also be set independently. In addition, the external interrupt vector number can be selected as either an internal vector number in the interrupt controller, or an externally input vector number. If an external vector is input, the IACK output (IACK0, 1, or 2) corresponding to an external interrupt channel is asserted in accordance with the interrupt acknowledge cycle. The auto-vectored interrupt function supported by the TMP68HC000 is not available because the TMP68301AK does not have 68000 interface signals. Figure 4.1 shows a block diagram of the interrupt controller. <sup>\*</sup> This signal is generated by decoding FC0 to 2 and other signals. Figure 4.1 Interrupt Controller Block Diagram #### 4.2 Interrupt Request When an interrupt request is present on an interrupt channel, the interrupt controller uses the internal $\overline{IPL0}$ to $\overline{IPL2}$ signals (not output to external pins in normal mode) to issue an interrupt request to the core processor at the previously set interrupt level. If requests are generated on more than one channel at the same time, the request with the highest priority level is issued. The following input modes can be selected for external interrupt requests (interrupts using INTO, 1, or 2). - Low-level interrupt - High-level interrupt - Rising-edge interrupt - Falling-edge interrupt Interrupt request inputs (INT0, 1, or 2) are detected on the falling edge of the system clock. Level-triggered interrupts must be asserted until the $\overline{IACK}$ output ( $\overline{IACK0}$ , $\overline{1}$ , $\overline{2}$ ) for the channel corresponding to the interrupt request is asserted. Edge-triggered interrupts must be held at the same state for at least two system clocks after the edge to prevent malfunction due to noise. Note: When switching from level mode to edge mode, the interrupt requests (pending bits) received in level mode are not cleared. To avoid this, clear any interrupt requests as follows: - 1. Mask interrupt requests - 2. Switch from level mode to edge - 3. Clear the pending bits - 4. Release the interrupt request mask Figure 4.2 External Interrupt Request # 4.3 Priority Between Channels The interrupt controller can set the interrupt level of IPL0, 1, and 2 for interrupting the core processor using the level bit of the interrupt control register for each channel. This sets the relative priority of each channel. The following priority applies if more than one channel is set to the same interrupt level: | Priority | | Channel | | |----------|---------|----------------------------|-----------| | Hi | igh | External interrupt request | Channel 0 | | | | Timer | Channel 0 | | | | Serial interface | Channel 0 | | | | Parallel interface | | | | | External interrupt request | Channel 1 | | | | Timer | Channel 1 | | | | Serial interface | Channel 1 | | | • | Serial interface | Channel 2 | | | | Timer | Channel 2 | | Lo | )<br>ow | External interrupt request | Channel 2 | Table 4.1 Priority of Channels Set to Same Interrupt Request Level ## 4.4 Interrupt Acknowledge Cycle (IACK Cycle) In 68000 interrupt processing, if an interrupt is accepted, the interrupt acknowledge cycle (IACK cycle) is performed. The interrupt request level is released on addresses A1 to A3 is output and the corresponding interrupt vector number is read from data bus D0 to D7. The 68301A interrupt controller has a function to automatically generate the vector number to be read by the core processor during the $\overline{IACK}$ cycle. This function allows the interrupt controller to automatically perform the above interrupt processing. Also, when an external interrupt is accepted, the interrupt controller can assert the IACKn signal corresponding to the interrupt and obtain the vector externally. If more than one channel issues requests at the same level, an interrupt acknowledge signal is asserted for the channel with the highest priority in Table 4.1. The interrupt acknowledge signal asserted here only applies internally to the 68301A and is not output externally. However, depending on the register setting, external interrupts can be output externally as $\overline{IACK}$ signals. $\overline{IACK}$ signals are asserted using the same timing as that for $\overline{AS}$ signals. Area control register 2 in the address decoder can be set to insert a WAIT into IACK cycles. For details, see the address decoder section. Figure 4.3 IACK Signals for External Vector Fetch by External Interrupt #### 4.5 Automatic Generation of Vector Numbers The interrupt controller automatically generates vector numbers during IACK cycles and these are read by the core processor. The five lower bits of the vector are determined depending on the interrupt channel or request. The three upper bits are set using the interrupt vector number register (IVNR). See Table 4.2 for a list of vector numbers. In the case of external interrupt requests, automatic generation or external vector input can be selected by setting the vector generation mode bit (V bit) of the interrupt control register (ICR0, 1, or 2). Serial interface interrupt requests generate vector numbers not only corresponding to the channel generating the interrupt, but also in accordance with the cause of the interrupt. | Channel | Cause | Vector Number | |------------------------------|------------------------------------------------------------|---------------| | External interrupt Channel 0 | | XXX00000 | | External interrupt Channel 1 | | XXX00001 | | External interrupt Channel 2 | | XXX00010 | | Timer 0 Channel 0 | | XXX00100 | | Timer 1 Channel 1 | | XXX00101 | | Timer 2 Channel 2 | | XXX00110 | | Serial interface Channel 0 | Receive error, break detection | XXX01000 | | | Receive complete | XXX01001 | | | Transmit ready | XXX01010 | | | Interrupt source cleared while interrupt pending (Note 1) | XXX01011 | | Serial interface Channel 1 | Receive error, break detection | XXX01100 | | | Receive complete | XXX01101 | | | Transmit ready | XXX01110 | | | Interrupt source cleared while interrupt pending (Note 1) | XXX01111 | | Serial interface Channel 2 | Receive error, break detection | XXX10000 | | | Receive complete | XXX10001 | | | Transmit ready | XXX10010 | | | Interrupt source cleared while interrupt pending (Note1) | XXX10011 | | Parallel interface | Receive complete | XXX10101 | | | Transfer ready | XXX10100 | | | Status change (fault input at transmit) of external device | XXX10110 | | | Interrupt cause cleared while interrupt pending (Note 1) | XXX10111 | | Other | Default vector (Note 2) | XXX11111 | XXX : Set by the three upper bits of the IVNR. Table 4.2 Vector Number List Note1: This vector number is generated when the cause of the interrupt becomes unknown if the interrupt source is cleared before the interrupt acknowledge is returned for a pending interrupt. Note2: If the CPU accepts an interrupt, the IACK cycle starts after the following instruction is completed. However, if that instruction masks the interrupt, the cause becomes masked and the vector is fixed at "11111" because the vector cannot now be generated by the IACK cycle. #### 4.5.1 Interrupt Source Cleared While Interrupt Pending This interrupt is generated under the following conditions. The following description is based on the generation of a serial 0 interrupt. When an interrupt is generated by the interrupt source, an interrupt request is passed to the interrupt controller. As a result, the interrupt controller sets the relevant IP bit to "1". If the relevant interrupt is masked, the interrupt controller waits for the interrupt request to be issued to the 68HC000 core. (Note 1: MPI represents the bit status of the mask register, pending register, and in-service register for the generated interrupt). During this period, the interrupt condition may be cleared at the interrupt source. (The above example shows when the $\overline{\text{CTS0}}$ input changes to high in the transmit interrupt state). Even if the interrupt cause is cleared at the interrupt source, because interrupt control is still pending, the interrupt controller sends an interrupt request to the 68HC000 core when the interrupt mask is cleared. This starts the interrupt sequence and generates the interrupt vector. Because the vector reflects the state of the interrupt source, "no applicable interrupt" indicates that the interrupt cause was cleared at the interrupt source while the interrupt was pending, as mentioned previously. For serial interfaces, these kinds of interrupts occur under the following conditions: - (a) The interrupt is masked by the serial mode register (SMRn) while it is pending. - (b) The $\overline{\text{CTS0}}$ input changes to high while a transmit ready interrupt is pending. (TxRDY is set to "0" when $\overline{\text{CTS0}}$ changes to high, clearing the transmit interrupt cause.) - (c) In the serial command register (SCMRn), TxEN is set to "0" while a transmit ready interrupt is pending, or RxEN is set to "0" while a receive complete interrupt is pending. - (d) The receive buffer is read by the error interrupt processing routine. (If both ERINTM and RxINTM of the serial mode register [SMRn] are "0" and both interrupt masks are cleared, both error interrupt and receive interrupt are generated when an error occurs. Since the priority of the error interrupt is higher, the error interrupt processing routine is executed first. If the serial data register [SDRn] is read by this processing routine, the pending receive interrupt is cleared). These interrupts occur due to software processing problems as described above. Therefore, check your software and make necessary modification so that these interrupts will not occur. #### 4.5.2 Default Vector Interrupts Default vector interrupts occur under the following conditions. The following description is based on the generation of a timer 0 interrupt. When an interrupt is generated, an interrupt request is passed to the interrupt controller. As a result, the interrupt controller sets the relevant IP bit to "1", checks that the interrupt is the highest priority interrupt, and outputs an interrupt with the set interrupt level to the 68HC000 core ( $\overline{IPL0}$ to $\overline{2}$ output). The internal status of the interrupt controller at this time is as follows: mask bit = "1" (M=1), pending bit = "1" (P=1), and in-service bit = "0" (I=0). (Note 1: MPI represents the bit status of the mask register, pending register, and in-service register for the generated interrupt). When the 68HC000 core accepts the $\overline{IPL0}$ to $\overline{2}$ interrupts, it attempts to jump to the interrupt sequence operations. However the interrupt sequence is delayed until instruction B fetched by the 68HC000 core is executed. If instruction B masks the generated interrupt (Note 2), the instruction is executed and the interrupt request by the interrupt controller is cancelled. Subsequently, even if the 68HC000 core starts the interrupt acknowledge cycle, the interrupt controller does not have a corresponding interrupt and so generates a default vector indicating that there is no relevant interrupt and ends the interrupt acknowledge cycle. Even if a default vector interrupt is generated, the interrupt generated remains in the interrupt controller in the pending state (Note 3). Accordingly, after clearing the interrupt mask, a normal interrupt sequence can be performed. If you simply wish to return to the main processing and disable vector generation when this default interrupt occurs, insert an instruction before the interrupt mask instruction (instruction B), to set the 68HC000 core interrupt level to the highest level. This prevents the 68HC000 core from receiving interrupts, apart from interrupt level 7, thus preventing initiation of the interrupt sequence midway through masking the interrupt. However, if the level of the interrupt generated is 7, the 68HC000 core cannot disable the interrupt request and the default vector is generated. In this case, perform default vector processing. #### 4.6 Interrupt Status The interrupt status for each channel is represented by the mask register (IMR), pending register (IPR), and in-service register (IISR) bits corresponding to the channel. The meaning of these bits are described below. The set (setting the bit to "1") and reset (setting the bit to "0") methods vary according to a bit. | Mask Bit (I | M) | Control Bit for masking interrupt requests | | |--------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--| | IVIASK BIT (IVI) | | Control Bit for masking interrupt requests | | | 1 | Masks the interrupt | Masks the interrupt request. | | | 0 | Unmasks the interru | pt request. | | | set | Set by hardware res | Set by hardware reset or by writing "1" by software. | | | reset | Set to "0" by software. | | | | Pending b | it (P) | Indicates an interrupt request occurred and is pending (waiting for interrupt processing). | | | 1 | An interrupt request occurred and is pending. | | | | 0 | No interrupt request occurred | | | | set | An interrupt request occurred (this bit cannot be set to "1" by software). | | | | reset | Reset by hardware reset or by writing "0" by software when the interrupt request is accepted by the core processor. (See Notes) | | | | In-service bit (I) | | Indicates that an interrupt request has been accepted by the core processor. | | | 1 | Indicates that an interrupt request has been accepted. | | | | 0 | Indicates that no interrupt request has been accepted. | | | | set | An interrupt request is accepted by the core processor (this bit cannot be set to "1" by software). | | | | reset | Hardware reset Set to "0" by software | | | Note1: The function to clear pending bits by software is used when initializing the whole system or when pending bits are set by unnecessary interrupts. However, if pending bits set according to interrupts generated by internal peripheral circuits are cleared to "0", interrupts will no longer occur. This is because the pending bit is only set when the interrupt request from the interrupt source changes from "0" to "1" (when an interrupt is generated). To re-enable interrupts after the pending bit has been cleared, the interrupt source must also be operated as follows. #### Timer First clear the interrupt request bit (INT bit) of the timer control register (TCRn) to "0", then set to "1". # Serial Interface First set the interrupt mask bit (INTM bit) of the serial control register (TCRn) to "1", then clear to "0". If, at that time, an interrupt request is present due to an interrupt source in a channel, the corresponding IP bit is set immediately after the INTM bit is cleared to "0". To avoid this, disable interrupt requests for the channel (for example, by setting an interrupt mask for each channel, by reading the receive data, or by performing an error reset) before performing the above procedure. #### Parallel Interface With a transmit ready interrupt, set the transmit interrupt mask bit (bit IM1) of the parallel command register (PCR) to 1, then clear the bit to 0. With a receive complete interrupt, set the receive complete interrupt mask bit (bit IM3) of the PCR to 1, then clear the bit to 0. At a fault interrupt, set the fault interrupt mask bit (bit IM2) of the PCR to 1, then clear the bit to 0. #### External Interrupt For edge mode interrupts, the IP bit is set the next time the interrupt edge is input. For level mode interrupts, the IP bit is set the next time the interrupt input is asserted. Note2: For level mode interrupts, clearing the IP bit by software requires first negating the interrupt input. The IP bit cannot be cleared by software while the interrupt input is still asserted. When clearing the pending bit by software, write "1" to all bits except for the bit to be cleared. Writing "1" to the pending bit will not affect operation but enables interrupts to be generated even though the pending bit is mistakenly cleared. The interrupt states for the mask bit (M), pending bit (P), and in-service bit (I) values are shown in Table 4.4. | М | Р | -1 | | | |---|---|----|---------------------------------------------------------------------------------------------|--| | 0 | 0 | 0 | No interrupt request | | | 0 | 0 | 1 | During interrupt processing routine | | | 0 | 1 | 0 | Interrupt request generated | | | 0 | 1 | 1 | Another interrupt request is generated during an interrupt processing routine. | | | 1 | 0 | 0 | No interrupt request | | | 1 | 0 | 1 | Interrupt is masked during an interrupt processing routine | | | 1 | 1 | 0 | Interrupt request generated while interrupt is being masked | | | 1 | 1 | 1 | Interrupt request generated after masking interrupt during an interrupt processing routine. | | Table 4.3 Interrupt Status ## 4.7 Register Configuration # 4.7.1 Interrupt Controller Registers 0, 1, and 2 (ICR0, 1, and 2) These registers control the external interrupt inputs (INT0, 1, and 2). The registers set the interrupt level and select external vector input or automatic generation of the vector number set for input mode. After a hardware reset, ICR0, 1, and 2 are all initialized to \$07 (vector number from external source, falling edge mode, interrupt request level 7). These registers can only be written to when the interrupt is masked by the interrupt mask register (IMR). V: Vector number automatic generation control 0 : Reads vector number from an external source instead of automatic generation of vector number 1 : Vector number automatic generation R/F, L/E : Request input mode for external interrupts | R/F | L/E | Interrupt Request Input Mode | |-----|-----|------------------------------| | 0 | 0 | Falling edge | | 1 | 0 | Rising edge | | 0 | 1 | Low level | | 1 | 1 | High level | $Level: \quad Interrupt \, request \, level$ 0 to 7: Indicate the interrupt request level corresponding to $\overline{IPL0}$ , $\overline{1}$ , and $\overline{2}$ to be input to the core processor. For example, $\overline{IPL2} = \overline{1}$ , $\overline{IPL1} = \overline{0}$ , and $\overline{IPL0} = \overline{0}$ indicate request level 3. The following table shows the correspondence between IPLx and interrupt levels. | Interrupt level | ĪPL2 | ĪPL1 | ĪPL0 | |-----------------|------|------|------| | 0 | 1 | 1 | 1 | | 1 | 1 | 1 | 0 | | 2 | 1 | 0 | 1 | | 3 | 1 | 0 | 0 | | 4 | 0 | 1 | 1 | | 5 | 0 | 1 | 0 | | 6 | 0 | 0 | 1 | | 7 | 0 | 0 | 0 | # 4.7.2 Interrupt Control Registers 3 to 5, 7 to 9 (ICR3 to 5, 7 to 9) These are the interrupt control registers for interrupts from internal peripheral circuits. After a hardware reset, ICR3 to 5 and 7 to 9 are all initialized to \$07 (interrupt request level 7). These registers can be written to only when the interrupt is masked by the interrupt mask register (IMR). Level: Interrupt request level 0 to 7: Indicate the interrupt request level corresponding to IPL0, 1, and 2 to be input to the core processor. #### 4.7.3 Interrupt Mask Register (IMR) This register sets the interrupt mask for a channel. A "1" masks the interrupt (ignore interrupt). A "0" unmasks the interrupt (allow interrupt). If masking an interrupt during operation, set the channels corresponding to the bits to be modified to a state whereby, even if an interrupt is generated, it will not be accepted by the core processor. (For example, set the interrupt level in the core processor status register to 7). This is necessary because, if an interrupt occurs during masking, the interrupt to be masked may be generated due to the timing mismatch. After a hardware reset, this register is initialized to \$07F7 (all interrupt channels masked). T2: Timer channel 2 T1: Timer channel 1 T0 : Timer channel 0 P : Parallel interface S2 : Serial interface channel 2 S1: Serial interface channel 1S0: Serial interface channel 0 E2 : External interrupt channel 2 E1: External interrupt channel 1 E0 : External interrupt channel 0 P : Parallel interface (only the case that IO12 is used for INT6 (External interrupt)) Note: Bit 7 is normally set to "1". R: Read only # 4.7.4 Interrupt Pending Register (IPR) This register indicates whether there is an interrupt request and that the interrupt request is not yet accepted by the core processor. A "1" indicates that there is an interrupt request that has not yet been accepted by the core processor. A "0" indicates that there is no interrupt request. Each bit is automatically cleared when the request is accepted by the core processor. Clearing a bit using software cancels the interrupt request. However, to enable subsequent interrupts, the interrupt source must be cleared. After a hardware reset, this register is initialized to \$0000 (no interrupt requests). # 4.7.5 Interrupt In-Service Register (IISR) This register indicates whether or not an interrupt request has been accepted by the core processor. A "1" indicates that a request has been accepted. A "0" indicates that a request has not been accepted. While operating with the register set to "1" does not affect operation, clear each bit during the interrupt processing routine. (These bits are not cleared automatically). After a hardware reset, the register is initialized to \$0000 (no interrupt requests accepted). # 4.7.6 Interrupt Vector Number Register (IVNR) This register specifies the three upper bits of a vector number. The five lower bits of a vector number are determined by the interrupt channel or the interrupt source. After a hardware reset, the register is initialized to \$00. Note: After a reset is released, the 68HC000 core interrupt vectors overlap the internal peripheral circuit interrupt vectors. Therefore, set the value of IVNR to \$40 or more by software. Vector: Three upper bits of the vector number #### 4.8 Interrupt Expansion Function In the TMP68301A, interrupt channels assigned to unused peripheral circuits can be used as external interrupt inputs by setting the expansion interrupt register. Thus, a maximum of seven channels can be used for external interrupt inputs in addition to the three standard external interrupt channels. The interrupt input pins are assigned as follows: | Peripheral circuit interrupt channel | Interrupt input pin | Interrupt input name | | |--------------------------------------|---------------------|----------------------|--| | Serial interface ch0 | RxD0 | ĪNT3 | | | Serial interface ch1 | RxD1 | ĪNT4 | | | Serial interface ch2 | RxD2 | ĪNT5 | | | Parallel interface | IO12/FAULT | ĪNT6 (Note) | | | Timer ch0 | TIN | ĪNT7 | | | Timer ch1 | IO14/DSR0 | ĪNT8 (Note) | | | Timer ch2 | IO15/DTRO | ĪNT9 (Note) | | Note: When used as interrupt inputs, the pins must be first set to input in the parallel direction register. Only falling-edge input mode is available for expanded external interrupts. However, like the standard external interrupt inputs, the state must be held for at least two clocks after the falling edge. Multiple falling edges may occur before the processor accepts an interrupt request. The processor treats these edges as if they were the same interrupt request. There is no IACK output signal corresponding to the expanded external interrupts. Therefore, the vector number is generated automatically by the interrupt controller because the vector number cannot be input from an external source during the interrupt acknowledge cycle. Vector numbers generated at this time are as follows. | Interrupt channel | Interrupt input name | Vector number | |----------------------|----------------------|---------------| | Serial interface ch0 | ĪNT3 | XXX010** | | Serial interface ch1 | ĪNT4 | XXX011** | | Serial interface ch2 | ĪNT5 | XXX100** | | Parallel interface | ĪNT6 | XXX101** | | Timer ch0 | ĪNT7 | XXX00100 | | Timer ch1 | ĪNT8 | XXX00101 | | Timer ch2 | ĪNT9 | XXX00110 | XXX : The three upper bits specified by the vector number register \*\*: The two lower bits of the interrupt vector number assigned to the serial interface depend on the status of the standard interrupt channels. Accordingly, when using these interrupts, set the same destination address in all four. The same applies to INT6. ## 4.8.1 Expansion Interrupt Register (IEIR) This register controls the switching of interrupt channels between internal peripheral circuits and external interrupt inputs. A "1" indicates external interrupt input. A "0" indicates interrupts from the internal peripheral circuits (external interrupt input disabled). After a hardware reset, this register is initialized to \$00 (all channels set to internal peripheral circuit interrupts). T2 : Timer ch2 T1 : Timer ch1 T0 : Timer ch0 P : Parallel interface S2 : Serial interface ch2 S1 : Serial interface ch1 S0 : Serial interface ch0 Note1: Even if external interrupt input is enabled, the internal peripheral circuits can perform their original functions. However, the pins assigned as interrupt inputs (for example, the serial interface RxD) cannot be used for their original functions. The peripheral circuits can function but cannot generate interrupts if the interrupt channels are used for interrupt inputs. # 5. Serial Interface #### 5.1 Outline The serial interface consists of three independent channels, which support full-duplex universal asynchronous receiver / transmitter (UART). Both the receive and transmit modules use double buffers and the same data format and baud rate. However, the receive and transmit modules are functionally independent. The data format used is a standard mark/space format. The data format consists of one start bit, between 5 and 8 data bits, and one or two stop bits. The serial interface also supports parity bit processing. The serial interface includes only one prescaler, and one baud rate generator for each channel to generate the baud rate clocks. Thus, independent baud rate clocks are available for each channel. The system clock (CLK) or external clock (input from the BCLK pin) can be selected as the divider clock. Error detect (parity error, overrun error, framing error) is supported. Break detect and break transmit is also supported. If an interrupt cause (receive complete, transmit ready, error occurred, break detected) is generated in any channel, an interrupt request is forwarded to the core processor via the interrupt controller. A separate vector number can be generated in the interrupt acknowledge cycle specifically for the channel and interrupt cause. Channel 0 supports modem control signals. Figure 5.1 is the serial interface block diagram. Figure 5.2 is a detailed channel diagram. Figure 5.1 Serial Interface Block Diagram Figure 5.2 Channel Detail Diagram Note: In the following description, the data register (SDR) is called the transmit data register at transmission, and the receive data register at reception. Although the transmit data register and the receive data register share the same register address, they are independent of each other. At read, the receive data register is accessed. At write, the transmit data register is accessed. #### 5.2 Communications #### 5.2.1 Data Format Figure 5.3 shows the data frame formats input through the serial interface from the receive data input pins (RxD0, RxD1, and RxD2), and output to the transmit data output pins (TxD0, TxD1, and TxD2). Figure 5.3 Data Frame - ① When no data are transmitted or received, the data lines are at level 1 (mark state). - ② The transmit (when sending) of the start bit (level 0) or detect (when receiving) of the start bit indicates the start of the data frame. - ③ The transmit/receive character immediately follow the start bit, beginning with the least significant bit. The serial mode register (SMR) setting determines the character length n (from five to eight bits). - (4) Setting the parity bit in the serial mode register (SMR) sends the parity bit at transmit, and checks the parity after receiving the parity bit at receive. - ⑤ The stop bit (level 1) indicates the end of the data frame. At transmit, one or two stop bits are sent in accordance with the serial mode register setting. At receive, regardless of the serial mode register setting, only one bit is identified as the stop bit. The stop bit is the bit following the most significant data bit (last data bit received; when parity bit receive is not set) or the bit following the parity bit (when parity bit receive is set). If the stop bit is at 0 level, a framing error is generated. - (6) A break consists of two consecutive frames where all data bits, the parity bit, and the stop bits, are at 0 level. ### 5.2.2 Baud Rate Clock Generation The serial interface uses an 8-bit prescaler and an 8-bit baud rate generator to divide the system clock (CLK) or external input clock (BCLK) and thereby generate a baud rate clock. Figure 5.4 is the baud rate clock generation circuit block diagram. Figure 5.4 Baud Rate Clock Generation Circuit Block Diagram The input clock select circuit selects either the system clock (CLK) or the external input clock (BCLK). The selected clock (SCLK) is divided by the prescaler by from 1/1 to 1/256 (PCLK), and the PCLK is divided by the baud rate generator by $1/2^n$ (n=0-7) times (GCLK). The GCLK is used as the fundamental clock for serial interface transmit/receive. The GCLK is further divided by eight times (TCLK) for transmitting data frames. One prescaler is built into the serial interface. One baud rate generator is built into each channel. #### 5.2.3 Data Transmit When a transmit character is written into the transmit data register (SDR), the serial interface resets the TxE (transmit data register buffer empty) bit of the status register (SSR) to 0 and checks whether transmit with the TxEN (transmit ready) bit of the command register (SCMR) is in progress. When $\overline{\text{CTS0}}$ is used in channel 0, the serial interface also checks pin $\overline{\text{IO13}}/\overline{\text{CTS0}}$ . When $\overline{\text{CTS0}}$ is not used, if TxEN=1 and transmit is not in progress, transmit begins with the transmit character loaded from the transmit data register to the transmit buffer. When $\overline{\text{CTS0}}$ is used, if TxEN=1, $\overline{\text{IO13}}/\overline{\text{CTS0}}$ =0, and transmit is not in progress, transmit begins in the same way. The transmit is synchronous with TCLK, which is generated by the baud rate generator. Figure 5.5 shows TLCK and the data frame detection timing. Figure 5.5 Data Frame Transmit Timing When the serial interface starts transmit, the interface transmits the start bit and sets the TxRDY (transmit ready) bit of the status register (SSR) to 1. As the transmit character is loaded from the transmit data register to the transmit buffer at that point, the next transmit character can be loaded in the transmit data register in advance. When the next transmit character is written in the transmit data register, it is retained in that register until transmission of the current transmit character is complete. After transmitting the start bit, the serial interface transmits the number of data bits specified by the CL1 - CL0 (character length) bits of the mode register (SMR), transmits the parity bit when the mode register PE (parity enable) bit is set to 1, and transmits from the transmit output pin (TxD) the number of stop bits specified by the mode register ST (stop bit length) bit. If the transmit data register contains a next transmit character, the serial interface transmits the start bit and the next character after transmitting the stop bit of the current data frame. Once the serial interface has begun transmit, it continues transmit of the current data character even if the status of the IO13/CTS0 pin or the TxEN bit change and ends transmit with the stop bit. If the SBRK (break transmit) bit of the mode register is set to 1, the serial interface sends a break until SBRK is reset to 0 regardless of TxEN, $\overline{CTSO}$ , or whether there is a transmit currently in progress. ### 5.2.4 Data Receive The receive data input pin (RxD) is normally set to 1 (mark status). The serial interface samples the input at the GCLK generated by the baud rate generator. When it detects 0 level, it regards the 0 level as the beginning of the start bit. If the serial interface detects the 0 level three more consecutive times, it determines that the first 0 level is the beginning of a valid start bit. Then the serial interface determines the center point of subsequent receive characters, and samples the receive characters. Figure 5.6 shows how the start bit and the center point of receive characters are determined. Figure 5.6 How to Determine Start Bits and Center Point of Receive Characters If the mode register PEN (parity enable) bit is set to 1 and parity bit receive is specified, the serial interface samples the parity bit and compares the parity with that generated by the receive character. If the compared parities do not match, the serial interface sets the PE (parity error) bit of the status register to 1. For stop bits, the serial interface samples the first stop bit irrespective of the stop bit length specified by the mode register ST (stop bit length) bit. If the result is not 1, it sets the FE bit (framing error) bit in the status register to 1. The receive data bits are sampled sequentially and saved in the receive buffer. When the programmed number of data bits specified by CL1 - CL0 (character length) of the mode register have been received, the data bits are transferred from the receive buffer to the receive data register (SDR). When the character length is 5, 6 or 7, the upper bits in the receive data register (SDR) are unused. However, these bits are reset to 0 at transfer to the receive data register. The RxRDY (receive ready) bit of the status register is set to 1 when a character is transferred from the receive buffer to the receive data register (SDR). At this time, the receive data register (SDR) value can be read, even while the next character is being received. If receive of the next character completes before the receive character is read, the new character is transferred from the receive buffer to the receive data register (SDR), overwriting the previous character. With this, the previous character is lost, and the status register OE (overrun error) bit is set to 1. When two or more data frames are received where the receive characters and, if specified, the parity bit and stop bits, are all 0, the serial interface assumes a break and sets the RBRK (break detect) bit of the status register to 1. If all error bits (status register bits OE, FE, PE, and RBRK) are set to 1, these settings are retained. Setting the control register ERS (error reset) bit to 1 clears the error bits to 0. Since the error bits remain cleared while the ERS bit is set to 1, subsequent errors cannot be detected. Clearing the ERS bit to 0 sets the error bits in accordance with the status of the receive data frame. Parity errors and overrun errors do not affect receive, which continues as if no error had occurred. If a break is not detected and a framing error is generated, the serial interface continues receive as if a stop bit was actually present and detects the next start bit. If a break is detected, the start bit detection is suspended until the receive data input pin (RxD) is set once to 1. # 5.3 Interrupt Control ### 5.3.1 Interrupt Causes The serial interface supports the following four interrupt causes. a) Transmit ready interrupt At data transmit, the transmit data register can be loaded with the next transmit character. TxRDY (transmit ready) = 1 b) Receive complete interrupt At data receive, the receive character is transferred from the receive buffer to the receive data register (SDR); therefore the receive data register is ready to be read. RxRDY (receive ready) = 1 and RxEN (receive enabled) = 1 c) Error occurred interrupt A parity error (PE), overrun error (OE), or framing error (FE) is generated ``` (PE = 1, or OE or FE = 1) and RxEN = 1 ``` d) Break detected interrupt A break is detected RBRK (break detected) = 1 and RxEN = 1 ### 5.3.2 Interrupt Mask Interrupts in the entire serial interface can be masked by the control register INTM (interrupt mask) bit. Each interrupt cause can be masked by the mode register RxINTM (receive complete interrupt mask) bit, the ERINTM (error occurred interrupt mask) bit, or the TxINTM (transmit ready interrupt mask) bit. Note that break detected interrupts are masked by the RxINTM bit. Moreover, bits S2 to S0 (serial interface channel 2 to 0 interrupt mask) of the interrupt control interrupt mask register (IMT) can mask interrupts for each channel. ### **5.3.3 Interrupt Generation Conditions** The interrupt generation conditions determined by the interrupt cause and mask are as follows. Note n: Indicates the channel number n = 0, 1, 2 + : Indicates logical OR× : Indicates logical AND Channel n interrupts = $(Sn=0) \times (INTM=0) \times$ {(transmit ready interrupt) + (receive complete interrupt) + (error occurred interrupt) + (break detected interrupt)} Transmit ready interrupt = $(TxINTM=0) \times (TxRDY=1)$ Receive complete interrupt = $(RxINTM = 0) \times (RxEN = 1) \times (RxRDY = 1)$ Error occurred interrupt = $(RxEN=1)\times[(ERINTM=0)\times\{(PE=1)+(OE=1)+(FE=1)\}]$ Break detected interrupt = $(RxINTM = 0) \times (RBRK = 1)$ #### 5.3.4 Vector Number Generation TMP68301A automatically generates vector numbers in the acknowledge cycle depending on the interrupt channels and causes. For details of vector numbers, see Table 4.2 in Chapter 4 Interrupt Controller. The vector number register (IVNR) determines the upper three bits (7 to 5) of vector numbers generated in the acknowledge cycle. Bits 4 to 2 are determined by the channel number and generated by the interrupt controller. Bits 1 to 0 are determined by the interrupt cause and generated by the serial interface. (Figure 5.7) Figure 5.7 Serial Interface Vector Number Generation Method When an interrupt is sent from the serial interface to the interrupt controller, the interrupt controller holds the interrupt and generates an interrupt request to the core processor. Interrupts pending (corresponding channel bits of the interrupt controller pending register are set to 1) due to masking by bits S2 to S0 (serial interface channel 2 to 0 interrupt mask) of the interrupt mask register (IMR) are accepted after the mask is released; interrupts pending due to execution of another interrupt with a higher priority are accepted after the higher-priority interrupt is fully processed. When the interrupt is masked by the serial control register INTM bit, or the serial mode register RxINTM bit, ERINTM bit, or TxINTM bit, interrupt generation conditions are not satisfied and no interrupt request is sent to the interrupt controller. The serial interface does not retain masked interrupts. Therefore, if the interrupt cause is lost before releasing the masks of the control register INTM bit, or the mode register RxINTM bit, ERINTM bit, or TxINTM bit, the serial interface acts as if no interrupt is generated. If conditions for the interrupt are no longer satisfied, the serial interface stops outputting an interrupt request to the interrupt controller. However, the interrupt controller holds the interrupt request and therefore continues to output the interrupt request to the core processor. If the pending bit of the channel corresponding to the interrupt pending register is not cleared (interrupt cancelled) before the core processor receives the interrupt request, the serial interface generates an interrupt acknowledge. When vector numbers are generated in the interrupt acknowledge cycle, numbers 7 to 2 are generated because the interrupt controller holds the interrupt request. However, as the interrupt generation conditions are no longer satisfied, the serial interface generates a vector number indicating "interrupt cause cleared while interrupt pending" using bits 1 to 0 of the vector number used to specify the interrupt cause. Figure 5.8 shows the relationship between the interrupt control circuit in the serial interface and the interrupt controller. Figure 5.8 Relationship Between Interrupt Control Circuit and Interrupt Controller #### 5.3.5 Cautions a) Break detected interrupts are masked by the RxINTM (receive interrupt mask) bit, but create an error occurred interrupt vector in the interrupt acknowledge cycle. - b) The TxRDY bit is still held in the transmit ready interrupt acknowledge cycle. - c) The TxRDY bit is initialized by a hardware reset (the RESET and HALT pins are simultaneously asserted). Therefore, the transmit ready interrupt can be used for the first data transmit after reset. - d) When interrupt request conditions are satisfied once, an interrupt processing is generated only once. That is, even if the transmit ready interrupt processing routine ends without the transmit data being written to the transmit data register (SDR), an interrupt will not be regenerated to jump to the transmit ready interrupt processing routine. If more than one error occurs simultaneously, the routine jumps only once to the error occurred interrupt processing routine. - e) The following is the interrupt processing priority when more than one interrupt request is generated simultaneously. Error occurred interrupt High Receive complete interrupt ↓ Transmit ready interrupt Low Figure 5.9 shows an interrupt processing routine example when an error occurred interrupt and a receive complete interrupt are generated simultaneously. Note \*: When a receive error occurs, an error occurred interrupt and a receive complete interrupt are generated simultaneously. Reading the receive data register (SDR) in the error occurred interrupt processing routine resets RxRDY to 0 and prevents the receive complete interrupt generation conditions from being satisfied. Therefore, a vector number indicating "interrupt cause cleared while interrupt pending" is generated in the next interrupt acknowledge cycle. Figure 5.9 Multiple Interrupt Processing Example ### 5.4 Initialization of Serial Interface To initialize serial interface, set the RES (software reset) bit of the control register to 1. The serial interface is also initialized if a hardware reset is executed (the RESET and HALT pins are simultaneously asserted) because the RES bit is set to 1. The initialized status is held until the RES bit is reset to 0. In the initial state, transmit, receive, and interrupts are all disabled. The generation of superfluous operations can thus be avoided until the serial interface setup is complete. Table 5.1 lists the initial register values. | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------------|----------------------------------------|------|-----------|-----|------|-------------------|--------------------|--------------------| | Serial control | CKSE | | RES | | | | | INTM | | register<br>(SCR) | 1 | _ | 1 | - | - | - | - | 1 | | Serial command | | | *1<br>RTS | ERS | SBRK | R <sub>X</sub> EN | *1<br>DTR | T <sub>X</sub> EN | | register<br>(SCMR0-2) | - | _ | 0 | 1 | 0 | 0 | 0 | 0 | | Serial status | ±1<br>DSR | RBRK | FE | OE | PE | T <sub>X</sub> E | R <sub>X</sub> RDY | T <sub>X</sub> RDY | | register<br>(SSR0-2) | Depending<br>on external<br>pin status | 0 | 0 | 0 | 0 | 1 | 0 | 0 | : Undefined\*1 : channel 0 only Table 5.1 Serial Interface Register Initial Values ## 5.5 Register Description # 5.5.1 Serial Control Register (SCR) This register is used to make the serial interface basic settings. Set the registers after resetting the RES bit to 0. Note: For future expansion, set undefined bits to 0. CKSE: Divider clock select 0 : External input clock (BCLK) 1 : System clock (CLK) $RES: \quad Software \ reset$ 0 : Reset cansel 1 : Reset INTM: Interrupt mask 0 : Enable interrupt signal generation1 : Disable interrupt signal generation ### 5.5.2 Serial Mode Registers 0 - 2 (SMR0 - 2) These registers, one per channel, specify the character structure and the interrupt generation masks. RxINTM : Receive complete interrupt mask and break detect interrupt mask \*2 0: Interrupt valid1: Interrupt masked ERINTM: Error occurred interrupt mask \*2 0: Interrupt valid 1: Interrupt masked PEO: Parity select \*1 0: Even parity 1: Odd parity PEN: Parity control 0: No parity 1: Parity CL1-CL0: Character length | CL1 | CL0 | Character length | |-----|-----|------------------| | 0 | 0 | 5-bit character | | 0 | 1 | 6-bit character | | 1 | 0 | 7-bit character | | 1 | 1 | 8-bit character | TxINTM: Transmit ready interrupt mask 0: Interrupt valid 1: Interrupt masked ST: Stop bit length 0: One stop bit 1: Two stop bits \*1 : Shows parity generation; Even parity means that the number of 1's in the transmit/receive character including the parity bit is even. Odd parity means that the number of 1's in the transmit/receive character including the parity bit is odd. \*2 : ERINTM is the interrupt mask for framing errors, overrun errors, and parity errors. RxINTM is the interrupt mask for break detect. ### 5.5.3 Serial Command Registers 0 - 2 (SCMR0 - 2) These registers, one per channel, are for transmit/receive control. Note: For future expansion, set undefined bits to 0. RTS : RTS0 pin output control (channel 0 only) 0: High output from RTS0 pin 1: Low output from RTS0 pin ERS: Error reset \*2 0: No operation 1: Reset PE, OE, FE, and RBRK bits SBRK: Break transmit 0: No break transmit 1: Break transmit RxEN: Receive enable 0: Receive disable 1: Receive enable DTR: DTR pin output control (channel 0 only) \*1 $\begin{array}{ll} 0: & \text{High output from pin } \overline{DTR0} \\ 1: & \text{Low output from pin } \overline{DTR0} \end{array}$ TxEN: Transmit enable 0: Transmit disable 1: Transmit enable \*1 : As pin IO13/\overline{\text{DTR0}} multiplexes with the parallel interface I/O port, the pin is used for \overline{\text{DTR0}} output only when bit PF0 (pin function 0) of the parallel control register is set to 1. \*2 : While bit ERS is set to 1, the error bits (PE, OE, FE, RBRK) are continuously reset. Resetting ERS to 0 sets the error bits according to the status of the receive data frame. Therefore, when resuming error detection after resetting error bits, reset the ERS bit to 0 again. ### 5.5.4 Serial Status Registers 0 - 2 (SSR0 - 2) These registers, one per channel, indicate the channel status. R: Read only DSR: DSR pin input sense (channel 0 only) \*2 0: IO14/DSR0 pin input is high.1: IO14/DSR0 pin input is low. RBRK: Break detect 0: Does not detect break 1 : Detects break FE : Framing error 0: Does not generate framing error 1: Generates framing error OE: Overrun error 0: Does not generate overrun error. 1: Generates overrun error. PE: Parity error 0: Does not generate parity error. 1: Generates parity error. TxE: Transmit data empty 0: The transmit data register (SDR) contains a transmit character, or a transmit is in progress (transmit character is in transmit buffer). 1: The transmit data register (SDR) is empty and no transmit is in progress (no transmit character in transmit buffer). RxRDY : Receive ready 0: Receive not ready 1: Receive ready (the receive data register (SDR) contains a receive character, the receive data register can be read) TxRDY : Transmit ready \*1 0: Transmit not ready 1: Transmit ready (transmit character can be written to transmit data register (SDR)) \*1 : TxRDY is set to 1 when [{transmit data register empty} x (CTS=0) x (TxEN=1)]. When channels 1, and 2, and 0 do not use CTS0, CTS0 is treated as CTS0=0 without checking CTS0 pin input. CTS0 multiplexes with the parallel interface I/O port: IO13/CTS0. Thus, the pin is used for CTS0 input only when bit PF0 (pin function 0) of the parallel control register (PCR) is set to 1. \*2 : Pin IO14/DSR0 multiplexes with the parallel interface I/O port. Thus, the pin is used for DSR0 input only when PF0 of the parallel control register is set to 1. ### 5.5.5 Serial Prescaler Register (SPR) The prescaler divides the input clock (system clock or BCLK pin input) by the divider ratio specified in this register. The values to be set in this register are from 0 to 255. | Set value | Divider ratio | |-----------|----------------| | 0 | × 1/256 | | 1 | ×1 | | 2~255 | × 1/2~ × 1/255 | # 5.5.6 Baud Rate Register 0 - 2 (SBRR0 - 2) The baud rate generator further divides, by the divider ratio specified in this register, the clock (PCLK) divided by the prescaler. Each channel has a baud rate register. More than one bit cannot be set simultaneously. The clock obtained (GCLK) by dividing PCLK with the baud rate register setting is used as the serial interface transmit/receive fundamental clock. The clock actually used to shift out data bits and perform sampling (TCLK) is obtained by dividing the GCLK by eight. Table 5.2 shows the baud rate register settings and the divider ratios with the baud rate generator (GCLK/PCLK). | | | Baud | rate re | gister va | alues | | | Divider ratio | | | |----|----|------|---------|-----------|-------------|---|----|---------------|-------|--| | В7 | В6 | В5 | В4 | В3 | B3 B2 B1 B0 | | В0 | 10<br>Decimal | | | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 128 | 1/128 | | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 64 | 1/64 | | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 32 | 1/32 | | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 16 | 1/16 | | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 8 | 1/8 | | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 4 | 1/4 | | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 2 | 1/2 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | Table 5.2 Divider Ratios by Baud Rate Generator Channel n baud rate set value is defined by the following equation: $TCLKn = CLK \div PR \div BRRn \div 8$ n : Channel number $(n=0\sim2)$ TCLKn : Channel n baud rate (bps) CLK : Input clock (system clock or BCLK pin input) frequency (Hz) PR: Prescaler (SPR) set value (PR=1-256 However, PR=256 means value is 0) BRRn : Channel n baud rate register (SBRRn) set value (BRRn = 1 - 128) Table 5.3 shows baud rate setting examples. # 5.5.7 Serial Data Registers 0 - 2 (SDR0 - 2) These registers, one per channel, store transmit data and receive data. Although the transmit data register and the receive data register share the same address, the two registers are independent. The receive data register is accessed at read. The transmit data register is accessed at write. SCLK = 16.67MHz | Baud Rate<br>(bps) | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | |--------------------|---------------------------|--------------------------|---------|---------------------------|--------------------------|---------| | 38.4K | 1 (\$01) | 54 (\$36) | + 0.48% | 2 (\$02) | 27 (\$1B) | + 0.48% | | 19.2K | 1 (\$01) | 109 (\$6D) | - 0.44% | 4 (\$04) | 27 (\$1B) | + 0.48% | | 14.4K | 1 (\$01) | 145 (\$91) | - 0.20% | 16 (\$10) | 9 (\$09) | + 0.48% | | 9600 | 1 (\$01) | 217 (\$D9) | + 0.02% | 8 (\$08) | 27 (\$1B) | + 0.48% | | 4800 | 2 (\$02) | 217 (\$D9) | + 0.02% | 16 (\$10) | 27 (\$1B) | + 0.48% | | 2400 | 4 (\$04) | 217 (\$D9) | + 0.02% | 32 (\$20) | 27 (\$1B) | + 0.48% | | 1200 | 8 (\$08) | 217 (\$D9) | + 0.02% | 64 (\$40) | 27 (\$1B) | + 0.48% | | 600 | 16 (\$10) | 217 (\$D9) | + 0.02% | 128 (\$80) | 27 (\$1B) | + 0.48% | SCLK = 16.0MHz | Baud Rate<br>(bps) | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | |--------------------|---------------------------|--------------------------|---------|---------------------------|--------------------------|---------| | 38.4K | 1 (\$01) | 52 (\$34) | + 0.16% | 2 (\$02) | 26 (\$1A) | + 0.16% | | 19.2K | 1 (\$01) | 104 (\$68) | + 0.16% | 4 (\$04) | 26 (\$1A) | + 0.16% | | 14.4K | 1 (\$01) | 139 (\$8B) | - 0.08% | 4 (\$04) | 35 (\$23) | - 0.79% | | 9600 | 1 (\$01) | 208 (\$D0) | + 0.16% | 8 (\$08) | 26 (\$1A) | + 0.16% | | 4800 | 2 (\$02) | 208 (\$D0) | + 0.16% | 16 (\$10) | 26 (\$1A) | + 0.16% | | 2400 | 4 (\$04) | 208 (\$D0) | + 0.16% | 32 (\$20) | 26 (\$1A) | + 0.16% | | 1200 | 8 (\$08) | 208 (\$D0) | + 0.16% | 64 (\$40) | 26 (\$1A) | + 0.16% | | 600 | 16 (\$10) | 208 (\$D0) | + 0.16% | 128 (\$80) | 26 (\$1A) | + 0.16% | SCLK = 12.5MHz | Baud Rate<br>(bps) | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | |--------------------|---------------------------|--------------------------|---------|---------------------------|--------------------------|---------| | 38.4K | 1 (\$01) | 41 (\$29) | - 0.76% | 2 (\$02) | 20 (\$14) | + 1.73% | | 19.2K | 1 (\$01) | 81 (\$51) | + 0.47% | 4 (\$04) | 20 (\$14) | + 1.73% | | 14.4K | 1 (\$01) | 109 (\$6D) | - 0.45% | 4 (\$04) | 27 (\$1B) | + 0.47% | | 9600 | 1 (\$01) | 163 (\$A3) | - 0.15% | 8 (\$08) | 20 (\$14) | + 1.73% | | 4800 | 2 (\$02) | 163 (\$A3) | - 0.15% | 16 (\$10) | 20 (\$14) | + 1.73% | | 2400 | 4 (\$04) | 163 (\$A3) | - 0.15% | 32 (\$20) | 20 (\$14) | + 1.73% | | 1200 | 8 (\$08) | 163 (\$A3) | - 0.15% | 64 (\$40) | 20 (\$14) | + 1.73% | | 600 | 16 (\$10) | 163 (\$A3) | - 0.15% | 128 (\$80) | 20 (\$14) | + 1.73% | Figure 5.3 Baud Rate Setting Examples (1) SCLK = 8.0MHz | Baud Rate<br>(bps) | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | |--------------------|---------------------------|--------------------------|---------|---------------------------|--------------------------|---------| | 38.4K | 1 (\$01) | 26 (\$1A) | + 0.16% | 2 (\$02) | 13 (\$0D) | + 0.16% | | 19.2K | 1 (\$01) | 52 (\$34) | + 0.16% | 4 (\$04) | 13 (\$0D) | + 0.16% | | 14.4K | 1 (\$01) | 69 (\$45) | + 0.64% | 4 (\$04) | 17 (\$11) | + 2.12% | | 9600 | 1 (\$01) | 104 (\$68) | + 0.16% | 8 (\$08) | 13 (\$0D) | + 0.16% | | 4800 | 2 (\$02) | 104 (\$68) | + 0.16% | 16 (\$10) | 13 (\$0D) | + 0.16% | | 2400 | 4 (\$04) | 104 (\$68) | + 0.16% | 32 (\$20) | 13 (\$0D) | + 0.16% | | 1200 | 8 (\$08) | 104 (\$68) | + 0.16% | 64 (\$40) | 13 (\$0D) | + 0.16% | | 600 | 16 (\$10) | 104 (\$68) | + 0.16% | 128 (\$80) | 13 (\$0D) | + 0.16% | # SCLK = 7.3728MHz | Baud Rate<br>(bps) | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | |--------------------|---------------------------|--------------------------|-------|---------------------------|--------------------------|-------| | 38.4K | 1 (\$01) | 24 (\$18) | 0% | 2 (\$02) | 12 (\$0C) | 0% | | 19.2K | 1 (\$01) | 48 (\$30) | 0% | 4 (\$04) | 12 (\$0C) | 0% | | 14.4K | 1 (\$01) | 64 (\$40) | 0% | 4 (\$04) | 16 (\$10) | 0% | | 9600 | 1 (\$01) | 96 (\$60) | 0% | 8 (\$08) | 12 (\$0C) | 0% | | 4800 | 1 (\$01) | 192 (\$C0) | 0% | 16 (\$10) | 12 (\$0C) | 0% | | 2400 | 2 (\$02) | 192 (\$C0) | 0% | 32 (\$20) | 12 (\$0C) | 0% | | 1200 | 4 (\$04) | 192 (\$C0) | 0% | 64 (\$40) | 12 (\$0C) | 0% | | 600 | 8 (\$08) | 192 (\$C0) | 0% | 128 (\$80) | 12 (\$0C) | 0% | SCLK = 1.8432MHz | Baud Rate<br>(bps) | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | BRR<br>( )<br>Hexadecimal | PR<br>( )<br>Hexadecimal | Error | |--------------------|---------------------------|--------------------------|-------|---------------------------|--------------------------|-------| | 38.4K | 1 (\$01) | 6 (\$06) | 0% | 2 (\$02) | 3 (\$03) | 0% | | 19.2K | 1 (\$01) | 12 (\$0C) | 0% | 4 (\$04) | 3 (\$03) | 0% | | 14.4K | 1 (\$01) | 16 (\$10) | 0% | 4 (\$04) | 4 (\$04) | 0% | | 9600 | 1 (\$01) | 24 (\$18) | 0% | 8 (\$08) | 3 (\$03) | 0% | | 4800 | 1 (\$01) | 48 (\$30) | 0% | 16 (\$10) | 3 (\$03) | 0% | | 2400 | 1 (\$01) | 96 (\$60) | 0% | 32 (\$20) | 3 (\$03) | 0% | | 1200 | 1 (\$01) | 192 (\$C0) | 0% | 64 (\$40) | 3 (\$03) | 0% | | 600 | 2 (\$01) | 192 (\$C0) | 0% | 128 (\$80) | 3 (\$03) | 0% | Figure 5.3 Baud Rate Setting Examples (2) # 6. Parallel Interface #### 6.1 Outline This parallel interface uses a general-purpose, 16-bit I/O port where input or output can be specified for each bit. Switching modes changes the interface to Centronics. With the Centronics interface, the 16-bit data bus becomes an 8-bit data bus with up to five control signal lines. At Centronics transmit, when the parallel interface receives 8-bit data from the MPU, the parallel interface generates an external data strobe at a period previously programmed in an internal register. At Centronics receive, 8-bit data are stored internally at the external data strobe, and the parallel interface returns a BUSY signal. The parallel interface generates three interrupts at Centronics transmit/receive. ## 6.2 Operating Mode The parallel interface has three operating modes. Use the internal control register to select one of these modes. Each mode can select one of several pin functions. Some modes can use some of the parallel interface I/O port pins as a serial interface or as a Centronics response control signal. Mode 0 16-bit bus (input/output operation) Mode 1 8-bit bus (output operation) + control signal (Centronics output) Mode 2 8-bit bus (input operation) + control signal (Centronics input) ## 6.2.1 Control Signal Automatic Generation Function The parallel interface can generate signals at any timing when DSTB and ACK Centronics control signals are programmed in the register. Two internal flags, XBUSY and BUFFER-FULL, are provided for the parallel interface. Thus, the parallel interface can communicate with external devices of any operating speed. ### 6.2.2 Interrupts The parallel interface generates the following three interrupts. At transmit ready (in mode 1) At receive complete (in mode 2) $At \ external \ device \ status \ change \qquad \quad (in \ mode \ 1: \ at \ FAULT \ input \ change)$ ### 6.2.3 Mode 0 Operation In mode 0, the port operates as a 16-bit I/O port. Each parallel interface bit can be specified as either input or output using the direction register. The input pins pass data received from an external source through the internal buffer and set them in the data register. The output pins pass data from the data register through the internal buffer and output them to external devices. ### 6.2.4 Mode 1 Operation Mode 1 operates as the Centronics output. When the parallel interface receives data from the core processor, it stores the data in the internal buffer and simultaneously generates $\overline{DSTB}$ at the timing specified in parameter registers 1 and 2. The interface then receives a negated BUSY signal returned by the external device, and generates an interrupt. To compensate for the delay of the external BUSY signal, an internal XBUSY flag is provided. When data are stored in the internal buffer, the XBUSY flag is set. When an external $\overline{ACK}$ signal is received, the flag is reset. The mode register selects the timing of the interrupt generation from either the external BUSY signal falling edge, or the clearance of the internal XBUSY flag. When PRIME and FAULT functions are added to the pins, PRIME is assigned to an output pin; FAULT, to an input pin. They are used for the printer initialization signal and the printer abnormality detection signal, respectively. Figure 6.2 Centronics Output Timing ### 6.2.5 Mode 2 Operation Mode 2 operates as the Centronics input. When the parallel interface receives a data strobe from an external source, it stores the data in the internal buffer and simultaneously generates an interrupt and an external BUSY signal. Then, with a read or dummy write from the core processor, the parallel interface returns an $\overline{ACK}$ signal externally with the timing specified in parameter registers 1 and 2. To show that data have been received, an internal BUFFER-FULL flag is provided. When data are stored in the internal buffer, this flag is set. The BUFFER-FULL flag is reset when an external $\overline{ACK}$ signal is generated. The $\overline{ACK}$ signal ready timing can be included in the BUSY signal ready timing by setting the mode register. When PRIME and FAULT functions are added to the pins, PRIME is assigned to an input pin; FAULT, to an output pin. Note: Reading the lower byte of the parallel data register when not receiving data generates a receive interrupt. Therefore, access the data register only after receive. Accessing the upper byte only does not generate an interrupt. \*1:1CLK~128CLK Figure 6.3 Centronics Input Timing # 6.3 Register Configuration # 6.3.1 Parallel Direction Register This register programs each bit of the 16-bit port for input or output. 1 specifies output; 0, input. # 6.3.2 Parallel Control Register This register selects operating modes and pin functions. M0 and M1 specify operating modes. PF0 and PF1 specify pin functions. The following diagram shows the relationship between operating modes and pin functions. R : Read only | Mod<br>(M0 = 0, | | | Mod<br>(M0 = 1, | | | Mode 2<br>(M0 = X, M1 = 1) | | | | | | | | | | |-----------------|---------|---------|-----------------|---------|-----------------|----------------------------|---------|---------|---------|--|--|--|--|--|--| | PF1 | = X | PF1 | = 0 | PF1 | = 1 | PF1 | = 0 | PF1 = 1 | | | | | | | | | PF0 = 0 | PF0 = 1 | PF0 = 0 | PF0 = 1 | PF0 = 0 | PF0 = 0 PF0 = 1 | | PF0 = 1 | PF0 = 0 | PF0 = 1 | | | | | | | | 1/0 0 | I/O 0 | DATA1 | | | | | | | I/O 1 | I/O 1 | DATA2 | | | | | | | I/O 2 | I/O 2 | DATA3 | | | | | | | I/O 3 | I/O 3 | DATA4 | | | | | | | 1/0 4 | I/O 4 | DATA5 | | | | | | | I/O 5 | I/O 5 | DATA6 | | | | | | | 1/0 6 | 1/0 6 | DATA7 | | | | | | | 1/07 | 1/0 7 | DATA8 | | | | | | | 1/08 | 1/08 | DSTB | | | | | | | 1/0 9 | I/O 9 | BUSY | | | | | | | I/O 10 | I/O 10 | ACK | | | | | | | I/O 11 | I/O 11 | 1/0 11 | I/O 11 | PRIME | PRIME | I/O 11 | 1/0 11 | PRIME | PRIME | | | | | | | | I/O 12 | I/O 12 | I/O 12 | I/O 12 | FAULT | FAULT | I/O 12 | I/O 12 | FAULT | FAULT | | | | | | | | I/O 13 | CTS0 | I/O 13 | CTS0 | I/O 13 | CTS0 | I/O 13 | CTS0 | I/O 13 | CTS0 | | | | | | | | I/O 14 | DSR0 | I/O 14 | DSR0 | I/O 14 | DSR0 | I/O 14 | DSR0 | I/O 14 | DSR0 | | | | | | | | I/O 15 | DTR0 | I/O 15 | DTR0 | I/O 15 | DTR0 | I/O 15 | DTR0 | I/O 15 | DTR0 | | | | | | | # 6.3.3 Parallel Status Register This register stores the control signals used in mode 1 and 2 Centronics operation. Note that S0, S1, S4, and S5 are valid only when PF1 of the control register is set to 1. S0 to S3 store the control signals for mode 1; S4 to S6, the control signals for mode 2. When an interrupt is generated in mode 1 or 2, the interrupt flag (IF) is set to 1. If becomes into 0 after the interrupt acknowledge cycle. The IF remains set to 1 until a reset is input. All bits of the register can be read, but only the IF bit can be written. (However, 0 cannot be set before the interrupt acknowledge cycle.) IF: Interrupt flag (for modes 1 and 2 only) 0 : No interrupt1 : Interrupt S6: BUFFER - FULL flag (for mode 2 only) 0 : Buffer empty1 : Buffer full S5: PRIME input status (in mode 2 only) S4: FAULT output status (in mode 2 only) S3: XBUSY flag (in mode 1 only) S2: BUSY input status (in mode 1 only) S1: PRIME output status (in mode 1 only) S0: FAULT input status (in mode 1 only) ### 6.3.4 Parallel Command Register The parallel command register sets the status of the output pins in modes 1 and 2, and enables or enables/disables each of the three interrupts. The parallel interface ignores and does not retain an interrupt request when the requested interrupt is disabled. To postpone an interrupt, use the mask register in the interrupt controller. C0, IM1, and IM2 are valid in mode 1. C1 and IM3 are valid in mode 2. However, C0, C1, and IM2 are valid only when PF1 of the control register is set to 1. IM3: Receive complete interrupt mask flag (valid only in mode 2) 0: Enables receive complete interrupt. 1: Masks receive complete interrupt. IM2: External device status change interrupt mask flag (valid only in mode 1) 0: Enables external device status change interrupt. 1: Masks external device status change interrupt. IM1: Transmit ready interrupt mask flag (valid only in mode 1) 0: Enables transmit ready interrupt. 1: Masks transmit ready interrupt. C1: FAULT output control (valid only in mode 2) 0: Sets FAULT output level to 0. 1: Sets FAULT output level to 1. C0: PRIME output control (valid only in mode 1) 0: Set PRIME output level to 0. 1: Set PRIME output level to 1. Note 1: The PRIME output level changes when data are written to the parallel data register. (Figure 6.2) ### 6.3.5 Parallel Mode Register This register defines the relationship between the BUSY signal and the interrupt, and the relationship between the BUSY signal and the $\overline{ACK}$ signal. In mode 1, PM0 is valid. In mode 2, PM1, PM2, and PM3 are valid. PM3: DSTB edge definition 0: Loads data at DSTB rising edge. 1: Loads data at DSTB falling edge. PM2: ACK generation control 0: A dummy write resets BUSY and generates the $\overline{ACK}$ signal. (Using this option, assertion of ACK can be delayed by software control.) 1: A read resets BUSY and generates the ACK signal. PM1: BUSY signal definition 0: ACK not included in BUSY signal. 1: ACK included in BUSY signal. PM0: Transfer interrupt definition 0: Generates a transfer ready interrupt when XBUSY flag is cleared. 1: Generates a transfer ready interrupt at the falling edge of the external BUSY signal. #### 6.3.6 Parallel Data Register This register reads or writes data input/output from the I/O ports. When a port is in input mode or during Centronics receive, data from an external source received by the receive buffer are immediately passed to this register. Note that any data written to this register at this time are ignored. When a port is in output mode or during Centronics transmit, data written to the corresponding bit in this register are output externally. If the register is read then, the data currently output to the port will be read. ## 6.3.7 Parallel Parameter Register 1 This register programs the delay time required for the Centronics interface to automatically generate $\overline{DSTB}$ and $\overline{ACK}$ control signals. The register setting automatically generates the $\overline{DSTB}$ and $\overline{ACK}$ delay time. The register indicates the number of $\overline{DSTB}$ delay clocks in mode 1, and the number of $\overline{ACK}$ delay clocks in mode 2. The equation for calculating the delay time is as follows. Delay = DT6 $$\times$$ 64 + DT5 $\times$ 32 + DT4 $\times$ 16 + DT3 $\times$ 8 + DT2 $\times$ 4 + DT1 $\times$ 2 + DT0 # 6.3.8 Parallel Parameter Register 2 This register programs the delay time required for the Centronics interface to automatically generate $\overline{DSTB}$ and $\overline{ACK}$ control signals. The register setting automatically generates the $\overline{DSTB}$ and $\overline{ACK}$ signal width. The register specifies the width of $\overline{DSTB}$ in clocks in mode 1, and the width of $\overline{ACK}$ in clocks in mode 2. The equation for calculating the width is as follows. This register is used together with parallel parameter register 1. Width = DW6 $\times$ 64 + DW5 $\times$ 32 + DW4 $\times$ 16 + DW3 $\times$ 8 + DW2 $\times$ 4 + DW1 $\times$ 2 + DW0 # 7. Timer ### 7.1 Outline The timer consists of three independent channels, each with a 16-bit counter. Each channel has an 8-bit prescaler (valid only when the system clock is used). Each channel generates interrupt requests. The timer can cascade-connect the three channels for long counts. Three independent channels each with a built-in 16-bit counter Count data are readable Generates interrupts for each channel Software/hardware trigger Programmable operating modes Outputs any duty comparison waveform (channels 1 and 2 only) Outputs one-shot pulse (channels 1 and 2 only) Event count Max. 8MHz count (at 16 MHz) Figures 7.1 and 7.2 show the timer outline. Figure 7.1 Timer Channel 0 Outline Figure 7.2 Timer Channel 1 Outline ### 7.2 Operational Description Each channel internal counter is a 16-bit upcounter. Immediately the count value set in the 16-bit counter reaches the value set in the MAX count register, the channel generates a count match signal that clears the count value. The channel can generate an interrupt request signal within the channel. ## 7.2.1 Channel 0 Channel 0 has three registers: a (16-bit) control register, a (16-bit) count register, and a (16-bit) MAX count register. The internal counter is a 16-bit upcounter. Immediately the count value set in the 16-bit counter reaches the value set in the MAX count register, the channel generates a count match signal that clears the count value. The channel can generate an interrupt request signal within the channel. This channel can receive external clocks or external signals from external input pins (shared by channels 1 and 2), and can count up external events. #### 7.2.2 Channels 1 and 2 Channels 1 and 2 have four registers: MAX count register 1 and 2, a control register, and a count register. The internal counter is a 16-bit upcounter. Immediately the count value set in the 16-bit counter reaches the value set in the MAX count register, the channel generates a count match signal that clears the count value. The channel can generate an interrupt request signal within the channel. These channels have external input pins (shared by channel 0) and external output pins, and can count up external events and output any waveform. # 7.2.3 Setting and Modifying Maximum Counts, Reading and Initializing Counts The value written in the MAX count register specifies the maximum count. Changing the MAX count register sets and modifies the maximum count. (The register can be rewritten during operation.) The count value can be read from the count register during a count. While the count register is normally used for reading only, the register can be used to initialize the timer to \$0000 by writing any value to it. (channel 1, 2 only) #### 7.3 8-Bit Prescaler The 8-bit prescaler divides the system clock by 2, 4, 8, 16, 32, 64, 128, or 256 to obtain a count clock. Use the control register to set the divider ratio. ## 7.4 Interrupt Generation The control register controls interrupt generation mode. The timer ignores and does not store the count match signal during modes in which interrupt request signals are not generated. Therefore, even though modes are switched, an interrupt is not generated. Interrupt generation timing: an interrupt request signal is generated when a count match signal is generated. # 7.5 Register Reading/Writing Reading a register during a count operation does not affect the count operation or timer output signal or interrupts. Note the following when writing to a register during a count operation. When the timer count a clock obtained by dividing the system clock by 2 using the 8-bit prescaler is used for timer count, or when a TIN input clock half the frequency of the system clock is used for timer count, the count match signal may not be generated and the counter value may reach \$FFFF if the register write signal and the count match signal (timer count value and MAX count register value comparison match signal) are generated simultaneously in the same channel. These conditions occur when a match signal and write signal occur simultaneously in the same channel. For example, the above situation occurs when to a channel 0-related register is written to at the same time as a channel 0 match signal is generated. However, this situation does not occur when to a channel 1 register is written to at the same time a channel 0 match signal is generated. To avoid this occurring, set the 8-bit prescaler divider ratio to 4 or higher. When using the TIN input clock, set the clock to 1/4 the system clock frequency or lower. When using a clock obtained by dividing the system clock by two, increase the interrupt priority level by program so that data are written to the register immediately after the count match signal is generated rather than at the time of the next match signal generation. # 7.6 Timer Operating Mode #### 7.6.1 TIN Pin Function The external input pin (TIN) can be used for inputting the external clock, and trigger and control signals. Signals input from TIN are all sampled at the rising edge of the system clock. Clocks and pulses input from TIN must have a pulse width of one system clock cycle or more. Figure 7.3 TIN Timing ### 7.6.1.1 External Clock The external clock (TIN) can be used as the count clock. ## 7.6.1.2 Count Control Signal Count control functions include the count start function and count wait function. These are selected by the count control register. Count start function: This function inputs a trigger signal from the external input pin (TIN). The count starts when the trigger signal is set to low (falling edge). (Any input after the second input is ignored.) Figure 7.4 Count Start Function # 7.7 Register Configuration # 7.7.1 Timer Count Registers The count values are read from these registers (TCTR1, TCTR2, and TCTR3). Only the upper byte or the lower byte can be read, too. While the timer count registers are normally read-only, writing any value to TCTR1 and TCTR2 initializes them to \$0000. Writing any value to TCTR0 does not initialize it. Writing any value to TCTR0, TCTR1 and TCTR2 sets the timer control register CS bit to 1 and the TS bit to 0, clears the counter, and sets the count operation to the wait state. | Offset | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | |------------------|--------|--------|--------|--------|--------|--------|--------|--------|------------|--------|------------|--------|------------|--------|--------|--------|-------------| | address<br>\$20C | C15 | C14 | C13 | C12 | C11 | C10 | C9 | C8 | <b>C</b> 7 | C6 | <b>C</b> 5 | C4 | <b>C</b> 3 | C2 | C1 | 9 | TCTR0 | | Reset | 0<br>R | | , | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | • | | \$22C | C15 | C14 | C13 | C12 | C11 | C10 | С9 | C8 | <b>C</b> 7 | C6 | <b>C</b> 5 | C4 | C3 | C2 | C1 | C0 | TCTR1 | | , | 0<br>R • | | i | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | \$24C | C15 | C14 | C13 | C12 | C11 | C10 | C9 | C8 | <b>C</b> 7 | C6 | <b>C</b> 5 | C4 | C3 | C2 | C1 | C0 | TCTR2 | | ' | 0<br>R 1 | | | | | | | | | | | | | | | | | | R | · Read only | R: Read only # 7.7.2 MAX Count Registers The value written to the MAX count registers specifies the maximum count. | Offset address | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----------------| | \$204 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR01<br>MAX1 | | Reset | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | For ch0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | \$224 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR11<br>MAX1 | | | _ | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | For ch1 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | | \$244 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR21<br>MAX1 | | | _ | - | - | - | - | - | - | - | - | - | - | - | - | - | - | _ | For ch2 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | | \$228 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR12<br>MAX2 | | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | For ch1 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | - | | \$248 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR22<br>MAX2 | | | - | - | - | _ | - | - | - | - | - | - | - | - | - | - | - | _ | For ch2 | # 7.7 Register Configuration # 7.7.1 Timer Count Registers The count values are read from these registers (TCTR1, TCTR2, and TCTR3). Only the upper byte or the lower byte can be read, too. While the timer count registers are normally read-only, writing any value to TCTR1 and TCTR2 initializes them to \$0000. Writing any value to TCTR0 does not initialize it. Writing any value to TCTR0, TCTR1 and TCTR2 sets the timer control register CS bit to 1 and the TS bit to 0, clears the counter, and sets the count operation to the wait state. | Offset | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | |------------------|--------|--------|--------|--------|--------|--------|--------|--------|------------|--------|------------|--------|------------|--------|--------|--------|-------------| | address<br>\$20C | C15 | C14 | C13 | C12 | C11 | C10 | C9 | | <b>C</b> 7 | C6 | <b>C</b> 5 | C4 | <b>C</b> 3 | C2 | C1 | 9 | TCTR0 | | Reset | 0<br>R | | , | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | • | | \$22C | C15 | C14 | C13 | C12 | C11 | C10 | С9 | C8 | <b>C</b> 7 | C6 | <b>C</b> 5 | C4 | C3 | C2 | C1 | C0 | TCTR1 | | , | 0<br>R • | | i | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | \$24C | C15 | C14 | C13 | C12 | C11 | C10 | C9 | C8 | <b>C</b> 7 | C6 | <b>C</b> 5 | C4 | C3 | C2 | C1 | C0 | TCTR2 | | ' | 0<br>R 1 | | | | | | | | | | | | | | | | | | R | · Read only | R: Read only # 7.7.2 MAX Count Registers The value written to the MAX count registers specifies the maximum count. | Offset address | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----------------| | \$204 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR01<br>MAX1 | | Reset | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | For ch0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | \$224 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR11<br>MAX1 | | | _ | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | For ch1 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | | \$244 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR21<br>MAX1 | | | _ | - | - | - | - | - | - | - | - | - | - | - | - | - | - | _ | For ch2 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | | \$228 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR12<br>MAX2 | | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | For ch1 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | - | | \$248 | M15 | M14 | M13 | M12 | M11 | M10 | М9 | M8 | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | TMCR22<br>MAX2 | | | - | - | - | _ | - | - | - | - | - | - | - | - | - | - | - | _ | For ch2 | # 7.7.3 Timer Control Registers The control registers control the count operation. The registers consist of the following bits. CK2, CK1 : Set the input clock for the counter. | CK2 | CK1 | Input clock | | | | | | | | |-----|-----|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 0 | 0 | System clock (CLK) | | | | | | | | | 0 | 1 | External clock (TIN pin) | | | | | | | | | 1 | 0 | For cascade connection Channel 0 : Channel 1 counter output Channel 1 : Channel 0 counter output Channel 2 : Channel 0 counter output | | | | | | | | | 1 | 1 | For cascade connection Channel 0 : Channel 2 counter output Channel 1 : Channel 2 counter output Channel 2 : Channel 1 counter output | | | | | | | | Note: Other timer outputs 1 and 2 are for cascade connection. P4, P3, P2, P1: Set prescaler divider ratio. Valid only when the system clock (CLK) is used as the input clock. (Not required if other input clock is used.) | P4 | P3 | P2 | P1 | Divider Ratio | |----|----|----|----|---------------| | 0 | 0 | 0 | 1 | 1/2 | | 0 | 0 | 1 | 0 | 1/4 | | 0 | 0 | 1 | 1 | 1/8 | | 0 | 1 | 0 | 0 | 1/16 | | 0 | 1 | 0 | 1 | 1/32 | | 0 | 1 | 1 | 0 | 1/64 | | 0 | 1 | 1 | 1 | 1/128 | | 1 | Х | Х | Х | 1/256 | X: Any value T2, T1: Count mode selection | T2 | T1 | Function select | |----|----|----------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | When an external clock is used or when count control is not used | | 1 | 0 | Uses the count start function. (When repeatedly using this function, first change the setting to another value then return to this setting.) | | 1 | 1 | Uses the count wait function. | N/1 : Repeat specification 0: Ends count operation after one cycle. (One shot) When the MAX count value is reached, the CS bit is set to 1 and the TS bit to 0, ending the count operation. 1: Repeats count operation. (Repeat) R/P : Output signal control (channels 1 and 2 only) 0: Generates a pulse as the output signal. (pulse) 1: Inverts the output level. (level inversion) MR2, MR1 : MAX count register setting | MR2 | MR1 | MAX count register select | |-----|-----|---------------------------| | 0 | 1 | MAX1 | | 1 | 0 | MAX2 | | 1 | 1 | MAX1 and MAX2 alternately | INT : Interrupt request bit 0: No interrupt request 1: Interrupt request signal CS: Count clock input control 0: Inputs count clock to counter. (Starts count operation.) 1: Does not input count clock to counter. (Stops count operation.) TS: Timer operation setting 0: Clears counter. 1: Releases clear state. Note: As channel 0 does not have a waveform output function, the channel 0 control register has no functions based on R/P, MR2, or MR1. #### **Count Wait Function** This function inputs the control signal from the external input pin (TIN). The count is performed while the control signal is low. When the control signal is high, the count is stopped. When the control signal goes low again, the count resumes. (If the counter is not cleared, the count continues from the previous value.) Figure 7.5 Count Wait Function #### 7.6.2 Count Clock Selection The maximum count frequency is 8MHz. Therefore, use an external clock of 8MHz or less. As the prescaler divides the frequency by two or more, the maximum frequency is never exceeded when the system clock is used. The count clock can be either the system clock, an external clock, or the output of another counter. Select the count clock when the counter is stopped. ### 7.6.3 TOUT Pin Function The external output pin (TOUT) is used to output a pulse or square wave. The device can be set to either generate a pulse or invert the output level at a count match. By using two MAX counter registers, any square wave can be generated. The signals output from TOUT (pulse generation or output level inversion timing) are synchronized with the rising edge of the system clock. If a pulse is generated, the pin, which is normally low, goes high for the duration of one clock at a count match. TOUT is low after a reset. Figure 7.4 TOUT Timing ### 7.6.4 MAX Count Register Setting Each channel has two MAX registers (henceforth, MAX1 and MAX2). Either register can be used individually or both registers can be used alternately. Control register settings specify how the MAX count registers are used. ### 7.8 TOUT Initialization Function With TMP68301A, use of timer output state or MAX count register is initialized by software. Initialize by writing any value to the timer count register. (Writing any value has no effect other than initialization.) After initialization, the timer output is low and operation is set to start from MAX count register 1. Channels 1 and 2 can be initialized separately. When the count operation is temporarily stopped (by setting the CS bit of the timer count register to 1) then restarted (by setting the CS bit to 0), TMP68301A stores the TOUT state and the MAX count register being used. Therefore, counting restarts from the stopped state. (Operation example 1) When the TMP68301A initialization function temporarily stops the count operation and performs initialization, the function sets TOUT to low and selects MAX count register 1 as the initial state, as shown in operation example 2. # 8. <u>Internal Peripheral Circuit Register Map</u> # 8.1 Register map (1) #### Address decoder | Offset<br>address | 158 | 7 ( | Offset<br>address | |-------------------|-------|-------|-------------------| | \$000 | AMAR0 | AAMR0 | \$001 | | \$002 | | AACR0 | \$003 | | \$004 | AMAR1 | AAMR1 | \$005 | | \$006 | | AACR1 | \$007 | | \$008 | | AACR2 | \$009 | | \$00A | | ATOR | \$00B | | \$00C | AR | \$00D | | | \$00E | | | \$00F | | | | | _ | ### O Interrupt controller ### O Parallel interface # 8.2 Register map (2) O Address Decoder | Symbol | Name | Offset<br>address | Data bu | | | 5 - 8 (evei<br>' - 0 (odd | | | | | |-----------------------------------------|----------------------------|-------------------|---------|------|------|---------------------------|------|------|--------|-----| | | | | 15/7 | 14/6 | 13/5 | 12/4 | 11/3 | 10/2 | 9/1 | 8/0 | | AMAR0 | Memory Address | \$000 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | | AIVIANU | Register 0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | For CS0 | | | | | R/ | w | | | | | AAMR0 | Address Mask | \$001 | M21 | M20 | M19 | M18 | M17 | M16 | M15-M9 | M8 | | , , , , , , , , , | Register 0 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | For CS0 | | | | | R/ | W | | | | | AACR0 | Area Control<br>Register 0 | \$003 | | | EN | ED | l ID | | WAIT | | | | Register 0 | | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | | | For CS0 | | | R | | | R/ | W | | | | AMAR1 | Memory Address | \$004 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | | ,, | Register 1 | | _ | _ | - | _ | - | - | - | - | | | For CS1 | | | R/W | | | | | | | | AAMR1 | Address Mask<br>Register 1 | \$005 | M21 | M20 | M19 | M18 | M17 | M16 | M15-M9 | M8 | | , , , , , , , , , , , , , , , , , , , , | | | _ | - | - | - | - | - | - | - | | | For CS1 | | | | | R/ | W | | | | | AACR1 | Area Control | \$007 | | | EN | ED | l ID | | WAIT | | | , contraction | Register 1 | | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | | For CS1 | | | R | | | R/ | W | | | | AACR2 | Area Control | \$009 | | | • | ED | , ID | | WAIT | | | AACRZ | Register 2 | | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | | For IACK cycle | | | R | | | | R/W | | | | ATOR | Time Out | \$00B | | | | • | 256 | 128 | 64 | 32 | | ATOR | Register | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | | For BERR generation | | | | ₹ | • | | F | z/W | | | ARELR | Relocaton | \$00C | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | | ANLLIN | Register | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | R/ | W | | | | | | | \$00D | A15 | A14 | A13 | A12 | A11 | A10 | | | | | | | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | | For internal registers | | | | R/ | w | | | R | | ### O Interrupt controller (1) | Symbol | Name | Offset<br>address | Data bus Upper bytes: 15 - 8 (even-numbered addresses) Lower bytes: 7 - 0 (odd-numbered addresses) | | | | | | | | |--------|---------------------------------|-------------------|-----------------------------------------------------------------------------------------------------|------|------|------|------|------|-------|---------| | | | | 15/7 | 14/6 | 13/5 | 12/4 | 11/3 | 10/2 | 9/1 | 8/0 | | ICR0 | Interrupt Control<br>Register 0 | \$081 | | | V | R/F | L/E | | Level | | | | For external interrupt | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | (INTO) | | | R | | | R/ | w | | | | ICR1 | Interrupt Control | \$083 | | | V | R/F | L/E | | Level | | | | Register 1 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | For external interrupt (INT1) | | | R | | | R/ | W | | | | ICR2 | Interrupt Control | \$085 | | | V | R/F | L/E | | Level | | | TCIVE | Register 2 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | For external interrupt (INT2) | | | R | | | R/ | W | | | | ICR3 | Interrupt Control | \$087 | | | | | | | Level | | | ICKS | Register 3 For serial ch0 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | (INT3) | | | | R | | | | R/W | | | ICR4 | Interrupt Control | \$089 | | | | | | | Level | | | | Register 4 For serial ch1 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | (INT4) | | | | R | | | | R/W | | | ICR5 | Interrupt Control<br>Register 5 | \$08B | | | | | | | Level | | | | For timer ch2 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | (INT5) | | | | R | | | | R/W | | | ICR6 | Interrupt Control | \$08D | | | | | | | Level | | | Teno | Register 6 For parallel | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | (INT6) | | | | R | | | | R/W | | | ICR7 | Interrupt Control | \$08F | | | | | | | Level | | | ICK/ | Register 7 For timer ch0 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | (INT7) | | | | R | | | | R/W | | | ICR8 | Interrupt Control | \$091 | | | | | | | Level | | | icito | Register 8 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | For timer ch1<br>(INT8) | | | | R | | | | R/W | | | ICR9 | Interrupt Control | \$093 | | | | | | | Level | | | ICNS | Register 9 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | For timer ch2<br>(INT9) | | | • | R | • | • | : | R/W | <u></u> | ### 9. <u>Electrical Characteristics</u> This section describes the electrical characteristics and timings of TMP68301. ### 9.1 Maximum Ratings | Parameter | Symbol | Rating | Unit | |------------------------|--------|----------------|-------| | rarameter symbol | | TMP68301A | Offic | | Power supply voltage | Vcc | - 0.3 to + 6.5 | ٧ | | Input voltage | Vin | -0.3 to +6.5 | ٧ | | Operating temperature | Та | 0 to +70 | °C | | Storage<br>temperature | Tstg | – 55 to + 150 | °C | While this device includes input protection circuits against high-voltage static electricity or damage from electric fields, avoid using a voltage higher than the maximum rating. Connect input pins not in use to GND or VCC. ### 9.2 DC Characteristics (GND = 0 V, Ta = 0 to 70 °C) | Par | rameter | Symbol | V <sub>CC</sub> = 5.0 | ) V + 5 % | Unit | |--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------|--------------------------|------| | | | | Min | Max | 0 | | Supply voltage | | V <sub>CC</sub> | 4.75 | 5.25 | ٧ | | High-level input voltage | Except CLK<br>CLK | V <sub>IH</sub> | 2.0<br>2.2 | V <sub>CC</sub> | ٧ | | Low-level input voltage | Except CLK<br>CLK | V <sub>IL</sub> | GND-0.3<br>GND-0.3 | 0.8<br>0.6 | > | | Input leakage current<br>(5.25 V) | BERR, BGACK, BR,<br>DTACK, CLK, HALT, RESET,<br>NOR / EMU, TIN,<br>INT0 to INT2, RxD0 to RxD2 | I <sub>IN</sub> | -<br>-<br>- | 2.5<br>2.5<br>20 | μΑ | | Tri-state (off state)<br>input current | (2.4 V/0.4 V)<br>AS, A1 to A23, D0 to D15,<br>FC0 to FC2, LDS, UDS,<br>R / W, IO0 to IO15 | I <sub>TSI</sub> | -<br>-<br>- | 20<br>20<br>20 | μΑ | | High-level output voltage<br>(IOH = − 400 μA) | AS, A1 to A23, D0 to D15, BG, FC0 to FC2, LDS, UDS, R/W, IO0 to IO15, TOUT1, TOUT2, CS0, CS1, RTS0, INT0 to INT2, TxD0 to TxD2 | V <sub>OH</sub> | –<br>V <sub>CC</sub> -0.75<br>V <sub>CC</sub> -0.75<br>V <sub>CC</sub> -0.75<br>V <sub>CC</sub> -0.75 | -<br>-<br>-<br>- | V | | Low-level output voltage<br>(IOL = 1.6 mA)<br>(IOL = 3.2 mA)<br>(IOL = 1.6 mA)<br>(IOL = 5.3 mA) | $ \begin{tabular}{ll} \hline HALT \\ A1 to A23, $\overline{BG}$, FC0 to FC2 \\ \hline $RESET$ \\ \hline $AS$, D0 to D15, $\overline{LDS}$, $\overline{UDS}$, $R/\overline{W}$, $IO0 to IO15, $TOUT1$, $TOUT2$, $CS0$, $CS1$, $\overline{RTS0}$, $\overline{DTACK}$, $BERR$, $INT0 to INT2$, $TxD0$ to $TxD2$. $ | V <sub>OL</sub> | -<br>-<br>-<br>- | 0.5<br>0.5<br>0.5<br>0.5 | V | | Current dissipation | f = 12.5 MHz<br>f = 16.67 MHz | I <sub>D</sub> | -<br>- | 90<br>100 | mA | | Power dissipation | f = 12.5 MHz<br>f = 16.67 MHz | P <sub>D</sub> | -<br>- | 0.473<br>0.525 | W | | Input capacitance<br>(Vin = 0 V, Ta = 25 °C :<br>Frequency = 1 MHz)* | | C <sub>IN</sub> | - | 20.0 | pF | | Load capacitance | HALT<br>Other pins | CL | _<br>_ | 70<br>130 | рF | <sup>\*:</sup> Input capacitance is periodically sampled rather than 100 % tested. AC Electrical Characteristics (VCC = 5.0 V ± 5 %) A: Maximum output delay B: Minimum output hold time C: Minimum input setup time D: Minimum input hold time E: Signal (A) valid - signal (B) valid time F: Signal ( ) valid - signal ( ) invalid time ### 9.3 AC Electrical Characteristics - Clock Timings $\sqrt{\text{VCC} = 5.0 \text{ V} \pm 5 \%}$ See Figure 9.1. GND = 0 V, Ta = 0 to 70 °C | Parameter | Symbol | 12.5 | MHz | 16.67 MHz | | Unit | |---------------------|------------|----------|------------|-----------|--------------|------| | | | Min. | Max. | Min. | Max. | | | Operating frequency | f | 4.0 | 12.5 | 8.0 | 16.67 | MHz | | Cycle time | tcyc | 80 | 250 | 60 | 125 | ns | | Clock pulse width | tCL<br>tCH | 35<br>35 | 125<br>125 | 27<br>27 | 62.5<br>62.5 | ns | | Rise and fall times | tCr<br>tCf | - | 5<br>5 | -<br>- | 5<br>5 | ns | Note: Unless otherwise specified, timings are measured between a low voltage of 0.8~V and a high voltage of 2.0~V. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8~V and 2.0~V. Figure 9.1 Clock Input Timing # 9.4 AC Electrical Characteristics - Read and Write Cycles (1/4) ( $V_{CC}$ = 5.0 V $\pm$ 5 %, GND = 0 V, Ta = 0 to 70 °C; See figures 9.2 and 9.3.) | Number | Parameter | Symbol | 12.5 | MHz | 16.67 | MHz | Unit | |--------------------------|------------------------------------------------------------------------------------------------------------|--------|------|------|-------|------|------| | | | | Min. | Max. | Min. | Max. | | | 1 | Clock cycle | tCYC | 80 | 250 | 60 | 125 | ns | | 2 | Clock width at low | tCL | 35 | 125 | 27 | 62.5 | ns | | 3 | Clock width at high | tCH | 35 | 125 | 27 | 62.5 | ns | | 4 | Clock fall time | tCf | _ | 5 | - | 5 | ns | | 5 | Clock rise time | tCr | _ | 5 | _ | 5 | ns | | 6 | Clock low to address valid | tCLAV | _ | 50 | _ | 50 | ns | | 6A | Clock high to FC valid | tCHFCV | _ | 45 | - | 45 | ns | | 7 | Clock high to address, data bus high impedance (maximum) | tCHADZ | - | 60 | - | 50 | ns | | 8 | Clock high to address, FC invalid (minimum) | tCHAFI | 0 | - | 0 | - | ns | | 91 | Clock high to $\overline{AS}$ , $\overline{DS}$ low | tCHSL | 3 | 40 | 3 | 40 | ns | | 112 | Address valid to $\overline{AS}$ , $\overline{DS}$ low (read)/Address valid to $\overline{AS}$ low (write) | tAVSL | 15 | _ | 15 | - | ns | | 11 <b>A</b> <sup>2</sup> | FC valid to $\overline{AS}$ , $\overline{DS}$ low (read)/FC valid to $\overline{AS}$ low (write) | tFCVSL | 60 | - | 30 | - | ns | | 121 | Clock low to AS, DS high | tCLSH | _ | 40 | 1 | 40 | ns | | 1 <b>3</b> 2 | AS, DS high to address/FC invalid | tSHAFI | 20 | - | 10 | - | ns | | 142 | AS, DS width low (read)/AS width low (write) | tSL | 160 | _ | 120 | _ | ns | | 14A <sup>2</sup> | DS width low (write) | tDSL | 80 | _ | 60 | _ | ns | | 15 <sup>2</sup> | AS, DS width high | tSH | 65 | - | 60 | - | ns | # 9.4 AC Electrical Characteristics - Read and Write Cycles (2/4) (V<sub>CC</sub> = 5.0 V $\pm$ 5 %, GND = 0 V, Ta = 0 to 70 °C; See figures 9.2 and 9.3) | Number | Parameter | Symbol | 12.5 | MHz | 16.67 | MHz | Unit | |-------------------------|-----------------------------------------------------------------------------------|--------|------|------|-------|------|------| | | | | Min. | Max. | Min. | Max. | | | 16 | Clock high to control bus high impedance | tCHCZ | - | 60 | - | 50 | ns | | 172 | AS, DS high to R/W high (read) | tSHRH | 20 | - | 10 | - | ns | | 18 <sup>1</sup> | Clock high to R/W high | tCHRH | 0 | 40 | 0 | 40 | ns | | 201 | Clock to R/W low (write) | tCHRL | 0 | 40 | 0 | 40 | ns | | 20A <sup>2.6</sup> | AS low to R/W valid (write) | tASRV | 1 | 10 | _ | 10 | ns | | <b>2</b> 1 <sup>2</sup> | Address valid to R\overline{W} low (write), FC valid to R\overline{W} low (write) | tAVRL | 0 | _ | 0 | _ | ns | | 21A <sup>2</sup> | FC valid to R/W low (write) | tFCVRL | 30 | - | 20 | - | ns | | <b>22</b> <sup>2</sup> | $R\overline{W}$ low to $\overline{DS}$ low (write) | tRLSL | 30 | - | 20 | - | ns | | 23 | Clock low to data out valid (write) | tCLDO | - | 50 | _ | 50 | ns | | <b>25</b> <sup>2</sup> | $\overline{AS}$ , $\overline{DS}$ high to data out invalid (write) | tSHDOI | 20 | - | 15 | _ | ns | | <b>26</b> <sup>2</sup> | Data out valid to $\overline{DS}$ low (write) | tDOSL | 20 | - | 15 | - | ns | | 275 | Data in to clock low (setup time on read) | tDICL | 10 | _ | 7 | _ | ns | | <b>28</b> <sup>2</sup> | AS, DS high to DTACK high | tSHDAH | 0 | 150 | 0 | 110 | ns | | 29 | AS, DS negate to data invalid (hold time for read) | tSHDII | 0 | _ | 0 | _ | ns | # 9.4 AC Electrical Characteristics - Read and Write Cycles (3/4) (V<sub>CC</sub> = 5.0 V $\pm$ 5 %, GND = 0 V, Ta = 0 to 70 °C; See figures 9.2 and 9.3.) | Number | Parameter | Symbol | 12.5 | MHz | 16.6 | 7 MHz | Unit | |-----------------|----------------------------------------------------------------|---------|------|---------------|------|---------------|--------------| | | | | | | Min. | Max. | | | 30 | AS, DS high to BERR high | tSHBEH | 0 | _ | 0 | _ | ns | | <b>3</b> 12,5 | DTACK low setup time (input data) | tDALDI | ı | 50 | ı | 40 | ns | | 32 | HALT and RESET input transition | tRHr, f | 0 | 200 | 0 | 150 | ns | | 33 | Clock high to $\overline{BG}$ low | tCHGL | _ | 40 | _ | 40 | ns | | 34 | Clock high to BG high | tCHGH | - | 40 | - | 40 | ns | | 35 | BR low to BG low | tBRLGL | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | 36 <sup>7</sup> | BR high to BG high | tBRHGH | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | 37 | BGACK low to BG high | tGALGH | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | 37A8 | BGACK low to BR high | tGALBRH | 20 | 1.5<br>Clocks | 10 | 1.5<br>Clocks | ns | | 38 | BG low to control, address, data bus, high impedance (AS high) | tGLZ | - | 60 | - | 50 | ns | | 39 | BG width high | tGH | 1.5 | - | 1.5 | _ | Clk.<br>Per. | ### 9.4 AC Electrical Characteristics - Read and Write Cycles (4/4) $(V_{CC} = 5.0 \text{ V} \pm 5 \%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0 \text{ to } 70 ^{\circ}\text{C}; \text{ See figures } 9.2 \text{ and } 9.3.)$ | Number | Parameter | Symbol | 12.5 | MHz | 16.67 | MHz | Unit | |-----------------|------------------------------------|---------|------|------|-------|------|--------------| | | | | Min. | Max. | Min. | Max. | | | 46 | BGACK width low | tGAL | 1.5 | - | 1.5 | | Clk.<br>Per. | | 475 | Asynchronous input setup time | tASI | 10 | _ | 10 | _ | ns | | 482.3 | BERR low to DTACK low | tBELDAL | 20 | _ | 10 | _ | ns | | 53 | Clock high to data out invalid | tCHDOI | 0 | _ | 0 | _ | ns | | 55 | R/W low to data bus drive | tRLDBD | 10 | - | 0 | - | ns | | 56 <sup>4</sup> | HALT / RESET pulse width | tHRPW | 10 | _ | 10 | _ | Clk.<br>Per. | | 57 | BGACK high to AS, DS, R/W<br>drive | tGASD | 1.5 | _ | 1.5 | _ | Clk.<br>Per. | | 58 <sup>7</sup> | BR high to control bus drive | tRHSD | 1.5 | _ | 1.5 | - | Clk.<br>Per. | - 1. For a loading capacitance of less than or equal to 50 picofarads, subtract five nanoseconds from the value given in the maximum columns. - 2. Actual value depends on clock cycle. - 3. If #47 is satisfied for both $\overline{DTACK}$ and $\overline{BERR}$ , #48 may be 0 nanoseconds. - 4. At power on, hold $\overline{RESET}$ and $\overline{HALT}$ into low status for 1 to 100 microseconds to stabilize MPU circuits. See #56 for the minimum reset times following power on. - 5. If the asynchronous setup time (#47) requirements are satisfied, the $\overline{DTACK}$ low-to-data setup time (#31) requirement can be ignored. The data must only satisfy the data-in to clock-low setup time (#27) requirement for the following cycle. - 6. When $\overline{AS}$ and R/W are equally loaded ( $\pm 20$ %), subtract ten nanoseconds (8-12.5 MHz) or five nanoseconds (16.67 MHz) from the tASRV maximum value. - 7. The processor will negate $\overline{BG}$ and begin driving the bus again if external arbitration logic negates $\overline{BR}$ before asserting $\overline{BGACK}$ . - 8. To guarantee proper operation, the minimum value must be met. If the maximum value is exceeded, $\overline{BG}$ may be reasserted. These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Functional descriptions and their related device operation diagrams are given elsewhere. #### Notes: - 1. Asynchronous input $\overline{BGACK}$ is detected at the clock's falling edge. - 2. It is necessary to assert at this timing only if $\overline{BR}$ is recognized at the end of this bus cycle. - 3. Unless otherwise specified, timings are measured between a low voltage of 0.8 V and a high voltage of 2.0 V. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 V and 2.0 V. Figure 9.2 Read Cycle Timing Diagram These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Functional descriptions and their related device operation diagrams are given elsewhere. #### Notes: - 1. Unless otherwise specified, timings are measured between a low voltage of 0.8 V and a high voltage of 2.0 V. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 V and 2.0 V. - 2. Because of loading variations, $R/\overline{W}$ may become valid after $\overline{AS}$ even though both are asserted at the rising edge of S2 (#20A). Figure 9.3 Write Cycle Timing Diagram # 9.4 AC Electrical Characteristics - Read and Write Cycles (1/4) ( $V_{CC}$ = 5.0 V $\pm$ 5 %, GND = 0 V, Ta = 0 to 70 °C; See figures 9.2 and 9.3.) | Number | Parameter | Symbol | 12.5 | MHz | 16.67 | MHz | Unit | |--------------------------|------------------------------------------------------------------------------------------------------------|--------|------|------|-------|------|------| | | | | Min. | Max. | Min. | Max. | | | 1 | Clock cycle | tCYC | 80 | 250 | 60 | 125 | ns | | 2 | Clock width at low | tCL | 35 | 125 | 27 | 62.5 | ns | | 3 | Clock width at high | tCH | 35 | 125 | 27 | 62.5 | ns | | 4 | Clock fall time | tCf | _ | 5 | - | 5 | ns | | 5 | Clock rise time | tCr | _ | 5 | _ | 5 | ns | | 6 | Clock low to address valid | tCLAV | _ | 50 | _ | 50 | ns | | 6A | Clock high to FC valid | tCHFCV | _ | 45 | - | 45 | ns | | 7 | Clock high to address, data bus high impedance (maximum) | tCHADZ | - | 60 | - | 50 | ns | | 8 | Clock high to address, FC invalid (minimum) | tCHAFI | 0 | - | 0 | - | ns | | 91 | Clock high to $\overline{AS}$ , $\overline{DS}$ low | tCHSL | 3 | 40 | 3 | 40 | ns | | 112 | Address valid to $\overline{AS}$ , $\overline{DS}$ low (read)/Address valid to $\overline{AS}$ low (write) | tAVSL | 15 | _ | 15 | - | ns | | 11 <b>A</b> <sup>2</sup> | FC valid to $\overline{AS}$ , $\overline{DS}$ low (read)/FC valid to $\overline{AS}$ low (write) | tFCVSL | 60 | - | 30 | - | ns | | 121 | Clock low to AS, DS high | tCLSH | _ | 40 | 1 | 40 | ns | | 1 <b>3</b> 2 | AS, DS high to address/FC invalid | tSHAFI | 20 | - | 10 | - | ns | | 142 | AS, DS width low (read)/AS width low (write) | tSL | 160 | _ | 120 | _ | ns | | 14A <sup>2</sup> | DS width low (write) | tDSL | 80 | _ | 60 | _ | ns | | 15 <sup>2</sup> | AS, DS width high | tSH | 65 | - | 60 | - | ns | # 9.4 AC Electrical Characteristics - Read and Write Cycles (2/4) (V<sub>CC</sub> = 5.0 V $\pm$ 5 %, GND = 0 V, Ta = 0 to 70 °C; See figures 9.2 and 9.3) | Number | Parameter | Symbol | 12.5 | MHz | 16.67 | MHz | Unit | |-------------------------|-----------------------------------------------------------------------------------|--------|------|------|-------|------|------| | | | | Min. | Max. | Min. | Max. | | | 16 | Clock high to control bus high impedance | tCHCZ | - | 60 | - | 50 | ns | | 172 | AS, DS high to R/W high (read) | tSHRH | 20 | - | 10 | - | ns | | 18 <sup>1</sup> | Clock high to R/W high | tCHRH | 0 | 40 | 0 | 40 | ns | | 201 | Clock to R/W low (write) | tCHRL | 0 | 40 | 0 | 40 | ns | | 20A <sup>2.6</sup> | AS low to R/W valid (write) | tASRV | 1 | 10 | _ | 10 | ns | | <b>2</b> 1 <sup>2</sup> | Address valid to R\overline{W} low (write), FC valid to R\overline{W} low (write) | tAVRL | 0 | _ | 0 | _ | ns | | 21A <sup>2</sup> | FC valid to R/W low (write) | tFCVRL | 30 | - | 20 | - | ns | | <b>22</b> <sup>2</sup> | $R\overline{W}$ low to $\overline{DS}$ low (write) | tRLSL | 30 | - | 20 | - | ns | | 23 | Clock low to data out valid (write) | tCLDO | - | 50 | _ | 50 | ns | | <b>25</b> <sup>2</sup> | $\overline{AS}$ , $\overline{DS}$ high to data out invalid (write) | tSHDOI | 20 | - | 15 | _ | ns | | <b>26</b> <sup>2</sup> | Data out valid to $\overline{DS}$ low (write) | tDOSL | 20 | - | 15 | - | ns | | 275 | Data in to clock low (setup time on read) | tDICL | 10 | _ | 7 | _ | ns | | <b>28</b> <sup>2</sup> | AS, DS high to DTACK high | tSHDAH | 0 | 150 | 0 | 110 | ns | | 29 | AS, DS negate to data invalid (hold time for read) | tSHDII | 0 | _ | 0 | _ | ns | # 9.4 AC Electrical Characteristics - Read and Write Cycles (3/4) (V<sub>CC</sub> = 5.0 V $\pm$ 5 %, GND = 0 V, Ta = 0 to 70 °C; See figures 9.2 and 9.3.) | Number | Parameter | Symbol | 12.5 | MHz | 16.6 | 7 MHz | Unit | |-----------------|----------------------------------------------------------------|---------|------|---------------|------|---------------|--------------| | | | | | | Min. | Max. | | | 30 | AS, DS high to BERR high | tSHBEH | 0 | _ | 0 | _ | ns | | 312,5 | DTACK low setup time (input data) | tDALDI | ı | 50 | ı | 40 | ns | | 32 | HALT and RESET input transition | tRHr, f | 0 | 200 | 0 | 150 | ns | | 33 | Clock high to $\overline{BG}$ low | tCHGL | _ | 40 | _ | 40 | ns | | 34 | Clock high to BG high | tCHGH | - | 40 | - | 40 | ns | | 35 | BR low to BG low | tBRLGL | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | 36 <sup>7</sup> | BR high to BG high | tBRHGH | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | 37 | BGACK low to BG high | tGALGH | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | 37A8 | BGACK low to BR high | tGALBRH | 20 | 1.5<br>Clocks | 10 | 1.5<br>Clocks | ns | | 38 | BG low to control, address, data bus, high impedance (AS high) | tGLZ | - | 60 | - | 50 | ns | | 39 | BG width high | tGH | 1.5 | - | 1.5 | _ | Clk.<br>Per. | ### 9.4 AC Electrical Characteristics - Read and Write Cycles (4/4) $(V_{CC} = 5.0 \text{ V} \pm 5 \%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0 \text{ to } 70 ^{\circ}\text{C}; \text{ See figures } 9.2 \text{ and } 9.3.)$ | | Parameter | Symbol | | | | | | |-----------------|------------------------------------|---------|----------|------|-----------|------|--------------| | Number | | | 12.5 MHz | | 16.67 MHz | | Unit | | | | | Min. | Max. | Min. | Max. | | | 46 | BGACK width low | tGAL | 1.5 | - | 1.5 | | Clk.<br>Per. | | 475 | Asynchronous input setup time | tASI | 10 | _ | 10 | _ | ns | | 482.3 | BERR low to DTACK low | tBELDAL | 20 | _ | 10 | _ | ns | | 53 | Clock high to data out invalid | tCHDOI | 0 | _ | 0 | _ | ns | | 55 | R/W low to data bus drive | tRLDBD | 10 | - | 0 | - | ns | | 56 <sup>4</sup> | HALT / RESET pulse width | tHRPW | 10 | _ | 10 | _ | Clk.<br>Per. | | 57 | BGACK high to AS, DS, R/W<br>drive | tGASD | 1.5 | _ | 1.5 | _ | Clk.<br>Per. | | 58 <sup>7</sup> | BR high to control bus drive | tRHSD | 1.5 | _ | 1.5 | _ | Clk.<br>Per. | - 1. For a loading capacitance of less than or equal to 50 picofarads, subtract five nanoseconds from the value given in the maximum columns. - 2. Actual value depends on clock cycle. - 3. If #47 is satisfied for both $\overline{DTACK}$ and $\overline{BERR}$ , #48 may be 0 nanoseconds. - 4. At power on, hold $\overline{RESET}$ and $\overline{HALT}$ into low status for 1 to 100 microseconds to stabilize MPU circuits. See #56 for the minimum reset times following power on. - 5. If the asynchronous setup time (#47) requirements are satisfied, the $\overline{DTACK}$ low-to-data setup time (#31) requirement can be ignored. The data must only satisfy the data-in to clock-low setup time (#27) requirement for the following cycle. - 6. When $\overline{AS}$ and R/W are equally loaded ( $\pm 20$ %), subtract ten nanoseconds (8-12.5 MHz) or five nanoseconds (16.67 MHz) from the tASRV maximum value. - 7. The processor will negate $\overline{BG}$ and begin driving the bus again if external arbitration logic negates $\overline{BR}$ before asserting $\overline{BGACK}$ . - 8. To guarantee proper operation, the minimum value must be met. If the maximum value is exceeded, $\overline{BG}$ may be reasserted. These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Functional descriptions and their related device operation diagrams are given elsewhere. #### Notes: - 1. Asynchronous input $\overline{BGACK}$ is detected at the clock's falling edge. - 2. It is necessary to assert at this timing only if $\overline{BR}$ is recognized at the end of this bus cycle. - 3. Unless otherwise specified, timings are measured between a low voltage of 0.8 V and a high voltage of 2.0 V. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 V and 2.0 V. Figure 9.2 Read Cycle Timing Diagram These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Functional descriptions and their related device operation diagrams are given elsewhere. #### Notes: - 1. Unless otherwise specified, timings are measured between a low voltage of 0.8 V and a high voltage of 2.0 V. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 V and 2.0 V. - 2. Because of loading variations, $R/\overline{W}$ may become valid after $\overline{AS}$ even though both are asserted at the rising edge of S2 (#20A). Figure 9.3 Write Cycle Timing Diagram #### 9.5 AC Electrical Characteristics - Bus Arbitration $(V_{CC} = 5.0 \text{ V} \pm 5 \text{ \%}, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0 \text{ to } 70 \text{ °C}; \text{ Figure 9.4})$ | | , e. | _ = 3.0 \ = 3 /( | ŕ | • | | | , | | |------------------|---------------------------------------------------------------|------------------|----------|---------------|-----------|---------------|--------------|--| | Number | Parameter | Symbol | 12.5 MHz | | 16.67 MHz | | Unit | | | | | | Min. | Max. | Min. | Max. | | | | 7 | Clock high to address, data bus high impedance | tCHADZ | _ | 60 | _ | 50 | ns | | | 16 | Clock high to control bus high impedance | tCHCZ | - | 60 | - | 50 | ns | | | 33 | Clock high to $\overline{BG}$ low | tCHGL | _ | 40 | _ | 40 | ns | | | 34 | Clock high to $\overline{BG}$ high | tCHGH | _ | 40 | _ | 40 | ns | | | 35 | BR low to BG low | tBRLGL | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | | 36 <sup>1</sup> | BR high to BG high | tBKHGH | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | | 37 | BGACK low to BG high | tGALGH | 1.5 | 3.5 | 1.5 | 3.5 | Clk.<br>Per. | | | 37A <sup>2</sup> | BGACK low to BR high | tGALBRH | 20 | 1.5<br>Clocks | 10 | 1.5<br>Clocks | ns | | | 38 | BG low to control, address, data bus high impedance (AS high) | tGLZ | ı | 60 | ı | | ns | | | 39 | BG width high | tGH | 1.5 | - | 1.5 | | Clk.<br>Per. | | | 46 | BGACK width low | tGAL | 1.5 | _ | 1.5 | | Clk.<br>Per. | | | 47 | Asynchronous input setup time | tASI | 10 | _ | 5 | | ns | | | 57 | BGACK high to control bus drive | tGABD | 1.5 | - | 1.5 | | Clk.<br>Per. | | | 58 <sup>1</sup> | BG high to control bus drive | tGHBD | 1.5 | - | 1.5 | | Clk.<br>Per. | | - 1. The processor will negate $\overline{BG}$ and begin driving the bus again if external arbitration logic negates $\overline{BR}$ before asserting $\overline{BGACK}$ - 2. To guarantee proper operation, the minimum value must be met. If the maximum value is exceeded, $\overline{BG}$ may be reasserted. These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Functional descriptions and their related device operation diagrams are given elsewhere. Note: Asynchronous inputs $\overline{BERR}$ , $\overline{BGACK}$ , $\overline{BR}$ , and $\overline{DTACK}$ are detected at the clock's falling edge. Figure 9.4 Bus Arbitration Timing Diagram When the external bus master accesses the registers of internal devices, addresses, data, and control signals must be input in accordance with the read/write cycle timing. # 9.6 AC Electrical Characteristics - Peripherals $(V_{CC} = 5.0 \text{ V} \pm 5 \text{ \%}, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0 \text{ to } 70 \,^{\circ}\text{C}; \text{ See figures } 9.5 - 9.11)$ | | (*() - 3.0 * 2 3 | | | | | | | |--------|---------------------------------------------------|---------|----------|------|-----------|------|------| | Number | Parameter | Symbol | 12.5 MHz | | 16.67 MHz | | Unit | | | | | Min. | Max. | Min. | Max. | | | 47 | Asynchronous input setup time | tASI | 10 | _ | 10 | _ | ns | | 101 | Clock to $\overline{CS}$ , $\overline{IACK}$ | tCDS | _ | 50 | _ | 50 | ns | | 102 | Clock high to TOUT | tCHTO | _ | 40 | _ | 40 | ns | | 103 | BCLK cycle | tBCYC | 125 | - | 125 | _ | ns | | 104 | BCLK width low | tBCL | 55 | ı | 55 | _ | ns | | 105 | BCLK width high | tBCH | 55 | ı | 55 | _ | ns | | 106 | BCLK rise time | tBCr | _ | 10 | _ | 10 | ns | | 107 | BCLK fall time | tBCf | _ | 10 | _ | 10 | ns | | 108 | LDS high to DTR, RTS | tDSMC | _ | 140 | _ | 140 | ns | | 109 | DSR to LDS low | tMCDS | 50 | _ | 50 | _ | ns | | 110 | DS high to I/O output | tDSIO | _ | 60 | _ | 60 | ns | | 111 | I/O data in to CLK low (setup time on I/O input) | tlOsCL | 50 | _ | 50 | _ | ns | | 112 | I/O data in to clock low (hold time on I/O input) | tlOhCL | 50 | _ | 50 | _ | ns | | 113 | DATA delay time | tDDA | _ | 60 | _ | 60 | ns | | 114 | Clock high to DSTB | tCHST | _ | 60 | _ | 60 | ns | | 115 | PRIME delay time | tDPR | _ | 60 | _ | 60 | ns | | 116 | DATA setup time for DSTB | tDAs\$T | 20 | _ | 20 | _ | ns | | 117 | DATA hold time for DSTB | tDAhST | 60 | _ | 60 | _ | ns | | 118 | DSTB width low | tSTL | 70 | _ | 70 | _ | ns | | 119 | BUSY delay time | tDBY | _ | 100 | _ | 100 | ns | | 120 | FAULT delay time | tDFA | _ | 100 | _ | 100 | ns | | 121 | From CLK high to ACK | tCHAC | _ | 60 | _ | 60 | ns | | 122 | From ACK low to BUSY low | tACLBY | _ | 60 | _ | 60 | ns | | 123 | From ACK high to BUSY low | tACHBY | _ | 60 | _ | 60 | ns | Figure 9.10 I/O Port Output Timing Diagram Figure 9.11 I/O Port Input Timing Diagram Figure 9.12 Centronics Output Timing Diagram (Mode 1) TOSHIBA Figure 9.13 Centronics Input Timing Diagram (Mode 2) #### 10. Development Environment #### 10.1 Emulation mode Set the NOR/EMU pin to low to enter emulation mode (henceforth, EMU mode). In EMU mode, the TMP68301A CPU is completely disconnected and only peripheral devices are active. In EMU mode, the emulator controls the peripheral devices. Figure 10.1 Outline of Normal and Emulation Modes #### 10.1.1 Pin Functions (1) NOR/ $\overline{EMU}$ : Fixed to high in normal mode. Fixed to low in $\overline{EMU}$ mode. $\begin{array}{cc} \textbf{(2)} & \overline{BR}/\overline{IPL0} \\ & \overline{BG}/\overline{IPL1} \end{array}$ BGACK/IPL2 : In normal mode, these pins $(\overline{BR}, \overline{BG}, \overline{BGACK})$ perform bus arbitration control. In EMU mode, $\overline{IPL0}$ to $\overline{IPL2}$ are output signals. As these pin signals operate differently for different modes, use jumpers to change pin operation, as shown in figures 10.2 and 10.3. (See \*1 in the figures) #### 10.2 Connecting to General-Purpose 68000 Emulator In principle, TMP68301A emulation can be performed using any commercially available general-purpose 68000 emulator. Note, however, the following points: - (1) As TMP68301A does not have E, $\overline{VPA}$ , and $\overline{VMA}$ signals for controlling 8-bit peripheral devices, the $\overline{VPA}$ input to the emulator must be pulled-up. - (2) The 68000 interrupt vector automatic generation function cannot be used because TMP68301A does not have a VPA signal. However, TMP68301A has a similar function in its internal interrupt controller. For interrupt requests from external devices, use the interrupt input pins INT0 to INT2 connected to the interrupt controller. - (3) The DTACK and BERR signals are open drain outputs in EMU mode. Therefore, the DTACK and BERR signals generated on the target board must also be open drain outputs and pull-up resistors must be provided. At \*2 in the figures, high resistance can result in slow rise times and cause operational problems. Therefore, use resistances of about 1K ohms. - (4) The following problems can occur due to a slow rise time for the $\overline{AS}$ signal output from the general-purpose 68000 emulator. - If another interrupt occurs while an interrupt is pending, the pending bit is cleared and the interrupt is not subsequently accepted. - If the $\overline{AS}$ signal setup time (\*1 in Figure 10.4) does not satisfy the specification, the operation of the $\overline{DTACK}$ automatic generation function may be impaired and $\overline{DTACK}$ may not be asserted. (If $\overline{DTACK}$ is not asserted, the bus cycle does not complete and a bus error is generated.) (Figure 10.4) For some 68000 emulators, the $\overline{AS}$ signal is always too slow. This problem can be solved, for example, by changing the relative phases of the clocks to the emulator and to 68301A, as shown in Figure 10.5. Figure 10.2 Wiring Diagram in Normal Mode Figure 10.3 Connection to Emulator in EMU Mode Figure 10.4 AS Signal Setup Time during Emulation Figure 10.5 Clock Adjustments for Emulation