TS68HC901

HCMOS

**MULTI FUNCTION** 

PERIPHERAL

CASES



### HEMOS MULTIFUNCTION PERIPHERAL

Partial A A A L M.

1.0

З

а

#### **ADVANCE INFORMATION**

The TS68HC901 muli-function peripheral (CMFP) is a member of the 68000 Family of peripherals and the CMOS version of the MK68901. The CMFP directly interfaces to the 68000 processor via an asynchronous bus structure and can also support both multiplexed and non multiplexed buses. Both vectored, non vectored and polled interrupt schemes are supported, with the CMFP providing unique vector number generation for each of its 16 interrupt sources. Additionally, handshake lines are provided to facilitate DMAC interfacing.

The TS68HC901 performs many of the functions common to most microprocessor-based systems. The resources available to the user include :

- Eight Individually Programmable I/O Pins with Interrupt Capability
- 16-Source Interrupt Controller with Individual Source Enabling and Masking
   Four Timor, Two of which are the birts of the second se
- Four Timers, Two of which are Multi-Mode Timers
- Timers may be used as Baud Rate Generators for the Serial Channel
   Single-Channel Full-Duplex Universal Synchronous/Asynchronous Receiver-Transmitter (USART) that Supports Asynchronous and with the Addition of a Polynominal Generator Checker Supports Byte Synchronous Formats.

By incorporating multiple functions within the CMFP, the system designer retains flexibility while minimizing device count.

The CMOS technology used for the TS68HC901 reduces also the power consumption of the system.





4-59

### SECTION 1 INTRODUCTION

The TS68HC901 multi-function peripheral (CMFP) is a member of the 68000 peripherals. The CMFP directly interfaces to the 68000 processor via an asynchronous bus structure. Both vectored and polled interrupt schemes are supported, with the CMFP providing unique vector number generation for each of its 16 interrupt sources. Additionally, handshake lines are provided to facilitate DMAC interfacing. Refer to block diagram of the TS68HC901.

The TS68HC901 performs many of the functions common to most microprocessor-based systems.

The resources available to the user include:

- Eight Individually Programmable I/O Pins with Interrupt Capability
- Eight individually in egreen with Individual Source Enabling and Masking
   16-Source Interrupt Controller with Individual Source Enabling and Masking
- Four Timers, Two of which are Multi-Mode Timers
- Timers May Be Used as Baud Rate Generators for the Serial Channel
- Single-Channel Full-Duplex Universal Synchronous/Asynchronous Receiver-Transmitter (USART) that Supports Asynchronous and with the Addition of a Polynomial Generator Checker Supports Byte Synchronous Formats

By incorporating multiple functions within the CMFP, the system designer retains flexibility while minimizing device count.

4-60

N N

From a programmer's point of view, the versatility of the CMFP may be attributed to its register set. The registers are well organized and allow the CMFP to be easily tailored to a variety of applications. All of the 24 registers are also directly addressable which simplifies programming. The register map is shown in Table 1-1.

| Address |     |        |     |     |     |              |                                 |  |  |
|---------|-----|--------|-----|-----|-----|--------------|---------------------------------|--|--|
|         |     | Binary |     |     |     |              |                                 |  |  |
| Hex     | RS5 | RS4    | RS3 | RS2 | RS1 | Abbreviation | Register Name                   |  |  |
| 01      | 0   | 0      | 0   | 0   | 0   | GPIP         | General Purpose I/O Register    |  |  |
| 03      | 0   | 0      | 0   | 0   | 1   | AER          | Active Edge Register            |  |  |
| 05      | 0   | 0      | 0   | 1   | 0   | DDR          | Data Direction Register         |  |  |
| 07      | 0   | 0      | 0   | 1   | 1   | IERA         | Interrupt Enable Register A     |  |  |
| 09      | 0   | 0      | 1   | 0   | 0   | IERB         | Interrupt Enable Register B     |  |  |
| OB      | 0   | 0      | 1   | 0   | 1   | IPRA         | Interrupt Pending Register A    |  |  |
| 0D      | 0   | 0      | 1   | 1   | 0   | IPRB         | Interrupt Pending Register B    |  |  |
| OF      | 0   | 0      | 1   | 1   | 1   | ISRA         | Interrupt In-Service Register A |  |  |
| 11      | 0   | 1      | 0   | 0   | 0   | ISRB         | Interrupt In-Service Register B |  |  |
| 13      | 0   | (1     | 0   | 0   | 1   | IMRA         | Interrupt Mask Register A       |  |  |
| 15      | 0   | 1      | 0   | 1   | 0   | IMRB         | Interrupt Mask Register B       |  |  |
| 17      | 0   | 1      | 0   | 1   | 1   | VR           | Vector Register                 |  |  |
| 19      | 0   | 1      | 1   | 0   | 0   | TACR         | Timer A Control Register        |  |  |
| 1B      | 0   | 1      | 1   | 0   | 1   | TBCR         | Timer B Control Register        |  |  |
| 1D      | 0   | 1      | 1   | 1   | 0   | TCDCR        | Timers C and D Control Register |  |  |
| 1F      | 0   | 1      | 1   | 1   | 1   | TADR         | Timer A Data Register           |  |  |
| 21      | 1   | 0      | 0   | 0   | 0   | TBDR         | Timer B Data Register           |  |  |
| 23      | 1   | 0      | 0   | 0   | 1   | TCDR         | Timer C Data Register           |  |  |
| 25      | 1   | 0      | 0   | 1   | 0   | TDDR         | Timer D Data Register           |  |  |
| 27      | 1   | 0      | 0   | 1   | 1   | SCR          | Synchronous Character Register  |  |  |
| 29      | 1   | 0      | 1   | 0   | 0   | UCR          | USART Control Register          |  |  |
| 2B      | 1   | 0      | 1   | 0   | 1   | RSR          | Receiver Status Register        |  |  |
| 2D      | 1   | 0      | 1   | 1   | 0   | TSR          | Transmitter Status Register     |  |  |
| 2F      | 1   | 0      | 1   | _ 1 | 1   | UDR          | USART Data Register             |  |  |

Table 1-1. CMFP Register Map

NOTE : Hex addresses assume that RS1 connects with A1, RS2 connects with A2, etc... and that DS is connected to LDS on the 68000 or DS is connected to DS on the 68008.

N In

4-62

### This Material Copyrighted By Its Respective Manufacturer

Downloaded from Datasheet.su

### SECTION 2 SIGNAL AND BUS OPERATION DESCRIPTION

This section contains a brief description of the input and output signals. A discussion of bus operation during the various operations is also presented.

Note: The terms assertion and negation will be used extensively. This is done to avoid confusion when dealing with a mixture of "active low" and "active high" signals. The term assert or assertion is used to indicate that a signal is active or true, independent of whether that level is represented by a high or low voltage. The term negate or negation is used to indicate that a signal is inactive or false.

#### 2.1 SIGNAL DESCRIPTION

The input and output signals can be functionally organized into the groups shown in Figure 2-1. The following paragraphs provide a brief description of the signal and a reference (if applicable) to other sections that contain more detail about its function.

1.81111111



Figure 2-1. Input and Output Signals

### 2.1.1 VCC and GND

These inputs supply power to the CMFP. The V<sub>CC</sub> is power at  $\pm$  5 volts and GND is the ground connection.

#### 2.1.2 Clock (CLK)

The clock input is a single-phase TTL-compatible signal used for internal timing. This input should not be gated off at any time and must conform to minimum and maximum pulse width times. The clock is not necessarily the system clock in frequency nor phase. When the bus is multiplexed (MPX=1), an adress strobe signal is connected to this pin. In the non multiplexed mode (MPX=0), this input is connected to the system clock when used with a 68000 processor type or to VSS (0 VDC) when used with a 6800 processor type.

### 2.1.3 Asynchronous Bus Control

Asynchronous data transfers are controlled by chip select, data strobe, read/write, and data transfer acknowledge. The low order register select lines, RS1-RS5, select an internal CMFP register for a read or write operation. The reset line initializes the CMFP registers and the internal control signals.

2.1.3.1 CHIP SELECT (CS). This input activates the CMFP for internal register access.

2.1.3.2 DATA STROBE (DS). This input is part of the internal chip select and interrupt acknowledge functions. The CMFP must be located on the lower portion of the 16-bit data bus so that the vector number passed to the processor during an interrupt acknowledge cycle will be located in the low byte of the data word. As a result, DS must be connected to the processor's lower data strobe if vectored interrupts are to be used. Note that this forces all registers to be located at odd addresses and latches data on the rising edge for writes. This signal is used as  $\overline{RD}$  with an Intel processor type.

**2.1.3.3 READ/WRITE (R/W).** This input defines a data transfer as a read (high) or a write (low) cycle. This signal is used as WR with an Intel processor type.

2.1.3.4. DATA TRANSFER ACKNOWLEDGE (DTACK). This output signals the completion of the operation phase of a bus cycle to the processor. If the bus cycle is a processor read, the CMFP asserts DTACK to indicate that the information on the data bus is valid. If the bus cycle is a = processor to the CMFP, DTACK acknowledges the acceptance of the data by the CMFP. DTACK will be asserted only by an CMFP that has CS or IACK (and IEI) asserted. This signal is not used with a 6800 processor type.

2.1.3.5 REGISTER SELECT BUS (RS1 THROUGH RS5). The lower five bits of the register select bus select an internal CMFP register during a read or write operation.

4-64

Parties to the second second

COLUMN 1

N IN IN

a,

**2.1.3.6 DATA BUS (D0 THROUGH D7).** This bidirectional bus is used to receive data from or transmit data to the CMFP's internal registers during a processor read or write cycle. During an interrupt acknowledge cycle, the data bus is used to pass a vector number to the processor. Since the CMFP is an 8-bit peripheral, the CMFP could be located on either the upper or lower portion of the 16-bit data bus (even or odd address). However, during an interrupt acknowledge cycle, the vector number passed to the processor must be located in the low byte of the data word. As a result, D0-D7 of the CMFP must be connected to the low order eight bits of the processor data bus, placing CMFP registers at odd addresses if vectored interrupts are to be used.

2.1.3.7 RESET (RESET). This input will initialize the CMFP during power up or in response to a total system reset. Refer to 2.2.3 for further information.

2.1.3.8 MPX. This signal selects the data bus mode:

MPX=0: non multiplexed mode

MPX=1: multiplexed mode. The register select lines RS1-RS5 and the data bus D0-D7 are multiplexed. An adress strobe must be connected to the CLK pin.

#### 2.1.4 Interrupt Control

The interrupt request and interrupt acknowledge signals are handshake lines for a vectored interrupt scheme. Interrupt enable in and the interrupt enable out implement a daisy-chained interrupt structure.

2.1.4.1 INTERRUPT REQUEST (IRQ). This output signals the processor that an interrupt is pending from the CMFP. These are 16 interrupt channels that can generate an interrupt request. Clearing the interrupt pending registers (IPRA and IPRB) or clearing the interrupt mask registers (IMRA and IMRB) will cause IRQ to be negated. IRQ will also be negated as the result of an interrupt acknowledge cycle, unless additional interrupts are pending in the CMFP. Refer to SECTION 3 for further information.

2.1.4.2 INTERRUPT ACKNOWLEDGE (IACK). If both IRQ and IEI are active, the CMFP will begin an interrupt acknowledge cycle when IACK and DS are asserted. The CMFP will supply a unique vector number to the processor which corresponds to the interrupt handler for the particular channel requiring interrupt service. In a daisy-chained interrupt structure, all devices in the chain must have a common IACK. Refer to 2.2.2 and 3.1.2 for additional information.

2.1.4.3 INTERRUPT ENABLE IN (IEI). This input, together with the IEO signal, provides a daisychained interrupt structure for a vectored interrupt scheme. IEI indicates that no higher priority device is requesting interrupt service. So, the highest priority device in the chain should have its IEI pin tied low. During an interrupt acknowledge cycle, an CMFP with a pending interrupt is not allowed to pass a vector number to the processor until its IEI pin is asserted. When the daisy-chain option is not implemented, all CMFPs should have their IEI pin tied low. Refer to 3.2 for additional information.

2.1.4.4 INTERRUPT ENABLE OUT (IEO). This output, together with the IEI signal, provides a daisy-chained interrupt structure for a vectored interrupt scheme. The IEO of a particular CMFP signals lower priority devices that neither the CMFP nor any other higher-priority device is requesting interrupt service. When a daisy-chain is implemented, IEO is tied to the next lower priority device's IEI input. The lowest priority device's IEO is not connected. When the daisychain option is not implemented, IEO is not connected. Refer to **3.2** for additional information.

## 2.1.5 General Purpose I/O Interrupt Lines (I0 Through I7)

This is an 8-bit pin-programmable I/O port with interrupt capability. The data direction register (DDR) individually defines each line as either a high-impedance input or a TTL-compatible output. As an input, each line can generate an interrupt on the user selected transition of the input signal. Refer to SECTION 4 for further information.

æ

1.91111111

#### 2.1.6 Timer Control

These lines provide internal timing and auxiliary timer control inputs required for certain operating modes. Additionally, the timer outputs are included in this group.

2.1.6.1 TIMER CLOCK (XTAL1 AND XTAL2). This input provides the timing signal for the four timers. A crystal can be connected between the timer clock inputs, XTAL1 and XTAL2, or XTAL1 can be driven with a TTL-level clock while XTAL2 is not connected. The following crystal parameters are suggested:

- a) Parallel resonance, fundamental mode AT-cut
- b) Frequency tolerance measured with 18 picofarads load (0.1% accuracy) drive level 10 microwatts
- c) Shunt capacitance equals 7 picofarads maximum
- d) Series resistance:
  - 2.0<f<2.7 MHz; RS≤300 Ω 2.8<f<4.0 MHz; RS  $\leq$  150  $\Omega$

2.1.6.2 TIMER INPUTS (TAI AND TBI). These inputs are control signals for timers A and B in the pulse width measurement mode and event count mode. These signals generate interrupts at the same priority level as the general purpose I/O interrupt lines I4 and I3, respectively. While I4 and I3 do not have interrupt capability when the timers are operated in the pulse width measurement mode or the event count mode, I4 and I3 may still be used for I/O. Refer to 5.1.2 and 5.1.3 for further information.

2.1.6.3 TIMER OUTPUTS (TAO, TBO, TCO, AND TDO). Each timer has an associated output which toggles when its main counter counts through 01 (hexadecimal), regardless of which operational mode is selected. When in the delay mode, the timer output will be a square wave with a period equal to two timer cycles. This output signal may be used to supply the universal synchronous/asynchronous receiver-transmitter (USART) baud rate clocks. Timer outputs TAO and TBO may be cleared at any time by writing a one to the reset location in timer control registers A and B. Also, a device reset forces all timer outputs low. Refer to 5.2.2 for additional information.

4-66

N N

#### 2.1.7 Serial I/O Control

The full duplex serial channel is implemented by a serial input and output line. The independent receive and transmit sections may be clocked by separate timing signals on the receiver clock input and the transmitter clock input.

2.1.7.1 SERIAL INPUT (SI). This input line is the USART receiver data input. This input is not used in the USART loopback mode. Refer to 6.3.2 for additional information.

**2.1.7.2 SERIAL OUTPUT (SO).** This output line is the USART transmitter data output. This output is driven high during a device reset.

2.1.7.3 RECEIVER CLOCK (RC). This input controls the serial bit rate of the receiver. This signal may be supplied by the timer output lines or by any external TTL-level clock which meets the minimum and maximum cycle times. This clock is not used in the USART loopback mode. Refer to 6.3.2 for additional information.

2.1.7.4 TRANSMITTER CLOCK (TC). This input controls the serial bit rate of the transmitter. This signal may be supplied by the timer output lines or by an external TTL-level clock which meets the minimum and maximum cycle times.

#### 2.1.8 DMA Control

The USART supports DMA transfers through its receiver ready and transmitter ready status lines.

2.1.8.1 RECEIVER READY (RR). This output reflects the receiver buffer full status for DMA operations.

**2.1.8.2 TRANSMITTER READY (TR).** This output reflects the transmitter buffer empty status for DMA operations.

4-67

#### 2.1.9 Signal Summary

Table 2-1 is a summary of all the signals discussed in the previous paragraphs.

| Signal Name                           | Mnemonic                 | 1/0    | Active                   |
|---------------------------------------|--------------------------|--------|--------------------------|
| Power Input                           | V <sub>CC</sub>          | Input  | High                     |
|                                       | GND                      | Input  | Low                      |
| Ground                                | СГК                      | Input  | N/A                      |
|                                       | <u>Ē</u> s               | Input  | Low                      |
| Chip Select                           | DS                       | Input  | Low                      |
| Data strobe                           | R/W                      | Input  | Read - High, Write - Low |
| Read/Write                            | DTACK                    | Output | Low                      |
| Data Transfer Acknowledge             | RS1-RS5                  | Input  | N/A                      |
| Register Select Bus                   | D0-D7                    | 1/0    | N/A                      |
| Data Bus                              | RESET                    | Input  | Low                      |
| Reset                                 | ĪRŌ                      | Output | Low                      |
| Interrupt Request                     | IACK                     | Input  | Low                      |
| Interrupt Acknowledge                 | TĒ                       | Input  | Low                      |
| Interrupt Enable In                   | IEO                      | Output | Low                      |
| Interrupt Enable Out                  | 10.17                    | 1/0    | N/A                      |
| General Purpose I/O – Interrupt Lines | XTAL1, XTAL2             | Input  | High                     |
| Timer Clock                           | TAL TBI                  | Input  | N/A                      |
| Timer Inputs                          |                          | Output | N/A                      |
| Timer Outputs                         | TAO, TBO, TCO, TDO<br>SI | Input  | N/A                      |
| Serial Input                          |                          | Output | N/A                      |
| Serial Output                         | <u>so</u>                | Input  | N/A                      |
| Receiver Clock                        | RC                       |        | N/A                      |
| Transmitter Clock                     |                          | Input  | Low                      |
| Receiver Ready                        | RR                       | Output | Low                      |
| Transmitter Ready                     | TR                       | Output | N/A                      |
| MPX                                   | MPX                      | Input  |                          |

#### Table 2-1. Signal Summary

#### 2.2 BUS OPERATION

The following paragraphs explain the control signals and bus operation during data transfer operations and reset.

#### 2.2.1 Data Transfer Operations

Transfer of data between devices involves the following pins:

Register Select Bus - RS1 through RS5

Data Bus - D0 through D7

**Control Signals** 

The address and data buses are separate parallel buses used to transfer data using an asynchronous bus structure. In all cycles, the bus master assumes responsibility for deskewing all signals it issues at both the start and end of a cycle. Additionally, the bus master is responsible for deskewing the acknowledge and data signals from the peripheral devices.

4-68

**2.2.1.1 READ CYCLE.** To read an CMFP register,  $\overline{CS}$  and  $\overline{DS}$  must be asserted, and  $R/\overline{W}$  must be high. The CMFP will place the contents of the register which is selected by the register select bus (RS1 through RS5) on the data bus (D0 through D7) and then assert  $\overline{DTACK}$ . The register addresses are shown in Table 1-1.

After the processor has latched the data,  $\overline{DS}$  is negated. The negation of either  $\overline{CS}$  or  $\overline{DS}$  will terminate the read operation. The CMFP will drive  $\overline{DTACK}$  high and place it in the high-impedance state. Also, the data bus will be in the high-impedance state. The timing for a read cycle is shown in Figure 2-2. Refer to 7.7 for actual timing numbers.



**2.2.1.2 WRITE CYCLE.** To write a register,  $\overline{CS}$  and  $\overline{DS}$  must be asserted, and  $R/\overline{W}$  must be low. The CMFP will decode the address bus to determine which register is selected (the register map is shown in Table 1-1). Then the register will be loaded with the contents of the data bus and  $\overline{DTACK}$  will be asserted.

4-69

When the processor recognizes DTACK, DS will be negated. The write cycle is terminated when either CS or DS is negated. The CMFP will drive DTACK high and place it in the high-impedance state. The timing for a write cycle is shown in Figure 2-3. Refer to **7.7** for actual numbers.





### 2.2.2 Interrupt Acknowledge Operation

The CMFP has 16 interrupt sources, eight internal sources, and eight external sources. When an interrupturequest is pending, the CMFP will assert IRQ. In a vectored interrupt scheme, the processor will acknowledge the interrupt request by performing an interrupt acknowledge cycle. IACK and DS will be asserted. The CMFP responds to the IACK signal by placing a vector number on the lower eight bits of the data bus. This vector number corresponds to the IRQ handler for the particular interrupt requesting service. The format of this vector number is given in Figure 3-1.

When the CMFP asserts DTACK to indicate that valid data is on the bus, the processor will latch the data and terminate the bus cycle by negating DS. When either DS or IACK are negated, the CMFP will terminate the interrupt acknowledge operation by driving DTACK high and placing it in the high-impedance state. Also, the data bus will be placed in the high-impedance state. IRO will be negated as a result of the IACK cycle unless additional interrupts are pending.

The CMFP can be part of a daisy-chain interrupt structure which allows multiple CMFPs to be placed at the same interrupt level by sharing a common IACK signal. A daisy-chain priority scheme is implemented with signals IEI and IEO. IEI indicates that no higher priority device is requesting interrupt service. IEO signals lower priority devices that neither this device nor any higher priority device is requesting service. To daisy-chain CMFPs, the highest priority CMFP has its IEI tied low and successive CMFPs have their IEI connected to the next higher priority device's IEO. Note that when the daisy-chain interrupt structure is not implemented, the IEI of all CMFPs must be tied low. Refer to **3.2** for additional information. When the processor initiates an interrupt acknowledge cycle by driving IACK and DS, the CMFP whose IEI is low may respond with a vector number if an interrupt is pending. If this device does not have a pending interrupt, IEO is asserted which allows the next lower priority device to respond to the interrupt acknowledge. When an CMFP propagates IEO, it will not drive the data bus nor DTACK during the interrupt acknowledge cycle. The timing for an IACK cycle is shown in Figure 2-4. Refer to 7.6 for further information.



#### 2.2.3 Reset Operation

The reset operation will initialize the CMFP to a known state. The reset operation requires that the RESET input be asserted for a minimum of two microseconds. During a device reset condition, all internal CMFP registers are cleared except for the timer data registers (TADR, TBDR, TCDR, and TDDR), the USART data register (UDR), the transmitter status register (TSR) and the interrupt vector register. All timers are stopped and the USART receiver and transmitter are disabled. The interrupt channels are also disabled and any pending interrupts are cleared. In addition, the general purpose interrupt I/O lines are placed in the high-impedance input mode and the timer outputs are driven low. External CMFP signals are negated. The interrupt vector register is initialized to a \$0F.

#### 2.2.4 Non Multiplexed mode

In this mode the MPX input must be set to zero, and the TS68HC901 can be used with a 68000 processor type or a 6800 processor type. Refer to figure 7-4, 7-5, 7-8 for the electrical characteristics.

With a 6800 processor type the  $\overline{\text{DS}}$  pin is connected to the E signal of the processor, the  $\overline{\text{DTACK}}$  signal is not used and the CLK must be zeroed.

4-71

#### 2.2.5 Multiplexed mode

The CMFP can be used either on a MOTOROLA or INTEL bus type. In this case the MPX pin is connected to  $V_{CC}$ . The following table gives the signification of the different signals used. A dummy access to the TS68HC901 has to be done before any valid access in order to set up the internal logic of sampling.

| <br>Pin | MOTOROLA        | MOTOROLA          | INTEL     |
|---------|-----------------|-------------------|-----------|
| <br>48  | 6800 type<br>CS | Multiplexed<br>CS | <u>CS</u> |
| 47      | E               | DS                | RD        |
| 1       | R∕₩             | R/W               | WR        |
| 35      | ∨ <sub>SS</sub> | AS                | ALE       |

4-72

### SECTION 3 INTERRUPT STRUCTURE

In a 68000 system, the CMFP will be assigned to one of the seven possible interrupt levels. All interrupt service requests from the CMFP's 16 interrupt channels will be presented at this level. Although, as an interrupt controller, the CMFP will internally prioritize its 16 interrupt sources. Additional interrupt sources may be placed at the same interrupt level by daisy-chaining multiple CMFPs. The CMFPs will be prioritized by their position in the chain.

1 1

N N

#### 3.1 INTERRUPT PROCESSING

Each CMFP provides individual interrupt capability for its various functions. When an interrupt is received on one of the external interrupt channels or from one of the eight internal sources, the CMFP will request interrupt service. The 16 interrupt channels are assigned a fixed priority so that multiple pending interrupts are serviced according to their relative importance. Since the CMFP can internally generate 16 vector numbers, the unique vector number which corresponds to the highest priority channel that has a pending interrupt is presented to the processor during an interrupt acknowledge cycle. This unique vector number allows the processor to immediately begin execution of the interrupt handler for the interrupting source, decreasing interrupt latency time.

#### 3.1.1 Interrupt Channel Prioritization

The 16 interrupt channels are prioritized as shown in Table 3-1. General purpose interrupt 7 (17) is the highest priority interrupt channel and 10 is the lowest priority channel. Pending interrupts are presented to the CPU in order of priority unless they have been masked off. By selectively masking interrupts, the channels are in effect re-prioritized.

| Priority | Channel | Description                      |
|----------|---------|----------------------------------|
| Highest  | 1111    | General Purpose Interrupt 7 (17) |
|          | 1110    | General Purpose Interrupt 6 (I6) |
|          | 1101    | Timer A                          |
|          | 1100    | Receiver Buffer Full             |
|          | 1011    | Receive Error                    |
|          | 1010    | Transmit Buffer Empty            |
|          | 1001    | Transmit Error                   |
|          | 1000    | Timer B                          |
|          | 0111    | General Purpose Interrupt 5 (15) |
|          | 0110    | General Purpose Interrupt 4 (14) |
|          | 0101    | Timer C                          |
|          | 0100    | Timer D                          |
|          | 0011    | General Purpose Interrupt 3 (I3) |
|          | 0010    | General Purpose Interrupt 2 (12) |
|          | 0001    | General Purpose Interrupt 1 (i1) |
| Lowest   | 0000    | General Purpose Interrupt 0 (10) |

#### Table 3-1. Interrupt Channel Prioritization

4-73

#### 3.1.2 Interrupt Vector Number Format

7

6

5

During an interrupt acknowledge cycle, a unique 8-bit vector number is presented to the system which corresponds to the specific interrupt source which is requesting service. The format of the vector is shown in Figure 3-1. The most significant four bits of the interrupt vector number are user programmable. These bits are set by writing the upper four bits of the vector register which is shown in Figure 3-2. The low order bits are generated internally by the TS68HC901. Note that the binary channel number shown in Table 3-1 corresponds to the low order bits of the vector number associated with each channel.

3

4

| √3-1V0 -<br>¢ | These bits are<br>channel that is ri | supplied bi<br>equesting in<br>Figure 3 | iterrupt ser               | VICE            |                         |                          | inel numt   | per of the hig | hest pr |
|---------------|--------------------------------------|-----------------------------------------|----------------------------|-----------------|-------------------------|--------------------------|-------------|----------------|---------|
|               | 7                                    | 6                                       | 5                          | 4               | 3                       | 2                        | 1           | 0              |         |
| Addre<br>(He  |                                      |                                         | V5                         | V4 [            | S                       | *                        | •           | •              |         |
| 7-V4          | The upper four significant four      | bits of the                             | interrupt v<br>vrites a on | ector num)<br>e | tten by the<br>ber.     | e user. The              | se bits bec | ome the most   |         |
|               | SET<br>CLEARED                       | a) MPU v<br>b) Reset                    |                            |                 |                         |                          |             |                |         |
|               |                                      | b) Reset<br>gister Ena<br>upt mode a    | ble. Whe<br>nd the in-     | service re      | gister bit<br>d-of-inte | s are force<br>rrupt moe | de and th   | ie in-Service  |         |

2

0

1

Figure 3-2 Vector Register Format (VR)

#### 3.2 DAISY-CHAINING CMFPs

As an interrupt controller, the TS68HC901 CMFP will support eight external interrupt sources in addition to its eight internal interrupt sources. When a system requires more than eight external interrupt sources to be placed at the same interrupt level, sources may be added to the prioritized structure by daisy-chaining CMFPs. Interrupt sources are prioritized internally within each CMFP and the CMFPs are prioritized by their position in the chain. Unique vector numbers are provided for each interrupt source.

The IEI and IEO signals implement the daisy-chained interrupt structure. The IEI of the highest priority CMFP is tied low and the IEO output of this device is tied to the next highest priority CMFP's IEI. The IEI and IEO signals are daisy-chained in this manner for all CMFPs in the chain, with the lowest priority CMFP's IEO left unconnected. A diagram of an interrupt daisy-chain is shown in Figure 3-3.

4-74



Figure 3-3. Daisy-Chained Interrupt Structure

Daisy-chaining requires that all parts in the chain have a common IACK. When the common IACK is asserted during an interrupt acknowledge cycle, all parts will prioritize interrupts in parallel. When the IEI signal to a CMFP is asserted, the part may respond to the IACK cycle if it requires interrupt service. Otherwise, the part will assert IEO to the next lower priority device. Thus, priority is passed down the chain via IEI and IEO until a part which has a pending interrupt is reached. The part with the pending interrupt passes a vector number to the processor and does not propagate IEO.

### 3.3 INTERRUPT CONTROL REGISTERS

CMFP interrupt processing is managed by the interrupt enable registers A and B, interrupt pending registers A and B, and interrupt mask registers A and B. These registers allow the programmer to enable or disable individual interrupt channels, mask individual interrupt channels, and access pending interrupt status information. In-service registers A and B allow interrupts to be nested as described in **3.4**. The interrupt control registers are shown in Figure 3-4.

#### 3.3.1 Interrupt Enable Registers

The interrupt channels are individually enabled or disabled by writing a one or zero, respectively, to the appropriate bit of interrupt enable register A (IERA) or interrupt enable register B (IERB). The processor may read these registers at any time.

When a channel is enabled, interrupts received on the channel will be recognized by the CMFP and IRQ will be asserted to the processor, indicating that interrupt service is required. On the other hand, a disabled channel is completely inactive; interrupts received on the channel are ignored by the CMFP.

Writing a zero to a bit of interrupt enable register A or B will cause the corresponding bit of interrupt pending register A or B to be cleared. This will terminate all interrupt service requests for the channel and also negate IRQ, unless interrupts are pending from other sources. Disabling a channel, however, does not affect the corresponding bit in interrupt in-service registers A or B. So, if the CMFP is in the software end-of-interrupt mode (see 3.4.3) and an interrupt is in service when a channel is disabled, the in-service status bit for that channel will remain set until cleared by software.

4-75

#### (a) Interrupt Enable Registers (IERA and IERB)

Ξ, · 2

Parteration of the second

and the second

ALC: NO

2

N IN IN

÷,

.7

. 7

|                     | 7     | 6     | 5          | 4                     | 3            | 2                       | 1             | 0          |
|---------------------|-------|-------|------------|-----------------------|--------------|-------------------------|---------------|------------|
| Address 07<br>(Hex) | GPIP7 | GPIP6 | Timer<br>A | RCV<br>Buffer<br>Full | RCV<br>Error | XMIT<br>Buffer<br>Empty | XMIT<br>Error | Timer<br>B |
|                     |       |       |            | L = =                 |              |                         |               |            |
|                     | 7     | 6     | 5          | 4                     | 3            | 2                       | 1             | 0          |
| Address 09<br>(Hex) | GPIP5 | GPIP4 | Timer<br>C | Timer<br>D            | GPIP3        | GPIP2                   | GPIP1         | GPIP0      |

When a bit is a zero, the associated interrupt channel is disabled. When a bit is a one, the associated interrupt channel is enabled.

SET a) MPU writes a one

a) MPU writes a zero CLEARED

b) Reset

(b) Interrupt Pending Registers (IPRA and IPRB)

|                     | 7     | 6     | 5          | 4                     | 3            | 2                       | 1             | 0          |
|---------------------|-------|-------|------------|-----------------------|--------------|-------------------------|---------------|------------|
| Address 0B<br>(Hex) | GPIP7 | GPIP6 | Timer<br>A | RCV<br>Buffer<br>Full | RCV<br>Error | XMIT<br>Buffer<br>Empty | XMIT<br>Error | Timer<br>B |
| ı                   |       |       |            |                       |              |                         |               |            |
|                     | 7     | 6     | 5          | 4                     | 3            | 2                       | 1             | 0          |
| Address 0D<br>(Hex) | GPIP5 | GPIP4 | Timer<br>C | Timer<br>D            | GPIP3        | GPIP2                   | GPIP1         | GPIP0      |

When a bit is a zero, no interrupt is pending on the associated interrupt channel. When a bit is a one, an interrupt is pending on the associated interrupt channel

a) Interrupt is received on an enabled interrupt channel SET a) Interrupt vector for the associated interrupt channel is passed during an IACK cycle

CLEARED

b) Associated interrupt channel is disabled

c) MPU writes a zero

d) Reset

#### 2 0 1 4 3 6 5 7 XMIT RCV Address OF XMIT Timer RCV Buffer Timer Buffer (Hex) Error Empty Error В GPIP6 Full GPIP7 А 0 2 1 3 4 6 5 7 Timer Timer Address 11 GPIP0 GPIP2 GPIP1 GPIP3 GPIP5 GPIP4 С D (Hex)

(c) Interrupt In-Service Registers (ISRA and ISRB)

When a bit is a zero, no interrupt processing is in progress for the associated interrupt channel. When a bit is a one, interrupt processing is in progress for the associated interrupt channel.

a) Interrupt vector number for the associated interrupt channel is passed during an IACK SET cycle and the S bit of the vector register is set.

a) Interrupt service is completed for the associated interrupt channel

CLEARED

b) The S bit of the vector register is a zero.

c) MPU writes a zero

d) Reset



4-76

(d) Interrupt Mask Registers (IMRA and IMRB)

г. 12

1.1

11.43

1.11.1

11 IV.

M In Ib

3



When a bit is zero, interrupts are masked for the associated interrupt channel. When a bit is a one, interrupts are not masked for the associated interrupt channel. SET a) MPU writes a one

CLEARED a) MPU write

 a) MPU writes a zero b) Reset



#### 3.3.2 Interrupt Pending Registers

When an interrupt is received on an enabled channel, the corresponding interrupt pending bit is set in interrupt pending register A or B (IPRA or IPRB). In a vectored interrupt scheme, this bit will be cleared when the processor acknowledges the interrupting channel and the CMFP responds with a vector number. In a polled interrupt system, the interrupt pending registers must be read to determine the interrupting channel and then the interrupt pending bit is cleared by the interrupt handling routine without performing an interrupt acknowledge sequence.

A single bit of the interrupt pending registers is cleared in software by writing ones to all bit positions except the bit to be cleared. Note that writing ones to IPRA and IPRB has no effect on the contents of the register. A single bit of the interrupt pending registers is also cleared when the corresponding channel is disabled by writing a zero to the appropriate bit of IERA or IERB.

#### 3.3.3 Interrupt Mask Registers

Interrupts are masked for a channel by clearing the appropriate bit in interrupt mask register A or B (IMRA or IMRB). Even though an enabled channel is masked, the channel will recognize subsequent interrupts and set its interrupt pending bit. However, the channel is prevented from requesting interrupt service (IRQ to the processor) as long as the mask bit for that channel is cleared.

If a channel is requesting interrupt service at the time that its corresponding bit in IMRA or IMRB is cleared, the request will cease and IRQ will be negated, unless another channel is requesting interrupt service. Later, when the mask bit is set, any pending interrupt on the channel will be processed according to the channel's assigned priority. IMRA and IMRB may be read at any time.

#### 3.4 NESTING CMFP INTERRUPTS

In a 68000 vectored interrupt system, the CMFP is assigned to one of seven possible interrupt levels. When an interrupt is received from the CMFP, an interrupt acknowledge for that level is initiated. Once an interrupt is recognized at a particular level, interrupts at that same level or

4-77

below are masked by 68000. As long as the processor's interrupt mask is unchanged, the 68000 interrupt structure will prohibit the nesting of interrupts at the same interrupt level. However, additional interrupt requests from the CMFP can be recognized before a previous channel's interrupt service routine is completed by lowering the processor's interrupt mask to the next lower interrupt level within the interrupt handler.

When nesting CMFP interrupts, it may be desirable to permit interrupts on any CMFP channel, regardless of its priority, to preempt or delay interrupt processing of an earlier channel's interrupt service request. Or, it may be desirable to only allow subsequent higher priority channel interrupt requests to supercede previously recognized lower priority interrupt requests. The CMFP interrupt structure provides this flexibility by offering two end-of-interrupt options for vectored interrupt schemes. Note that the end-of-interrupt modes are not active in a polled interrupt scheme.

### 3.4.1 Selecting The End-Of-Interrupt Mode

In a vectored interrupt scheme, the CMFP may be programmed to operate in either the automatic end-of-interrupt mode or the software end-of-interrupt mode. The mode is selected by writing the S bit of the vector register (see Figure 3-2). When the S bit is programmed to a one, the CMFP is placed in the software end-of-structure mode and when the S bit is a zero, all channels operate in the automatic end-of-interrupt mode.

#### 3.4.2 Automatic End-Of-Interrupt

When an interrupt vector number is passed to the processor during an interrupt acknowledge cycle, the corresponding channel's interrupt pending bit is cleared. In the automatic end-of-interrupt mode, no further history of the interrupt remains in the CMFP. The in-service bits of the interrupt in-service registers (ISRA and ISRB) are forced low. Subsequent interrupts which are received on any CMFP channel will generate an interrupt request to the processor, even if the current interrupt's service routine has not been completed.

#### 3.4.3 Software End-Of-Interrupt

In the software end-of-interrupt mode, the channel's associated interrupt pending bit is cleared and in addition, the channel's in-service bit of in-service register A or B is set when its vector number is passed to the processor during an IACK cycle. A higher priority channel may subsequently request interrupt service and be acknowledged, but as long as the channel's in-service bit is set, no lower priority channel may request interrupt service nor pass its vector during an interrupt acknowledge sequence.

While only higher priority channels may request interrupt service, any channel can receive an interrupt and set its interrupt pending bit. Even the channel whose in-service bit is set can receive a second interrupt. However, no interrupt service request is made until its in-service bit is cleared.

The in-service bit for a particular channel can be cleared by writing a zero to its corresponding bit in ISRA or ISRB and ones to all other bit positions. Since bits in the in-service registers can only be cleared in software and not set, writing ones to the registers does not alter their contents. ISRA and ISRB may be read at any time.

4-78

### SECTION 4 GENERAL PURPOSE INPUT/OUTPUT INTERRUPT PORT

The general purpose interrupt input/output (I/O) port (GPIP) provides eight I/O lines (I0 through I7) that may be operated as either inputs or outputs under software control. In addition, these lines may optionally generate an interrupt on either a positive transition or a negative transition of the input signal. The flexibility of the GPIP allows it to be configured as an 8-bit I/O port or for bit I/O. Since interrupts are enabled on a bit-by-bit basis, a subset of the GPIP could be programmed as handshake lines or the port could be connected to as many as eight external interrupt sources, which would be prioritized by the CMFP interrupt controller for interrupt service.

#### 4.1 6800 INTERRUPT CONTROLLER

The CMFP interrupt controller is particularly useful in a system which has many 6800-type devices. Typically, in a vectored 68000 system, 6800-type peripherals use the autovector which corresponds to their assigned interrupt level since they do not provide a vector number in response to an IACK cycle. The autovector interrupt handler must then poll all 6800-type devices at that interrupt level to determine which device is requesting service. However, by tying the IRQ output from a 6800-type device to the general purpose I/O interrupt port (GPIP) of a CMFP, a unique vector number will be provided to the processor during an interrupt acknowledge cycle. This interrupt structure will significantly reduce interrupt latency for 6800-type devices and other peripheral devices which do not support vector-by-device.

#### 4.2 GPIP CONTROL REGISTERS

The GPIP is programmed via three control registers shown in Figure 4-1. These registers control the data direction, provide user access to the port, and specify the active edge for each bit of the GPIP which will produce an interrupt. These registers are described in detail in the following paragraphs.

COLUMN 1

M In Ib

#### 4.2.1 GPIP Data Register

The general purpose I/O data register is used to input or output data to the port. When data is written to the GPIP data register, those pins which are defined as inputs will remain in the highimpedance state. Pins which are defined as outputs will assume the state (high or low) of their corresponding bit in the data register. When the GPIP is read, data will be passed directly from the bits of the data register for pins which are defined as outputs. Data from pins defined as inputs will come from the input buffers.

#### 4.2.2 Active Edge Register

The active edge register (AER) allows each of the GPIP lines to produce an interrupt on either a one-to-zero or a zero-to-one transition. Writing a zero to the appropriate edge bit of the active edge



г. 12

æ

1.91111111

8 12 2

ы и



Figure 4-1. GPIP Control Registers

register causes the associated input to generate an interrupt on the one-to-zero transition. Writing a one to the edge bit will produce an interrupt on the zero-to-one transition of the corresponding GPIP line.

**Note:** The transition detector is an exclusive-OR gate whose inputs are the edge bit and the input buffer. As a result, writing the AER may cause an interrupt-producing transition, depending upon the state of the input. So, the AER should be configured before enabling interrupts via the interrupt enable registers (IERA and IERB). Also, changing the edge bit while interrupts are enabled may cause an interrupt on the corresponding channel.

#### 4.2.3 Data Direction Register

The data direction register (DDR) allows the programmer to define I0 through I7 as inputs or outputs by writing the corresponding bit. When a bit of the data direction register is written as a zero; the corresponding interrupt I/O pin will be a high-impedance input. Writing a one to any bit of the data direction register will cause the corresponding pin to be configured as a push-pull output.

4-80

### SECTION 5 TIMERS

The CMFP contains four 8-bit timers which provide many functions typically required in microprocessor systems. The timers can supply the baud rate clocks for the on-chip serial I/O channel, generate periodic interrupts, measure elapsed time, and count signal transitions. In addition, two timers have waveform generation capability.

All timers are prescaler/counter timers with a common independent clock input (XTAL1 or XTAL2) and are not required to be operated from the system clock. Each timer's output signal toggles when the timer's main counter times out. Additionally, timers A and B have auxiliary control signals which are used in two of the operation modes. An interrupt channel is assigned to each timer and when the auxiliary control signals are used, a separate interrupt channel will respond to transitions on these inputs.

#### 5.1 OPERATION MODES

Timers A and B are full function timers which, in addition to the delay mode, operate in the pulse width measurement mode and the event count mode. Timers C and D are delay timers only. A brief discussion of each of the timer modes follows.

#### 5.1.1 Delay Mode Operation

All timers may operate in the delay mode. In this mode, the prescaler is always active. The prescaler specifies the number of timer clock cycles which must elapse before a count pulse is applied to the main counter. A count pulse causes the main counter to decrement by one. When the timer has decremented down to 01 (hexadecimal), the next count pulse will cause the main counter to be reloaded from the timer data register and a time out pulse will be produced. This time out pulse is coupled to the timer's interrupt channel and, if the channel is enabled, an interrupt will occur. The time out pulse also causes the timer output pin to toggle. The output will remain in this new state until the next time out pulse occurs.

1.41.71

8 12

.

N In

For example, if delay mode with a divide-by-10 prescaler is selected and the timer data register is loaded with 100 (decimal), the main counter will decrement once every 10 timer clock cycles. After 1,000 timer clocks, a time out pulse will be produced. This time out pulse will generate an interrupt if the channel is enabled (IERA, IERB) and in addition, the timer's output line will toggle. The output line will complete one full period every 2,000 cycles of the timer clock.

If the prescaler value is changed while the timer is enabled, the first time out pulse will occur at an indeterminate time no less than one nor more than 200 timer clock cycles. Subsequent time out pulses will then occur at the correct interval.

If the main counter is loaded with 01 (hexadecimal), a time out pulse will occur every time the prescaler presents a count pulse to the main counter. If the main counter is loaded with 00, a time out pulse will occur every 256 count pulses.

#### 5.1.2 Pulse Width Measurement Operation

Besides the delay mode, timers A and B may be programmed to operate in the pulse width measurement mode. In this mode an auxiliary control input is required; timers A and B auxiliary input lines are TAI and TBI. Also, in the pulse width measurement mode, interrupt channels normally associated with I4 and I3 will respond to transitions on TAI and TBI, respectively. General purpose lines I3 and I4 may still be used for I/O. A conceptual circuit of the timers in the pulse width measurement mode is shown in Figure 5-1.

1.11.1



# Figure 5-1. Conceptual Circuit of Timers A and B in Pulse Width Measurement Mode

The pulse width measurement mode functions similarly to the delay mode, with the auxiliary control signal acting as an enable to the timer. When the control signal is active, the prescaler and main counter are allowed to operate. When the control signal is negated, the timer is stopped. So, the width of the active pulse on TAI or TBI is measured by the number of timer counts which occur while the timer is allowed to operate.

The active state of the auxiliary input line is defined by the associated interrupt channel's edge bit in the active edge register (AER). GPIP4 of the AER is the edge bit associated with TAI and GPIP3 is associated with TBI. When the edge bit is a one, the auxiliary input will be active high, enabling the timer while the input signal is at a high level. If the edge bit is low, the auxiliary input will be active high edge be active high end the input signal is at a high level. If the edge bit is low, the auxiliary input will be active high edge be active.

4-82

The state of the active edge bit also specifies whether a zero-to-one transition or a one-to-zero transition of the auxiliary input pin will produce an interrupt when the interrupt channel is enabled. In normal operation, programming the active edge bit to a one will produce an interrupt on the zeroto-one transition of the associated input signal. Alternately, programming the edge bit to a zero will produce an interrupt on the one-to-zero transition of the input signal. However, in the pulse width measurement mode, the interrupt generated by a transition on TAI or TBI will occur on the opposite transition as that normally defined by the edge bit.

e

and the second

COLUMN 1

 $\geq$ 

M In Ib

Ę

а .т

For example, in the pulse width measurement mode, if the edge bit is a one, the timer will be allowed to run while the auxiliary input TAI is high. When TAI transitions from high to low, the timer will stop and, if the interrupt channel is enabled, an interrupt will occur. By having the interrupt occur on the one-to-zero transition instead of the zero-to-one transition, the processor will be interrupted when the pulse being measured has terminated and the width of the pulse is available from the timer. Therefore, the timers act like a divide-by-prescaler that can be programmed by the timer data register and the timers' A and B control register.

After reading the contents of the timer, the main counter must be reinitialized by writing to the timer data register to allow consecutive pulses to be measured. If the timer is written after the auxiliary input signal is active, the timer will count from the previous contents of the timer data register until it counts through 01 (hexadecimal). At that time, the main counter is loaded with the new value from the timer data register, a time out pulse is generated which will toggle the timer output, and an interrupt may be optionally generated on the timer interrupt channel. Note that the pulse width measured will include counts from before the main counter was reloaded. If the timer data register is written while the pulse is transitioning to the active state, an indeterminate value may be written into the main counter.

Once the timer is reprogrammed for another mode, interrupts will again occur as normally defined by the edge bit. Note that an interrupt may be generated as the result of placing the timer into the pulse width measurement mode or by reprogramming the timer for another mode. Also, an interrupt may be generated by changing the state of the edge bit while in the pulse width measurement mode.

#### 5.1.3 Event Count Mode Operation

In addition to the delay mode and the pulse width measurement mode, timers A and B may be programmed to operate in the event count mode. Like the pulse width measurement mode, the event count mode also requires an auxiliary input signal, TAI or TBI, and the interrupt channels normally associated with I4 and I3 will respond to transitions on TAI and TBI, respectively. General purpose lines I3 and I4 still function normally.

In the event count mode the prescaler is disabled, allowing each active transition on TAI and TBI to produce a count pulse. The count pulse causes the main counter to decrement by one. When the timer counts through 01 (hexadecimal), a time out pulse is generated which will cause the output signal to toggle and may optionally produce an interrupt via the associated timer interrupt channel. The timer's main counter is also reloaded from the timer data register. To count transitions reliably, the input signal may only transition once every four timer clock periods. For this reason, the input signal must have a maximum frequency equal to one-fourth that of the timer clock.

4-83

The active edge of the auxiliary input signal is defined by the associated interrupt channel's edge bit. GPIP4 of the AER specifies the active edge for TAI and GPIP3 defines the active edge for TBI. When the edge bit is programmed to a one, a count pulse will be generated on the zero-to-one transition of the auxiliary input signal. When the edge bit is programmed to a zero, a count pulse will be generated on the one-to-zero transition. Also, note that changing the state of the edge bit while the timer is in the event count mode may produce a count pulse.

л, га

1.9.1.1.1.1.1

• •

COLUMN CONTROL

 $\geq$ 

2

N IN IN

R,

л л

\_

Besides generating a count pulse, the active transition of the auxiliary input signal will also produce an interrupt on the I3 or I4 interrupt channel, if the interrupt channel is enabled. Typically, in the event count mode, these channels are not enabled since the timer is automatically counting transitions on the input signal. If the interrupt channel were enabled, the number of transitions could be counted in the interrupt routine without requiring the use of the timer.

#### 5.2 TIMER REGISTERS

The four timers are programmed via three control registers and four timer data registers. Control registers TACR and TBCR and timer data registers TADR and TBDR (refer to Figure 5-1) are associated with timers A and B respectively. Timers C and D are controlled by the control register TCDCR and the data registers TCDR and TDDR (refer to Figure 5-2).



(a) Timer A Data Register (TADR)

4-84

#### 5.2.1 Timer Data Registers

Each timer's main counter is an 8-bit binary down counter. The value of the main counter may be read at any time by reading the timer's data register. The information read is the value of the counter which was captured on the last low-to-high transition of the DS pin.

The main counter is initialized by writing to the timer's data register. If the timer is stopped, data is loaded simultaneously into both the timer data register and the main counter. If the timer data register is written while the timer is enabled, the value is not loaded into the timer until the timer counts through 01 (hexadecimal). Writing the timer data register while the timer is counting through 01 (hexadecimal) will cause an indeterminate value to be loaded into the timer's main counter. The four data registers are shown in Figure 5-2.

#### 5.2.2 Timer Control Registers

Bits in the timer control registers select the operation mode, select the prescale value, and disable the timers. Timer control registers TACR and TBCR also have bits which allow the programmer to reset output lines TAO and TBO. These control registers are shown in Figure 5-3.

1.911.111.111

and the second

1.11.1

11 N/

2

N In

R,

л л



AC3-AC0, BC3-BC0 These bits are decoded to determine the timer operation mode.

Figure 5-3. Timer Control Registers (Sheet 1 of 2)



| AC3<br>BC3 | AC2<br>BC2 | AC1<br>BC1                              | AC0<br>BC0 | Operation Mode                               |
|------------|------------|-----------------------------------------|------------|----------------------------------------------|
| 0          | 0          | 0                                       | 0          | Timer Stopped*                               |
| ň          | ō          | 0                                       | 1          | Delay Mode, + 4 Prescaler                    |
| ň          | ñ          | 1                                       | 0          | Delay Mode, + 10 Prescaler                   |
| ñ          | õ          | 1                                       | 1          | Delay Mode, + 16 Prescaler                   |
| ñ          | 1          | Ó                                       | 0          | Delay Mode, + 50 Prescaler                   |
| õ          | 1          | õ                                       | 1          | Delay Mode, + 64 Prescaler                   |
| 0          | 1          | 1                                       | 0          | Delay Mode, + 100 Prescaler                  |
| 0          | 1          | 1                                       | 1          | Delay Mode, + 200 Prescaler                  |
| 1          | ņ          | ò                                       | Ó          | Event Count Mode                             |
| 1          | ő          | õ                                       | 1          | Pulse Width Mode, + 4 Prescaler              |
| •          | ŏ          | ĩ                                       | 0          | Pulse Width Mode, + 10 Prescaler             |
| 1          | õ          | 1                                       | 1          | Pulse Width Mode, + 16 Prescaler             |
|            | 1          | ò                                       | Ó          | Pulse Width Mode, + 50 Prescaler             |
| 4          | 1          | õ                                       | 1          | Pulse Width Mode, 🛨 64 Prescaler             |
| 1          | 1          | 1                                       | Ó          | Pulse Width Mode, + 100 Prescaler            |
| 1          | 1          | 1                                       | 1          | Pulse Width Mode, + 200 Prescaler            |
| - F        |            | , , , , , , , , , , , , , , , , , , , , |            | ounting is inhibited when the timer is stop- |

\* Regardless of the operation mode, counting is inhibited when the timer is stopped. The contents of the timer's main counter is not affected, although any residual count in the prescaler is lost.

| SET     | <ul> <li>a) MPU writes a one</li> </ul>  |
|---------|------------------------------------------|
| CLEARED | <ul> <li>a) MPU writes a zero</li> </ul> |
|         | b) Reset                                 |

#### (c) Timers C and D Control Register (TCDCR)

|            | 7      | 6           | 5       | 4   | 3 | 2   | 1   | 0   |
|------------|--------|-------------|---------|-----|---|-----|-----|-----|
| Address 1D | *      | CC2         | CC1     | CC0 | * | DC2 | DC1 | DC0 |
| (Hex)      | Unused | bits read a | is zero |     |   |     |     |     |

CC2-CC0, DC2-DC0 The bits are decoded to determine the timer operation mode.

| CC2<br>DC2 | CC1<br>DC1 | CC0<br>DC0 | Operation Mode                            |
|------------|------------|------------|-------------------------------------------|
| 0          | 0          | 0          | Timer Stopped*                            |
| 0          | õ          | 1          | Delay Mode, ÷ 4 Prescaler                 |
| 0          |            | 0          | Delay Mode, ÷ 10 Prescaler                |
| 0          | 1          | •          | Delay Mode, ÷ 16 Prescaler                |
| 0          | 1          | 1          |                                           |
| 1          | 0          | 0          | Delay Mode, ÷ 50 Prescaler                |
| 1          | 0          | 1          | Delay Mode, ÷ 64 Prescaler                |
| 1          | 1          | 0          | Delay Mode, ÷ 100 Prescaler               |
| 1          | 1          | 1          | Delay Mode, ÷ 200 Prescaler               |
|            | •          |            | success to The second and the time of the |

\*When the timer is stopped, counting is inhibited. The contents of the timer's main counter is not affected, although any residual count in the prescaler is lost.

| SET     | <ul> <li>a) MPU writes a one</li> </ul>  |
|---------|------------------------------------------|
| CLEARED | <ul> <li>a) MPU writes a zero</li> </ul> |
|         | b) Reset                                 |

## Figure 5-3. Timer Control Registers (Sheet 2 of 2)

4-86

### This Material Copyrighted By Its Respective Manufacturer

л. 12

Parteration of the second

### SECTION 6 UNIVERSAL SYNCHRONOUS/ASYNCHRONOUS RECEIVER-TRANSMITTER

The universal synchronous/asynchronous receiver-transmitter (USART) is a single full-duplex serial channel with a double-buffered receiver and transmitter. There are separate receive and transmit clocks and separate receive and transmit status and data bytes. The receive and transmit sections are also assigned separate interrupt channels. Each section has both a normal condition interrupt channel and an error condition interrupt channel. These channels can be optionally disabled from interrupting the processor and instead, DMA transfers can be performed using the receiver ready and transmitter ready external CMFP signals.

#### 6.1 CHARACTER PROTOCOLS

The CMFPUSART supports asynchronous and with the aid of a polynomial generator checker (PGC) supports byte synchronous character formats. These formats are selected independently of the divide-by-one and divide-by-16 clock modes.

When the divide-by-one clock mode is selected, synchronization must be accomplished externally. The receiver will sample the serial data on the rising edge of the receiver clock. In the divide-by-16 clock mode, the data is sampled at mid-bit time to increase transient noise rejection.

Also, when the divide-by-16 clock mode is selected, the USART resynchronization logic is enabled. This logic increases the channel's clock skew tolerance. When a valid transition is detected, an internal counter is reset to state zero. Transition checking is then inhibited until state four. Then at state eight, the previous state of the transition checking logic is clocked into the receive shift register.

#### 6.1.1 Asynchronous Format

Variable word length and start/stop bit configurations are available under software control for asynchronous operation. The word length can be five to eight bits and one, one and one-half, or two stop bits can be selected. The user can also select odd, even, or no parity. For character lengths of less than eight bits, the assembled character will consist of the required number of data bits followed by zeros in the unused bit positions and a parity bit, if parity is enabled. THE LET IN T

N M

In the asynchronous format, start bit detection is always enabled. New data is not shifted into the receive shift register until a zero bit is received. When the divide-by-16 clock mode is selected, the false start bit logic is also active. Any transition must be stable for three positive receive clock edges to be considered valid. Then a valid zero-to-one transition must not occur for at least eight additional positive clock edges.

**6.1.1.1 WAKE-UP FEATURE.** In a typical serial loop multiprocessor configuration, the software protocol will usually identify the addressee(s) at the beginning of the message. In order to permit uninterested MPUs to ignore the remainder of the message, wake-up feature is included whereby all further USART receiver flag (and interrupt) processing can be inhibited until its data line goes idle. An USART receiver is re-enabled by an idle string of ten consecutive ones or during reset. Software must provide for the required idle string between consecutive messages and prevent it within messages.

4-87

#### 6.1.2 Synchronous Format

When the synchronous character format is selected, the 8-bit synchronous character loaded into the synchronous character register is compared to received serial data until a match is found. Once synchronization is established, incoming data is clocked into the receiver. The synchronous word will be continuously transmitted during an underrun condition. All synchronous characters can be optionally stripped from the receive buffer. Figure 6-1 shows the synchronous character register.



i T

3



The synchronous character is typically written after the data word length is selected, since unused bits in the synchronous character register are zeroed out. When parity is enabled, synchronous word length is the data word length plus one. The CMFP will compute and append the parity bit for the synchronous word when a word length of eight is selected. However, if the word length is less than eight, the user must determine the synchronous word parity and write it into the synchronous character register along with the synchronous character. The CMFP will then transmit the extra bit in the synchronous word as a parity bit.

#### 6.1.3 USART Control Register

The USART control register (UCR) selects the clock mode and the character format for the receive and transmit sections. This register is shown in Figure 6-2.

#### 6.2 RECEIVER

As data is received on the serial input line (SI), it is clocked into an internal 8-bit shift register until the specified number of data bits have been assembled. This character will then be transferred to the receive buffer, assuming that the last word in the receiver buffer has been read. This transfer produces a buffer full interrupt to the processor.

Reading the receive buffer satisfies the buffer full condition and allows a new data word to be transferred to the receive buffer when it is assembled. The receive buffer is accessed by reading the USART data register (UDR). The UDR is simply an 8-bit data register used when transferring data from the CMFP and the CPU.

Each time a word is transferred to the receive buffer, its status information is latched into the receiver status register (RSR). The RSR is not updated again until the data word in the receive buffer has been read. When a buffer full condition exists, the RSR should always be read before the receive buffer (UDR) to maintain the correct correspondance between data and flags. Otherwise, it is possible that after reading the UDR and prior to reading the RSR, a new word could be received and transferred to the receive buffer. Its associated flags would be latched into the RSR, overwriting the flags for the previous data word. Then when the RSR were read to access the status information for the first data word, the flags for the new word would be retrieved.

4-88

| Address 29 | 7   | 6   | 5   | 4   | 3   | 2  | 1   | 0  |   |
|------------|-----|-----|-----|-----|-----|----|-----|----|---|
| (Hex)      | CLK | WL1 | WLO | ST1 | STO | PE | E/O | WU | ] |

CLK Clock Mode. When this bit is zero, data will be clocked into and out of the receiver and transmitter at the frequency of their respective clocks. When this bit is a one, data will be clocked into and out of the receiver and transmitter at one sixteenth the frequency of their respective clocks. Also, the receiver data transition resynchronization logic will be enabled.

SET • ÷ 16 a) MPU writes a one CLEARED • ÷ 1 a) MPU writes a zero b) Reset

WL0, WL1 Word Length. These two bits specify the length of the data word exclusive of start bits, stop bits, and parity.

| <u>WL1</u> | WLO           | Word Length |
|------------|---------------|-------------|
| 0          | 0             | 8 Bits      |
| 0          | 1             | 7 Bits      |
| 1          | 0             | 6 Bits      |
| 1          | 1             | 5 Bits      |
| SET        | a) MPU writes | a one       |
| CLEARED    | a) MPU writes | a zero      |
|            | b) Reset      |             |

ST0, ST1 Start/Stop Bit and Format Control. These two bits select the number of start and stop bits and also specify the character format.

| ST1 | STO | Start Bits | Stop Bits | Format        |
|-----|-----|------------|-----------|---------------|
| 0   | 0   | 0          | 0         | Synchronous   |
| 0   | 1   | 1          | 1         | Asynchronous  |
| 1   | 0   | 1          | 1 1/2     | Asynchronous* |
| 1   | 1   | 1          | 2         | Asynchronous  |

\* Only used with divide-by-16 clock mode

SET a) MPU writes a one CLEARED a) MPU writes a zero b) Reset

- Parity Enable. When this bit is zero, no parity check will be made and no parity bit will be computed for transmission. When this bit is a one, parity will be checked by the receiver and parity will be calculated and inserted during data transmission. Note that parity is not automatically appended to the synchronous character for word lengths of less than eight bits. In this case, the parity should be written into the synchronous character register along with the synchronous word.
  - SET a) MPU writes a one CLEARED a) MPU writes a zero b) Reset

E/O Even/Odd Parity. When this bit is zero, odd parity is selected. When this bit is a one, even parity is selected.
 SET a) MPU writes a one
 CLEARED a) MPU writes a zero
 b) Reset

WU Bit 0 "Wake-up" on idle line. When set, WU enables the wake-up function; it is cleared by ten consecutive ones or during reset. WU will not be set if the line is idle. Refer to 6.1.1.1.

### Figure 6-2. USART Control Register (UCR)

#### 4-89

This Material Copyrighted By Its Respective Manufacturer

ΡE

• •

COLUMN C

 $\geq$ 

2

b b a w w ha ha

л. 12

#### 6.2.1 Receiver Interrupt Channels

The USART receive section is assigned two interrupt channels. One indicates the buffer full condition, while the other channel indicates an error condition. Error conditions include overrun, parity error, synchronous found, and break. These interrupting conditions correspond to the BF, OE, PE, and F/S or B bits of the receiver status register. These flags will function as described in **6.2.2** whether the receiver interrupt channels are enabled or disabled.

æ

ы қ

While only one interrupt is generated per character received, two dedicated interrupt channels allow separate vector numbers to be assigned for normal and abnormal receiver conditions. When a received word has an error associated with it and the error interrupt channel is enabled, an interrupt will be generated on the error channel only. However, if the error channel is disabled, an interrupt for an error condition will be generated on the buffer full interrupt channel along with interrupts produced by the buffer full condition. The receiver status register must always be read to determine which error condition produced the interrupt.

#### 6.2.2 Receiver Status Register

The receiver status register contains the receive buffer full flag, the synchronous strip enable, the receiver enable, and various status information associated with the data word in the receive buffer. The RSR is latched each time a data word is transferred to the receive buffer. RSR flags cannot change again until the data word has been read. The exception is the character in progress flag which monitors when a new word is being assembled in the asynchronous character format. The receiver status register is shown in Figure 6-3.

|    |                                                                       |                                                         | ·                                             |                                                      | r                                                   | F/S                         | [          |             |              | 1                                                                    |
|----|-----------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------|------------------------------------------------------|-----------------------------------------------------|-----------------------------|------------|-------------|--------------|----------------------------------------------------------------------|
|    | Address 28                                                            | BF                                                      | OE                                            | PE                                                   | FE                                                  | or B                        | M/CIP      | SS          | RE           | ]                                                                    |
| BF | receive buffer<br>SET a<br>CLEARED a<br>H                             | is read by<br>a) Receive<br>a) Receive<br>b) Reset      | accessing<br>d word tra<br>buffer rea         | the USAr<br>insferred ti<br>id                       | o buffer                                            |                             |            |             |              | leared when the                                                      |
| OE | receive buffer<br>full condition<br>OE bit is clear<br>SET<br>CLEARED | is full. Nei<br>is satisfied<br>ed by read<br>a) Incomi | ther the re                                   | ceive buffe<br>g the UDR<br>SR: New G<br>sceived and | This erro<br>This erro<br>data words<br>d receive t | r condition<br>s will not b | will gener | ate an inte | errupt to th | ve buffer, but the<br>the receive buffer<br>e processor. The<br>ead. |
| PE | the word tran<br>SET<br>CLEARED                                       | a) Word<br>a) Word<br>a) Word<br>b) Reset               | the receive I<br>in receive I<br>in receive I | e buffer has<br>buffer has<br>buffer doe             | a parity el<br>is not have                          | rror<br>a parity e          | rror       |             |              | it is cleared when                                                   |
| FE | Frame Error.<br>character for<br>cleared wher<br>SET<br>CLEARED       | mat. The f<br>the word                                  | E bit is se<br>transferre<br>in receive       | t when the<br>d to the re<br>buffer has              | eceive buff<br>a frame e                            | fer does no                 | t have a f |             |              | the asynchronous<br>error The FE bit is                              |
|    | Fi                                                                    | gure 6-3                                                | 3. Recei                                      | ver Sta                                              | tus Reg                                             | jister (R                   | SR) (Sł    | neet 1 o    | f 2)         |                                                                      |

4-90

г. 12

| F/S or B | Found/Search or Break Detect. In the synchronous character format this bit can be set or cleared in softwa<br>When the bit is a zero, the USART receiver is placed in the search mode. The incoming data is compared to the s<br>chronous character register (SCR) and the word length counter in death is The Fig. 2.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|          | chronous character register (SCR) and the word length counter is disabled. The F/S bit will automatically be when a match is found and the word length counter will be enabled. An interrupt will also be produced on receive error channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|          | SET a) Incoming word matches synchronous character<br>CLEARED a) MPU writes a zero                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|          | b) Incoming word does not match synchronous character<br>c) Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|          | In the asynchronous character format, this flag indicates a break condition. A break is detected when an all ze data word with no stop bit is received. The break condition continues until a non-zero data bit is received. The B is set when the word transferred to the receive buffer is a break indication. A break condition generates an interrut to the processor. This bit is cleared when a non-zero data bit is received and the break condition has been acknowledged by reading the RSR at least once. An end of break interrupt will be generated when the bit is cleared. SET a) Word in receive buffer is a break. CLEARED a) Break terminates and receiver status register read since beginning of break condition. |  |  |  |  |  |  |
| M or CIP | Match/Character in Progress. In the synchronous character format, this flag indicates that a synchronous character has been received. The M bit is set when the word transferred to the receive buffer matches the synchronous character register. The M bit is cleared when the word transferred to the receive buffer does not match the synchronous character register.                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|          | SET a) Word transferred to receive buffer matches the synchronous character<br>CLEARED a) Word transferred to receive buffer does not match synchronous character<br>b) Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|          | In the asynchronous character format, this flag indicates that a word is being assembled. The CIP bit is set when start bit is detected. The CIP bit is set when SETa). Start bit is detected. CLEAREDa). End of word detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|          | b) Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| SS       | Synchronous Strip Enable. When this bit is a one, data words that match the synchronous character register wind the loaded into the receive buffer and no buffer full condition will be produced. When this bit is a zero data words that match the synchronous character register will be transferred to the receive buffer an a bufferfull condition will be produced.                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|          | SET a) MPU writes a one<br>CLEARED a) MPU writes a zero<br>b) Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| RE       | Receiver Enable. When this bit is a zero, the receiver will be immediately disabled. All flags will be cleared. When this bit is a one, normal receiver operation is enabled. This bit should not be set to a one until the receiver olock is active.<br>SET a) MPU writes a one.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|          | <ul> <li>b) Transmitter is disabled in auto-turnaround mode</li> <li>CLEARED a) MPU writes a zero</li> <li>b) Reset</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|          | Figure 6-3. Receiver Status Register (RSR) (Sheet 2 of 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |

Certain receive conditions relating to the overrun error flag and the break detect flag require further explanation. Consider the following examples:

- A break is received while the receive buffer is full. This does not produce an overrun condition. Only the B flag will be set after the receiver buffer is read.
- 2) A new word is received and the receive buffer is full. A break is received before the receive buffer is read.

Both the B and OE flags will be set when the buffer full condition is satisfied.

4-91

#### 6.3 TRANSMITTER

The transmit buffer is loaded by writing to the USART data register (UDR). The data word will be transferred to an internal 8-bit shift register when the last word in the shift register has been transmitted. This will produce a buffer empty condition. If the transmitter completes the transmission of the word in the shift register before a new word is written to the transmit buffer, an underrun error will occur. In the asynchronous character format, the transmitter will send a mark until the transmit buffer is written. In the synchronous character format, the transmitter will continuously send the synchronous character.

The transmit buffer can be loaded prior to enabling the transmitter. After the transmitter is enabled, there is a delay before the first bit is output. The serial output line (SO) should be programmed to be high, low, or high impedance when the transmitter is enabled to force the output line to the desired state until the first bit is shifted out. Note that a one bit will always be transmitted prior to the word in the transmitter is first enabled.

When the transmitter is disabled, any word currently being transmitted will continue to completion. However, any word in the transmit buffer will not be transmitted and will remain in the buffer. So, no buffer empty condition will occur. If the buffer is empty when the transmitter is disabled, the buffer empty condition will remain, but no underrun condition will be generated when the word in transmission is completed. If no word is being transmitted when the transmitter is disabled, the transmitter will stop at the next rising edge of the internal shift clock.

In the asynchronous character format, the transmitter can be programmed to send a break. The break will be transmitted once the word currently in the shift register has been sent. If the shift register is empty, the break command will be effective immediately. An END interrupt will be generated at every normal character boundary to aid in timing the break transmission. The break will continue until the break command is cleared.

Any character in the transmit buffer at the start of a break will be transmitted when the break is terminated. If the transmit buffer is empty at the start of a break, it may be written at any time during the break. If the buffer is still empty at the end of the break, an underrun condition will exist.

Disabling the transmitter during a break condition causes the transmitter to cease transmission of a the break character at the end of the current character. No end of break stop bit will be transmitted. Even if the transmit buffer is empty, no buffer empty condition will occur nor will an underrun condition occur. Also, any word in the transmit buffer will remain.

#### 6.3.1 Transmitter Interrupt Channels

The USART transmit section is assigned two interrupt channels. One channel indicates a bufferempty condition and the other channel indicates an underrun or end condition. These interruptingconditions correspond to the BE, UE, and END flag bits of the transmitter status register (TSR). Theflag bits will function as described in 6.3.2 whether their associated interrupt channel is enabled or disabled.

### 6.3.2 Transmitter Status Register

The transmitter status register contains various transmitter error flags and transmitter control bits for selecting auto-turnaround and loopback mode. The TSR is shown in Figure 6-4.

|      | Address                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2D <b>C</b>          | 7                       | 6                           | 5                       | 4                                          | 3                          | 2                           | 1                      | 0                                                                                                      |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------------------|-----------------------------|-------------------------|--------------------------------------------|----------------------------|-----------------------------|------------------------|--------------------------------------------------------------------------------------------------------|
|      | (Hex                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      | BE                      | UE                          | AT                      | END                                        | В                          | н                           | L                      | TE                                                                                                     |
| BE   | Buffer Em<br>Is cleared<br>SET<br>CLEARED                                                                                                                                                                                                                                                                                                                                                                                                                             | a)                   | Transmit                | nit buner                   | ntents tra              | the transmi<br>d by writing<br>nsferred to | i to the U                 | SABL data                   | a remister l           | nsmit shift register. Thi<br>UDR).                                                                     |
| UE   | Underrun Error. This bit is set when the word in the transmit shift register has been transmitted before a new word is<br>loaded into the transmit buffer. This bit is cleared by reading the TSR or by disabling the transmitter. This bit does<br>not need to be cleared before writing to the UDR.<br>SET a) Transmit shift register contents transmitted before transmit buffer written<br>CLEARED a) Transmitter status register read<br>b) Transmitter disabled |                      |                         |                             |                         |                                            |                            |                             |                        |                                                                                                        |
| AT   | Auto-Turna<br>disabled ar<br>SET<br>CLEARED                                                                                                                                                                                                                                                                                                                                                                                                                           | a) N                 | APU write               |                             | g uananin               | eceiver will<br>ted is comp                | be enabled<br>leted.       | d automati                  | cally after            | the transmitter has b                                                                                  |
| END  | End of Trar<br>after the ch<br>END bit wil<br>SET<br>CLEARED                                                                                                                                                                                                                                                                                                                                                                                                          | ll be se<br>a) T     | t immedia<br>ransmitte  |                             | END bit                 | -m + w + m + s                             | Deina trai                 | nemittad                    | hon the to             | itted, the END will be<br>ansmitter is disabled,                                                       |
| В    | transmit shi<br>ware, the bi<br>set                                                                                                                                                                                                                                                                                                                                                                                                                                   | ft regis<br>reak ind | ter A bre<br>dication v | eak consis<br>vill cease a  | its of an a             | illed upon<br>Illizero data                | the completers word with   | etion of th                 | e transmis             | s character format, wh<br>ssion of any word in t<br>his bit is cleared by sc<br>in B is set, BE cannot |
|      | SET<br>CLEARED                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                      | PU write<br>PU write    |                             |                         |                                            |                            |                             |                        |                                                                                                        |
| H, L | High and Lo<br>also force th                                                                                                                                                                                                                                                                                                                                                                                                                                          | w The<br>ne trans    | se contro<br>smitter ou | el bits conf<br>utput after | igure the trans         | transmitter i<br>smitter is er             | output (SC<br>abled unt    | )) when the<br>it END is cl | e transmitt<br>leared. | er is disabled. These b                                                                                |
|      | H                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                      | <u>L</u>                | Outp                        | ut State                |                                            |                            |                             |                        |                                                                                                        |
|      | 0<br>0<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                      | 0<br>1<br>0             | l                           | npedance<br>.ow<br>ligh | 2                                          |                            |                             |                        |                                                                                                        |
|      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                      | 1                       |                             | ack Mode                |                                            |                            |                             |                        |                                                                                                        |
|      | Loopback m<br>receiver cloc<br>disabled, SO<br>SET<br>CLEARED                                                                                                                                                                                                                                                                                                                                                                                                         | is forc<br>a) MF     | itaniy ing              | a one                       | ne transm<br>clock (R(  | itter output<br>C) and the s               | to the rec<br>serial input | ceiver inpu<br>t (SI) are r | t and the liot used. N | transmitter clock to th<br>When the transmitter                                                        |
| TE   | Transmitter F                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                      |                         |                             | and the                 | •                                          |                            |                             |                        |                                                                                                        |

г. 13

PRESERVE A STREET

• •

ALC: NO

2

A N IN IN

.7

. 7

Transmitter Enable. When this bit is cleared, the transmitter is disabled. The UE bit will be-cleared and the END bit will be set. When this bit is set, the transmitter is enabled. The transmitter output will be driven according to the H and L bits until transmission begins. A one bit will be transmitted before the transmission of the word in the transmit shift register is begun.

SET a) MPU writes a one CLEARED a) MPU writes a zero

b) Reset

## Figure 6-4. Transmitter Status Register (TSR)

#### 6.4 DMA OPERATION

USART error conditions are only valid for each character boundary. When the USART performs block data transfers by using the DMA handshake lines RR (receiver ready) and TR (transmitter ready), errors must be saved and checked at the end of a block. This is accomplished by enabling the error channel for the receiver or transmitter and by masking interrupts for this channel. Once the transfer is complete, interrupt pending register A is read. Any pending receiver or transmitter error indicates an error in the data transfer.

### This Material Copyrighted By Its Respective Manufacturer

Downloaded from Datasheet.su

## SECTION 7 ELECTRICAL CHARACTERISTICS

This section contains the electrical specifications and associated timing information for the TS68HC901 multi-function peripheral.

## 7.1 MAXIMUM RATINGS

| Rating                                                                   | Symbol | Value                                                                        | Unit |
|--------------------------------------------------------------------------|--------|------------------------------------------------------------------------------|------|
| Supply Voltage                                                           | Vcc    | -0.3 to 7.0                                                                  |      |
| Input Voltage                                                            |        | -0.3 to 7.0                                                                  | +    |
| Operating Temperature Range<br>TS68HC901 C<br>TS68HC901 V<br>TS68HC901 V | TA     | T <sub>L</sub> to T <sub>H</sub><br>0 to + 70<br>-40 to + 85<br>-55 to + 125 | °c   |
| Storage Temperature                                                      | Tstg   | - 65 to 150                                                                  | °C   |
| Power Dissipation                                                        | PD     | 30                                                                           | mW   |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either V<sub>CC</sub> or GND).

> н 22

> Ξ

(2)

(3)

# 7.2 THERMAL CHARACTERISTICS

| Symbol | Value         | Rating |
|--------|---------------|--------|
|        |               |        |
| Δ.     | 40            |        |
| PJA    |               | °C⊬W   |
|        | Symbol<br>ØJA |        |

## 7.3 POWER CONSIDERATIONS

The average chip-junction temperature, TJ, in °C can be obtained from:

 $T_{J} = T_{A} + (P_{D} \bullet \theta_{JA})$ Where:  $T_{A} = \text{Ambient Temperature, °C}$   $\theta_{JA} = \text{Package Thermal Resistance, Junction-to-Ambient, °C/W}$   $P_{D} = P_{INT} + P_{I/O}$   $P_{INT} = I_{CC} \times V_{CC}, \text{ Watts } - \text{ Chip Internal Power}$   $P_{I/O} = P_{Ower Dissipation on Input and Output Pins - User Determined}$ For most applications  $P_{I/O} < P_{INT}$  and can be neglected.
(1)

An approximate relationship between PD and TJ (if  $P_{I/O}$  is neglected) is:  $P_{D} = K + (T_{J} + 273 \circ C)$ 

Solving equations 1 and 2 for K gives:

 $K = P_{D} \bullet (T_{A} + 273^{\circ}C) + \theta_{JA} P_{D}^{2}$ 

Where:

K is a constant pertaining to the particular part. K can be determined from equation (3) by measuring PD (at equilibrium) for a known TA. Using this value of K the values of PD and TJ can be obtained by solving equations (1) and (2) iteratively for any value of TA.

4-95

# 7.4 DC ELECTRICAL CHARACTERISTICS

### $V_{CC} = -5 V \pm 5\%$ , unless otherwise noted) $(T_{\Delta} = T_{1} \text{ to } T_{H})$

|                                                               | Symbol     | Min     | Max     | Unit |
|---------------------------------------------------------------|------------|---------|---------|------|
| Characteristic                                                | ViH        | 20      | VDD+03  | V    |
| nput High Voltage except XTAL1, XTAL2                         |            | Vpp-1.5 | VDD+0.3 |      |
| Input High Voltage XTAL1, XTAL2                               |            | -03     | 08      | V    |
| Input Low Voltage                                             |            | 4.1     | —       | V    |
| Output High Voltage, Except $DTACK$ ( $I_{QH} = -120 \mu A$ ) | VOL        | _       | 0.5     | V    |
| Output Low Voltage, Except DTACK (IOL = 2.0 mA)               |            |         | 3.7     | mA   |
| Power Supply Current (Outputs Open)                           |            | -       | ±10     | μΑ   |
| Input Leakage Current (Vin = 0 to VCC)                        | 1.0Н       | -       | 10      | μΑ   |
| Hi-Z Output Leakage Current in Float (Vout = 2.4 to VCC)      | <u></u>    |         | - 10    | μΑ   |
| Hi-Z Output Leakage Current in Float (Vout = 0.5 V)           | <u>Iон</u> |         | - 400   | μA   |
| DTACK Output Source Current (Vout = 2.4.V)                    |            |         | 53      | mA   |
| DTACK Output Sink Current (Vout=0.5 V)                        | RMPX       | 1       | 3       | MΩ   |
| Pull Down Resistor                                            |            | _!      |         |      |
|                                                               |            |         | 14      |      |

# 7.5 CAPACITANCE ( $T_A = 25^{\circ}C$ , f = 1 MHz, unmeasured pins returned to ground)

|                         | Symbol | Min | Max | Unit |   |
|-------------------------|--------|-----|-----|------|---|
| Characteristic          | Cin    |     | 10  | pF   | 1 |
| Input Capacitance       | Cout   | -   | 10  | pF   |   |
| Hi-Z Output Capacitance |        |     |     |      |   |



Figure 7-1. IRQ Test Load

11 

N N



Figure 7-2. Typical Test Load

4-96

## 7.6 CLOCK TIMING

| Characteristic         | Symbol          | Min | Max  | Unit |
|------------------------|-----------------|-----|------|------|
| Frequency of Operation |                 | 1.0 | ·    |      |
| Cycle Time             |                 | 1.0 | 4.0  | MHz  |
| Clock Pulse Width      | tcyc            | 250 | 1000 | ns   |
| Rise and Fall Times    | <u>tCL, tCH</u> | 110 | 250  | ns   |
|                        | tCr. tCf        |     | 15   | ns   |



Crystal Parameters Parallel resonance fundamental mode AT cut  $R_S \le 150 \ \Omega$  (f= 2.8 ~ 4.0 MHz)  $R_S \le 300 \ \Omega$  (f= 2.0 - 2.7 MHz)  $C_L = 18 \ pF$ ,  $C_M = 0.02 \ pF$ ,  $C_R = 5 \ pF$ ,  $L_M = 96 \ MHz$ f (typical) = 2.4576 MHz г. 12

PRESERVES A STRUCTURE

ALC: UNK

N In





Figure 7-3-1. CMFP External Clock Connection

4-97

This Material Copyrighted By Its Respective Manufacturer

Downloaded from Datasheet.su

# 7.7 AC ELECTRICAL CHARACTERISTICS ( $V_{CC} = 5.0V_{DC} \pm 5\%$ , $V_{SS} = 0V_{DC}$ , $T_A = 0^{\circ}C$ to 70°C unless otherwise noted). See figures 7-4 through 7-10.

| <u> </u>   |                                                                                          |     | Hz   | 8 MI     | Чż       | Unit |
|------------|------------------------------------------------------------------------------------------|-----|------|----------|----------|------|
| Num        | Characteristic                                                                           | Min | Max  | Min      | Max      |      |
|            | CS, DS Width High                                                                        | 50  | —    | 50       |          |      |
| 2          | $R/\overline{W}$ , A1-A5 Valid to Falling $\overline{CS}$ (Setup)                        | 30  |      | 20       | -        | ns   |
| 3          | Data Valid Prior to Falling CLK                                                          | 280 |      | 100      |          | ns   |
| 4 (3)      | CS, IACK Valid to falling Clock (Setup)                                                  | 50  | —    | 50       | —        | ns   |
| 4 (3)<br>5 | CLK Low to DTACK Low                                                                     | _   | 220  | —        | 90       | ns   |
| 6          | CS, DS or IACK High to DTACK High                                                        | _   | 60   |          | 50       | ns   |
| 7          | CS, DS or IACK High to DTACK Tri-state                                                   | -   | 100  |          | 100      | ns   |
| 8          | DTACK Low to Data Invalid (Hold Time)                                                    | 0   |      | 0        |          | ns   |
| 9          | CS, DS or IACK High to Data Tri-state                                                    | _   | 50   |          | 50       | ns   |
| 10         | $\overline{CS}$ or $\overline{DS}$ High to R/ $\overline{W}$ , A1-A5 Invalid (Hold Time) | 0   |      | 0        | _        | ns   |
| 11 (3,5)   | Data Valid from CS Low                                                                   |     | 310  | —        | 180      | ns   |
| 12         | Read Data Valid to DTACK Low (Setup Time)                                                | 50  |      | 0        |          | ns   |
| 13         | DTACK Low to DS, CS or IACK High (Hold Time)                                             | 0   |      | 0        |          | ns   |
| 14         | IEI Low to Falling CLK (Setup)                                                           | 50  |      | 50       |          | ns   |
| 15 (1)     | IEO Valid from Clock Low (Delay)                                                         |     | 180  |          | 120      | ns   |
| 16         | Data Valid from Clock Low (Delay)                                                        | _   | 300  |          | 180      | ns   |
| 17         | IEO Invalid from IACK High (Delay)                                                       |     | 150  |          | 100      | ns   |
| 18         | DTACK Low from Clock High (Delay)                                                        |     | 180  |          | 100      | ns   |
| 19(1)      | IEO Valid from IEI Low (Delay)                                                           |     | 100  | <u> </u> | 100      | ns   |
| 20         | Data Valid from IEI Low (Delay)                                                          | -   | 220  |          | 140      | ns   |
| 21         | Clock Cycle Time                                                                         | 250 | 1000 | 125      | 1000     | ns   |
| 22         | Clock Width Low                                                                          | 110 |      | 55       | <u> </u> | ns   |
| 23         | Clock Width High                                                                         | 110 |      | 55       | <u> </u> | ns   |
| 24 (4)     | CS, TACK Inactive to Rising Clock (Setup)                                                | 100 |      | 50       |          | ns   |
| 25         | I/O Minimum Active Pulse Width                                                           | 100 |      | 100      |          | ns   |
| 26         | IACK Width High/Minimum Delay between two Pulses                                         | 2   |      | 2        |          | CLI  |
| 27         | $I/O$ Data Valid from Rising $\overline{CS}$ or $\overline{DS}$                          |     | 450  |          | 350      | ns   |
| 28         | Receiver Ready Delay from Falling RC                                                     |     | 600  |          | 200      | ns   |
| 29         | Transmitter Ready Delay from Falling TC                                                  |     | 600  |          | 200      |      |
| 30 (6)     | Timer Output Low from Rising Edge of CS or DS<br>(A & B) (Reset T <sub>OUT</sub> )       |     | 450  |          | 200      | ns   |

This Material Copyrighted By Its Respective Manufacturer

Downloaded from Datasheet.su

| Num    | Characteristic                                                            | 4    | MHz                         | 8    | MHz                                          |             |
|--------|---------------------------------------------------------------------------|------|-----------------------------|------|----------------------------------------------|-------------|
|        |                                                                           |      | Max                         | Min  | Max                                          | Unit        |
| 31 (2) | T <sub>OUT</sub> Valid from Internal Timeout                              | -    | 2 t <sub>CLK</sub><br>+ 300 | -    | 2 t <sub>CLK</sub><br>+ 300                  | ns          |
| 32     | Timer Clock Low Time                                                      | 110  |                             | 55   | <b>†</b> _                                   | ns          |
| 33     | Timer Clock High Time                                                     | 110  |                             | 55   | <u>†                                    </u> | ns          |
| 34     | Timer Clock Cycle Time                                                    | 250  | 1000                        | 125  | 1000                                         | ns          |
| 35     | RESET Low Time                                                            | 2    | -                           | 1.5  |                                              | μs          |
| 36     | Delay to Falling INTR from External<br>Interrupt Active Transition        | -    | 380                         | -    | 250                                          | ns          |
| 37     | Transmitter Internal Interrupt Delay from Falling<br>Edge of TC           | 550  |                             | 250  | -                                            | ns          |
| 38     | Receiver Buffer Full Interrupt Transition Delay<br>from Rising Edge of RC | 800  | 1 -                         | 400  |                                              | ns          |
| 39     | Receiver Error Interrupt Transition Delay from<br>Falling Edge of RC      | 800  | -                           | 400  | <u>+</u>                                     | ns          |
| 40     | Serial In Set Up Time to Rising Edge of RC<br>(Divide by one only)        | 80   |                             | 50   |                                              | ns          |
| 41     | Data Hold Time from Rising Edge of RC<br>(Divide by one only)             | 350  | ·                           | 100  |                                              | ns          |
| 42     | Serial Output Data Valid from Falling Edge of TC ( $\div$ 1)              |      | 440                         |      | 200                                          | ns          |
| 43     | Transmitter Clock Low Time                                                | 500  |                             | 250  |                                              | ns          |
| 44     | Transmitter Clock High Time                                               | 500  |                             | 250  |                                              |             |
| 45     | Transmitter Clock Cycle Time                                              | 1.05 | ×                           | 0.55 | ×                                            | <br>μs      |
| 46     | Receiver Clock Low Time                                                   | 500  |                             | 250  |                                              | ns          |
| 47     | Receiver Clock High Time                                                  | 500  |                             | 250  |                                              | <br>        |
| 48     | Receiver Clock Cycle Time                                                 | 1.05 | ~                           | 0.55 | ~                                            |             |
| 9 (2)  | CS, IACK, DS Width Low                                                    |      | 80                          |      | 80                                           | μs<br>Touri |
| 50     | Serial Output Data Valid from Falling Edge of TC ( $\div$ 16)             | -    | 490                         | -    | 200                                          | TCLK<br>ns  |
| 51     | Cycle Time                                                                | 1000 |                             |      |                                              | ns          |
| 52     | Pulse Width, E High                                                       | 430  |                             |      |                                              | <br>        |
| 53     | Pulse Width, E Low                                                        | 450  |                             |      |                                              | ns          |
| 54     | Address, R/W Setup Time Before E                                          | 80   |                             |      |                                              |             |
| 55     | CS Setup Time Before E                                                    | 80   |                             |      |                                              | ns          |
| 56     | Address Hold Time                                                         | 10   |                             |      |                                              | ns          |
| 57     | CS Hold Time                                                              | 10   |                             |      |                                              | <u>ns</u>   |
| 58     | Output Data Delay Time (Read)                                             |      | 250                         | +    |                                              | ns          |
| 59     | Data Hold Time (Read)                                                     | 0    | 100                         |      |                                              | ns          |

г, 12

1.1

1.9111111111111

THE PLANE

.

N In In

| — T |                                                                           | 4 MHz 8 |          | 8 N | 1Hz      | Unit |
|-----|---------------------------------------------------------------------------|---------|----------|-----|----------|------|
| Num | Characteristic                                                            | Min     | Max      | Min | Max      |      |
| 60  | Input Data Setup Time (Write)                                             | 280     | _        | _   | _        | ns   |
| 61  | Data Hold Time (Write)                                                    | 20      |          |     |          | ns   |
| 62  | Cycle Time                                                                | 800     | —        |     |          | ns   |
| 63  | Pulse Width $\overline{\text{DS}}$ Low or RD/ $\overline{\text{WR}}$ High | 350     |          |     | L        | ns   |
| 64  | Pulse Width DS High or RD/WR Low                                          | 340     | _        |     |          | ns   |
| 65  | Pulse Width AS/ALE High                                                   | 100     | _        |     |          | ns   |
| 66  | Delay AS Fall to DS Rise or ALE Fall to RD/WR Fall                        | 30      |          |     |          | ns   |
| 67  | Delay DS or RD/WR Rise to AS/ALE Rise                                     | 30      | <u> </u> |     |          | ns   |
| 68  | R/W Setup Time to DS                                                      | 100     |          |     |          | ns   |
| 69  | R/W Hold Time to DS                                                       | 10      |          |     |          | ns   |
|     | Address Setup Time to AS/ALE                                              | 20      | <u> </u> |     | <u> </u> | ns   |
| 71  | Address Hold Time to AS/ALE                                               | 20      |          |     |          | ns   |
| 72  | Data Setup Time to DS or WR (Write)                                       | 280     |          |     |          | ns   |
| 73  | Delay Data to DS or RD (Read)                                             |         | 250      |     | -        | ns   |
| 74  | Data Hold Time to DS or WR (Write)                                        | 20      | -        |     |          | ns   |
| 75  | Data Hold Time to DS or RD (Read)                                         | 0       | 100      |     |          | ns   |
| 76  | CE Setup Time to AS/ALE Fall                                              | 20      |          |     |          | ns   |
| 77  | CE Hold Time to DS, RD or WR                                              | 20      | -        |     |          | ns   |

Ξ,

8 12 2

#### Notes:

- IEO only goes low if no acknowledgeable interrupt is pending. If IEO goes low, DTACK and the data bus remain tri-stated.
- T<sub>CLK</sub> refers to the clock applied to the CMFP CLK input pin. t<sub>CLK</sub> refers to the timer clock signal, regardless of whether that signal comes from the XTAL1/XTAL2 crystal clock inputs or the TAI or TBI timer inputs.
- 3. If the setup time is not met,  $\overline{CS}$  or  $\overline{IACK}$  will not be recognized until the next falling CLK.
- If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles.
- 5. Althrough CS and DTACK are synchronized with the clock, the data out during a reed cycle is asynchronous to the clock, relying only on CS for timing.
- 6. Spec. 30 applies to timer outputs TAO and TBO only.

4-100

# 7.7.1 AC ELECTRICAL CHARACTERISTICS - READ CYCLES

 $(V_{CC} = 5.0 V_{DC} \pm 5 \%, V_{SS} = 0 V_{DC}, T_{A} = T_{L}$  to T<sub>H</sub> unless otherwise noted)

| Num      | Characteristic                                                                                                                  | 4        | MHz      | MHz 8      |           |          |
|----------|---------------------------------------------------------------------------------------------------------------------------------|----------|----------|------------|-----------|----------|
| ļ        |                                                                                                                                 | Min      | Max      | Min        | Max       | - Unit   |
| 1        | CS, DS Width High                                                                                                               | 50       | T _      | 50         | <u> </u>  |          |
| 2        | $R/\widetilde{W}$ , A1-A5 Valid to Falling $\widetilde{CS}$ (Setup)                                                             | 30       | <u> </u> | 20         | t         | ns       |
| 4 (3)    | CS, IACK Valid to Falling Clock (Setup)                                                                                         | 50       | <u> </u> | 50         | <u></u> + | ns       |
| 5        | CLK Low to DTACK Low                                                                                                            |          | 220      | <u> </u>   | 90        | ns       |
| 6        | CS, DS or IACK High to DTACK High                                                                                               | _        | 60       | <u>  _</u> | 50        | ns       |
| 7        | CS, DS or IACK High to DTACK Tri-state                                                                                          |          | 100      | <u> </u>   | 100       | ns       |
| 8        | DTACK Low to Data Invalid (Hold Time)                                                                                           | 0        | <u>├</u> | 0          |           | ns       |
| 9        | CS, DS or IACK High to Data Tri-state                                                                                           |          | 50       |            | 50        | ns       |
| 10       | $\overrightarrow{\text{CS}}$ or $\overrightarrow{\text{DS}}$ High to R/ $\overrightarrow{\text{W}}$ , A1-A5 Invalid (Hold Time) | 0        |          | 0          |           | ns       |
| 11 (3,5) | Data Valid from CS Low                                                                                                          | <u> </u> | 310      |            | 180       | ns       |
| 12       | Read Data Valid to DTACK Low (Setup Time)                                                                                       | 50       |          | 0          |           | ns       |
| 13       | DTACK Low to DS, CS or IACK High (Hold Time)                                                                                    | 0        |          | 0          |           |          |
| 24 (4)   | CS, IACK Inactive to Rising Clock (Setup)                                                                                       | 100      |          | 50         |           | ns<br>ns |

#### Notes:

- 3. If the setup time is not met,  $\overline{CS}$  or  $\overline{IACK}$  will not be recognized until the next falling CLK.
- 4. If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles.
- 5. Althrough CS and DTACK are synchronized with the clock, the data out during a reed cycle is asynchronous to the clock, relying only on CS for timing.



This Material Copyrighted By Its Respective Manufacturer

З

# 7.7.2 AC ELECTRICAL CHARACTERISTICS - WRITE CYCLES

 $(V_{CC} = 5.0 V_{DC} \pm 5\%, V_{SS} = 0 V_{DC}, T_A = T_L \text{ to } T_H \text{ unless otherwise noted})$ 

| T      |                                                                   | 4 N | 1Hz | 8 N | IHz | Unit |
|--------|-------------------------------------------------------------------|-----|-----|-----|-----|------|
| Num    | Characteristic                                                    | Min | Max | Min | Max |      |
|        | CS, DS Width High                                                 | 50  | -   | 50  |     |      |
| 2      | $R/\overline{W}$ , A1-A5 Valid to Falling $\overline{CS}$ (Setup) | 30  |     | 20  |     | ns   |
| 3      | Data Valid Prior to Falling CLK                                   | 280 | —   | 100 |     | ns   |
| 4 (3)  | CS, IACK Valid to Falling Clock (Setup)                           | 50  |     | 50  |     | ns   |
| 5      | CLK Low to DTACK Low                                              |     | 220 |     | 90  | ns   |
| 6      | CS, DS or IACK High to DTACK High                                 | _   | 60  |     | 50  | ns   |
|        | CS, DS or IACK High to DTACK Tri-state                            |     | 100 |     | 100 | ns   |
|        | DTACK Low to Data Invalid (Hold Time)                             | 0   | —   | 0   |     | ns   |
| 10     | CS or DS High to R/W, A1-A5 Invalid (Hold Time)                   | 0   |     | 0   |     | ns   |
| 13     | DTACK Low to DS, CS or IACK High (Hold Time)                      | 0   |     | 0   |     | ns   |
| 24 (4) | CS, IACK Inactive to Rising Clock (Setup)                         | 100 |     | 50  |     | ns   |

1.1

N N

#### Notes:

- If the setup time is not met, CS or IACK will not be recognized until the next falling CLK. 3.
- If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not 4. met, the hold off will be two clock cycles.



Figure 7-5. Write Cycle Timing

#### 4-102

# 7.7.3 AC ELECTRICAL CHARACTERISTICS - INTERRUPT ACKNOWLEDGE CYCLES

 $(V_{CC} = 5.0 V_{DC} \pm 5\%, V_{SS} = 0 V_{DC}, T_A = T_L \text{ to } T_H$ See Figures 7-6 and 7-7.

| Num    | Characteristic                                   | 4   | MHz      | 8 MHz       |             | Τ    |
|--------|--------------------------------------------------|-----|----------|-------------|-------------|------|
|        |                                                  | Min | Max      | Min         | Max         | Unit |
| 4 (3)  | CS, IACK Valid to Falling Clock (Setup)          | 50  |          | 50          | 1 _         | ns   |
| 5      | CLK Low to DTACK Low                             | _   | 220      | -           | 90          | ns   |
| 6      | CS, DS or IACK High to DTACK High                | _   | 60       | -           | 50          | ns   |
| 7      | CS, DS or IACK High to DTACK Tri-state           | _   | 100      |             | 100         | ns   |
| 9      | CS, DS or IACK High to Data Tri-state            |     | 50       | <u>+</u>    | 50          | ns   |
| 13     | DTACK Low to DS, CS or IACK High (Hold Time)     | 0   | T        | 0           | <u>+</u>    | ns   |
| 14     | IEI Low to Falling CLK (Setup)                   | 50  | <u> </u> | 50          | <u>  _ </u> | ns   |
| 15 (1) | IEO Valid from Clock Low (Delay)                 |     | 180      | <b> </b>    | 120         | ns   |
| 16     | Data Valid from Clock Low (Delay)                |     | 300      | †•          | 180         |      |
| 17     | IEO Invalid from IACK High (Delay)               |     | 150      | †- <u>-</u> | 100         | ns   |
| 18     | DTACK Low from Clock High (Delay)                |     | 180      | <u> </u>    | 100         | ns   |
| 19 (1) | TEO Valid from TEI Low (Delay)                   |     | 100      |             | 100         | ns   |
| 20     | Data Valid from IEI Low (Delay)                  | -   | 220      |             | 140         | ns   |
| 21     | Clock Cycle Time                                 | 250 | 1000     | 125         | 1000        | ns   |
| 22     | Clock Width Low                                  | 110 |          | 55          |             | ns   |
| 23     | Clock Width High                                 | 110 |          | 55          |             | ns   |
| 24 (4) | CS, IACK Inactive to Rising Clock (Setup)        | 100 |          | 50          |             | ns   |
| 26     | IACK Width High/Minimum Delay between two Pulses | 2   |          | 2           |             | CLK  |

#### Notes:

- 1. IEO only goes low if no acknowledgeable interrupt is pending. If IEO goes low, DTACK and the data bus remain tri-stated.
- 3. If the setup time is not met,  $\overline{CS}$  or  $\overline{IACK}$  will not be recognized until the next falling CLK.
- If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles.

unless otherwise noted)

4-103



г. 13

PRESERVE AND A DEPART

A STATE OF A

COLUMN 1

.

N IN IN

÷,

.5

Figure 7-6. Interrupt Acknowledge Cycle (IEI Low)





Figure 7-7. Interrupt Acknowledge Cycle (IEI High)

4-104

# 7.7.4 AC ELECTRICAL CHARACTERISTICS - 6800 INTERFACE TIMING ( $V_{CC} = 5.0 V_{DC} \pm 5\%$ , $V_{SS} = 0V_{DC}$ , $T_A = 0^{\circ}$ C to 70°C unless otherwise noted). See figure 7-8.

|     |                                  | ······································ |     |     |     |      |  |  |
|-----|----------------------------------|----------------------------------------|-----|-----|-----|------|--|--|
| Num | Characteristic                   | 41                                     | ИНz | 81  | ЛНz |      |  |  |
|     |                                  | Min                                    | Max | Min | Max | Unit |  |  |
| 51  | Cycle Time                       | 1000                                   | _   |     | 1   | ns   |  |  |
| 52  | Pulse Width, E High              | 430                                    |     |     |     | ns   |  |  |
| 53  | Pulse Width, E Low               | 450                                    |     |     |     | ns   |  |  |
| 54  | Address, R/W Setup Time Before E | 80                                     |     |     |     | ns   |  |  |
| 55  | CS Setup Time Before E           | 80                                     |     |     |     | ns   |  |  |
| 56  | Address Hold Time                | 10                                     |     |     |     | ns   |  |  |
| 57  | CS Hold Time                     | 10                                     | _   |     |     | ns   |  |  |
| 58  | Output Data Delay Time (Read)    |                                        | 250 |     |     | ns   |  |  |
| 59  | Data Hold Time (Read)            | 0                                      | 100 |     |     | ns   |  |  |
| 60  | Input Data Setup Time (Write)    | 280                                    |     |     |     | ns   |  |  |
| 61  | Data Hold Time (Write)           | 20                                     | _   |     |     | ns   |  |  |

1.911111111

ALL PLANE

N IN



Figure 7-8. 6800 Interfacing Timing



# 7.7.5 AC ELECTRICAL CHARACTERISTICS - MULTIPLEXED BUS TIMING ( $V_{CC} = 5.0 \text{ V}_{DC}$ $\pm 5\%$ , $V_{SS} = 0 \text{ V}_{DC}$ , $T_A = 0^{\circ}$ C to 70°C unless otherwise noted). See figures 7-9, 7-10.

| Num |                                                    | 4 MHz |     | 8 MHz |     | Unit |
|-----|----------------------------------------------------|-------|-----|-------|-----|------|
|     | Characteristic                                     | Min   | Max | Min   | Мах |      |
| 62  | Cycle Time                                         | 800   |     |       | _   | ns   |
| 63  | Pulse Width DS Low or RD/WR High                   | 350   |     |       |     | ns   |
| 64  | Pulse Width DS High or RD/WR Low                   | 340   | —   |       |     | ns   |
| 65  | Pulse Width AS/ALE High                            | 100   |     |       |     | ns   |
| 66  | Delay AS Fall to DS Rise or ALE Fall to RD/WR Fall | 30    |     |       | -   | ns   |
| 67  | Delay DS or RD/WR Rise to AS/ALE Rise              | 30    |     |       |     | ns   |
| 68  | R/W Setup Time to DS                               | 100   |     |       |     | ns   |
| 69  | $R/\overline{W}$ Hold Time to $\overline{DS}$      | 10    |     |       |     | ns   |
| 70  | Address Setup Time to AS/ALE                       | 20    | —   | -     |     | ns   |
| 71  | Address Hold Time to AS/ALE                        | 20    |     |       |     | ns   |
| 72  | Data Setup Time to DS or WR (Write)                | 280   |     |       |     | ns   |
| 73  | Delay Data to DS or RD (Read)                      |       | 250 |       |     | ns   |
| 74  | Data Hold Time to DS or WR (Write)                 | 20    |     |       |     | ns   |
| 75  | Data Hold Time to DS or RD (Read)                  | 0     | 100 |       |     | ns   |
| 76  | CE Setup Time to AS/ALE Fall                       | 20    |     | -     |     | ns   |
|     | CE Hold Time to DS, RD or WR                       | 20    | _   | -     | _   | ns   |



Figure 7-9. Multiplexed Bus Timin Motorola Type

THE DESIGN

4-106



PRESERVE AND A DEPART

A LONG TO DESCRIPTION

COLUMN 1

N IN IN



Figure 7-10. Multiplexed Bus Timing - Intel Type

## 4-107





Figure 7-11. Interrupt Timing



Figure 7-12. Port Timing

н 22

M In Ib ā,

4-108



л. 13

PRESERVE A REPORT

ALL OF BUS

Ξ





Figure 7-14. Transmitter Timing

4-109



Figure 7-15. Timer Timing



Figure 7-16. Reset Timing

R,

## 7.8 TIMER AC CHARACTERISTICS

### Definitions:

Error = Indicated time value - actual time value tpsc = tCLK × Prescale Value

| Internal Timer Mode:                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Single Interval Error (Free Running) (See Note 2)                                                                                                    |
| Cumulative Internal Error                                                                                                                            |
| Error Between Two Timer Reads                                                                                                                        |
| Start Timer to Stop Timer Error $2 \text{ t}_{\text{CLK}} + 100 \text{ ns to} - (\text{t}_{\text{psc}} + 6 \text{ t}_{\text{CLK}} + 100 \text{ ns})$ |
| Start Timer to Read Timer Error                                                                                                                      |
| Start Timer to Interrupt Request Error (See Note 3)                                                                                                  |
| Pulse Width Measurement Mode:                                                                                                                        |
| Measurement Accuracy (See Note 1) Measurement Accuracy (See Note 1)                                                                                  |
| Measurement Accuracy (See Note 1)                                                                                                                    |
| Event Counter Mode:                                                                                                                                  |
| Minimum Active Time of TAI and TBI                                                                                                                   |
| Minimum Inactive Time of TAI and TBI                                                                                                                 |
|                                                                                                                                                      |

л. 13

ALL PLANE

ы қ

## NOTES:

- 1. Error may be cumulative if repetitively performed.
- 2. Error with respect to  $t_{out}$  or  $\overline{IRQ}$  if note 3 is true.
- 3. Assuming it is possible for the timer to make an interrupt request immediately.

4-111

## SECTION 8 MECHANICAL DATA AND ORDERING INFORMATION

This section contains the pin assignments, package dimensions, and ordering information for the TS68HC901.

## PIN ASSIGNMENTS

| -            |     |            |    |             |
|--------------|-----|------------|----|-------------|
| R/₩ <b>[</b> | 1 🔴 | $\bigcirc$ | 48 | I ĈŜ        |
| RS1 [        | 2   |            | 47 | I DS        |
| RS2 🕻        | 3   |            | 46 | DTACK       |
| RS3 🕻        | 4   |            | 45 | TACK        |
| RS4 🕻        | 5   |            | 44 | <b>]</b> D7 |
| RS5 🕻        | 6   |            | 43 | <b>]</b> D6 |
| тс 🕻         | 7   |            | 42 | <b>D</b> 5  |
| so 🕻         | 8   |            | 41 | <b>]</b> D4 |
| si <b>C</b>  | 9   |            | 40 | <b>1</b> D3 |
| RC 🕻         | 10  |            | 39 | <b>1</b> D2 |
| ∨cc <b>[</b> | 11  |            | 38 | <b>1</b> D1 |
|              | 12  |            | 37 | ∎∞          |
| ταο 🕻        | 13  |            | 36 | GND         |
| тво 🕻        | 14  |            | 35 | CLK         |
| тсо 🕻        | 15  |            | 34 | ग्रि व      |
| TDO <b>[</b> | 16  |            | 33 | I IEO       |
| XTAL1        | 17  |            | 32 |             |
| XTAL2        | 18  |            | 31 |             |
| TAL          | 19  |            | 30 | TR I        |
| тві 🕻        | 20  |            | 29 | <b>1</b> 7  |
| RESET        | 21  |            | 28 | <b>1</b> 16 |
| 10           | 22  |            | 27 | <b>h</b> 15 |
| 11           | 23  |            | 26 | <b>P</b> 14 |
| 12           | 24  |            | 25 | <b>j</b> 13 |



4-112





CE RAMIC PACKAGE







FN SUFFIX PLCC 52

л. 13

æ

PRESERVES A STRUCTURE



## ORDERING INFORMATION

# STANDARD VERSIONS

| Package Type            | Frequency<br>(MHz) | Temperature<br>Range                            | Part Number                                     |
|-------------------------|--------------------|-------------------------------------------------|-------------------------------------------------|
| Ceramic DIL<br>C Suffix | 4.0<br>5.0<br>8.0  | 0°C to + 70°C<br>0°C to + 70°C<br>0°C to + 70°C | TS68HC901CC4<br>TS68HC901CC5<br>TS68HC901CC8    |
| Plastic DIL<br>P Suffix | 4.0<br>5.0<br>8.0  | 0°C to + 70°C<br>0°C to + 70°C<br>0°C to + 70°C | TS68HC901CP4<br>TS68HC901CP5<br>TS68HC901CP8    |
| PLCC<br>FN Suffix       | 4.0<br>5.0<br>8.0  | 0°C to + 70°C<br>0°C to + 70°C<br>0°C to + 70°C | TS68HC901CFN4<br>TS68HC901CFN5<br>TS68HC901CFN8 |

## **Hi-REL VERSIONS**

In order to fit more closely to customer specific requirements, THOMSON SEMICONDUCTEURS is proposing different screening levels for its Hi-REL ranges.

- G/B screening : Available only from THOMSON SEMICONDUCTEURS, this quality level, very close to the MIL-STD-883, is a cost effective alternative for customers who want to buy Hi-REL devices (low guaranteed AQL). The G/B level is in full accordance with the NFC96883 class G.
- B/B screening : Full accordance with the MIL-STD-883 Rev. C, class B (US), the CECC 90,000 class B (european) and with the NFC96883 class B (French).

Contraction of the state of the

N IN I

Details on screening procedures for these levels of selection are available on request (please contact our sales representatives).

| Package Type            | Frequency<br>(MHz)                            | Temperature<br>Range                                                                                                                                                                                                                                                                                         | Part Number                                                                                              |
|-------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Ceramic DIL<br>C Suffix | 4.0<br>4.0<br>4.0<br>4.0<br>4.0<br>4.0<br>4.0 | $\begin{array}{r}40^{\circ}\text{C to} + 85^{\circ}\text{C} \\55^{\circ}\text{C to} + 125^{\circ}\text{C} \\40^{\circ}\text{C to} + 85^{\circ}\text{C} \\40^{\circ}\text{C to} + 85^{\circ}\text{C} \\55^{\circ}\text{C to} + 125^{\circ}\text{C} \\55^{\circ}\text{C to} + 125^{\circ}\text{C} \end{array}$ | TS68HC901VC4<br>TS68HC901MC4<br>TS68HC901VCG/B4<br>TS68HC901VCB/B4<br>TS68HC901MCG/B4<br>TS68HC901MCG/B4 |

#### 4-114