



#### Welcome to E-XFL.COM

#### **Understanding Embedded - Microprocessors**

Embedded microprocessors are specialized computing chips designed to perform specific tasks within an embedded system. Unlike general-purpose microprocessors found in personal computers, embedded microprocessors are tailored for dedicated functions within larger systems, offering optimized performance, efficiency, and reliability. These microprocessors are integral to the operation of countless electronic devices, providing the computational power necessary for controlling processes, handling data, and managing communications.

#### Applications of **Embedded - Microprocessors**

Embedded microprocessors are utilized across a broad spectrum of applications, making them indispensable in

#### Details

| Product Status                  | Obsolete                                               |
|---------------------------------|--------------------------------------------------------|
| Core Processor                  | Z8S180                                                 |
| Number of Cores/Bus Width       | 1 Core, 8-Bit                                          |
| Speed                           | 10MHz                                                  |
| Co-Processors/DSP               | ·                                                      |
| RAM Controllers                 | DRAM                                                   |
| Graphics Acceleration           | No                                                     |
| Display & Interface Controllers | •                                                      |
| Ethernet                        | -                                                      |
| SATA                            | -                                                      |
| USB                             | -                                                      |
| Voltage - I/O                   | 5.0V                                                   |
| Operating Temperature           | 0°C ~ 70°C (TA)                                        |
| Security Features               | -                                                      |
| Package / Case                  | 80-BQFP                                                |
| Supplier Device Package         | 80-QFP                                                 |
| Purchase URL                    | https://www.e-xfl.com/product-detail/zilog/z8s18010fsc |
|                                 |                                                        |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# **GENERAL DESCRIPTION** (Continued)

Power connections follow the conventional descriptions below:

| Connection | Circuit         | Device          |  |
|------------|-----------------|-----------------|--|
| Power      | V <sub>CC</sub> | V <sub>DD</sub> |  |
| Ground     | GND             | V <sub>SS</sub> |  |





## **PIN IDENTIFICATION**





## **PIN DESCRIPTIONS**

**A0–A19** Address Bus (Output, 3-state). A0–A19 form a 20-bit address bus. The Address Bus provides the address for memory data bus exchanges (up to 1 MB) and I/O data bus exchanges (up to 64 KB). The address bus enters a high–impedance state during reset and external bus acknowledge cycles. Address line A18 is multiplexed with the output of PRT channel 1 ( $T_{OUT}$ , selected as address output on reset), and address line A19 is not available in DIP versions of the Z8S180.

**BUSACK**. Bus Acknowledge (Output, active Low). BUSACK indicates that the requesting device, the MPU address and data bus, and some control signals enter their high-impedance state.

**BUSREQ.** Bus Request (Input, active Low). This input is used by external devices (such as DMA controllers) to request access to the system bus. This request demands a higher priority than  $\overline{\text{NMI}}$  and is always recognized at the end of the current machine cycle. This signal stops the CPU from executing further instructions, places addresses, data buses, and other control signals into the high-impedance state.

**CKAO**, **CKA1**. Asynchronous Clock 0 and 1 (bidirectional). When in output mode, these pins are the transmit and receive clock outputs from the ASCI baud rate generators. When in input mode, these pins serve as the external clock inputs for the ASCI baud rate generators. CKAO is multiplexed with DREQO, and CKA1 is multiplexed with TENDO.

**CKS.** Serial Clock (bidirectional). This line is the clock for the CSI/O channel.

**CTSO**–**CTS1**. Clear to send 0 and 1 (Inputs, active Low). These lines are modem control signals for the ASCI channels.  $\overline{CTS1}$  is multiplexed with RXS.

**D0–D7.** Data Bus = (bidirectional, 3-state). D0–D7 constitute an 8-bit bidirectional data bus, used for the transfer of information to and from I/O and memory devices. The data bus enters the high-impedance state during reset and external bus acknowledge cycles.

**DCDO.** Data Carrier Detect 0 (Input, active Low); a programmable modem control signal for ASCI channel 0.

**DREQO**, **DREQ1**. DMA Request 0 and 1 (Input, active Low). **DREQ** is used to request a DMA transfer from one of the on-chip DMA channels. The DMA channels monitor these inputs to determine when an external device is ready for a READ or WRITE operation. These inputs can be programmed to be either level or edge sensed. **DREQO** is multiplexed with CKAO.

**E.** Enable Clock (Output). This pin functions as a synchronous, machine-cycle clock output during bus transactions.

**EXTAL.** External Clock Crystal (Input). Crystal oscillator connections. An external clock can be input to the Z8S180/Z8L180 on this pin when a crystal is not used. This input is Schmitt triggered.

**HALT.** HALT/SLEEP (Output, active Low). This output is asserted after the CPU executes either the HALT or SLEEP instruction and is waiting for either a nonmaskable or a maskable interrupt before operation can resume. It is also used with the  $\overline{M1}$  and ST signals to decode the status of the CPU machine cycle.

**INTO.** Maskable Interrupt Request 0 (Input, active Low). This signal is generated by external I/O devices. The CPU honors these requests at the end of the current instruction cycle as long as the  $\overline{\text{NMI}}$  and  $\overline{\text{BUSREQ}}$  signals are inactive. The CPU acknowledges this interrupt request with an interrupt acknowledge cycle. During this cycle, both the  $\overline{\text{M1}}$  and  $\overline{\text{IORQ}}$  signals become active.

**INT1**, **INT2**. Maskable Interrupt Request 1 and 2 (Inputs, active Low). This signal is generated by external I/O devices. The CPU honors these requests at the end of the current instruction cycle as long as the  $\overline{\text{NMI}}$ ,  $\overline{\text{BUSREQ}}$ , and  $\overline{\text{INT0}}$  signals are inactive. The CPU acknowledges these requests with an interrupt acknowledge cycle. Unlike the acknowledgment for  $\overline{\text{INT0}}$ , neither the  $\overline{\text{M1}}$  or  $\overline{\text{IORQ}}$  signals become active during this cycle.

**IORQ.** I/O Request (Output, active Low, 3-state). **IORQ** indicates that the address bus contains a valid I/O address for an I/O READ or I/O WRITE operation. **IORQ** is also generated, along with  $\overline{M1}$ , during the acknowledgment of the INTO input signal to indicate that an interrupt response vector can be place onto the data bus. This signal is analogous to the IOE signal of the Z64180.

**M1.** Machine Cycle 1 (Output, active Low). Together with  $\overline{\text{MREQ}}$ ,  $\overline{\text{M1}}$  indicates that the current cycle is the opcodefetch cycle of instruction execution. Together with  $\overline{\text{IORQ}}$ ,  $\overline{\text{M1}}$  indicates that the current cycle is for interrupt acknowledgment. It is also used with the  $\overline{\text{HALT}}$  and ST signal to decode the status of the CPU machine cycle. This signal is analogous to the  $\overline{\text{LIR}}$  signal of the Z64180.

**MREQ.** Memory Request (Output, active Low, 3-state). **MREQ** indicates that the address bus holds a valid address for a memory READ or memory WRITE operation. This signal is analogous to the  $\overline{\text{ME}}$  signal of Z64180.

**NMI.** Nonmaskable Interrupt (Input, negative edge triggered).  $\overline{\text{NMI}}$  demands a higher priority than  $\overline{\text{INT}}$  and is al-

## PIN DESCRIPTIONS (Continued)

ways recognized at the end of an instruction, regardless of the state of the interrupt-enable flip-flops. This signal forces CPU execution to continue at location 0066H.

**PHI.** System Clock (Output). The output is used as a reference clock for the MPU and the external system. The frequency of this output may be one-half, equal to, or twice the crystal or input clock frequency.

**RD.** Read (Output, active Low, 3-state). **RD** indicates that the CPU wants to read data from either memory or an I/O device. The addressed I/O or memory device should use this signal to gate data onto the CPU data bus.

**RFSH**. Refresh (Output, active Low). Together with  $\overline{\text{MREQ}}$ , RFSH indicates that the current CPU machine cycle and the contents of the address bus should be used for refresh of dynamic memories. The low-order 8 bits of the address bus (A7–A0) contain the refresh address. *This signal is analogous* to the  $\overline{REF}$  signal of the Z64180.

**RTSO**. Request to Send 0 (Output, active Low); a programmable MODEM control signal for ASCI channel 0.

**RXA0**, **RXA1**. Receive Data 0 and 1 (Input). These signals are the receive data for the ASCI channels.

**RXS.** Clocked Serial Receive Data (Input). This line is the receive data for the CSI/O channel. RXS is multiplexed with the  $\overline{\text{CTS1}}$  signal for ASCI channel 1.

**ST.** Status (Output). This signal is used with the  $\overline{M1}$  and  $\overline{HALT}$  output to decode the status of the CPU machine cycle. See Table 3.

Table 3. Status Summary

| ST                         | HALT                                           | <u>M1</u> | Operation                                       |  |
|----------------------------|------------------------------------------------|-----------|-------------------------------------------------|--|
| 0                          | 1                                              | 0         | CPU Operation (1st Opcode Fetch)                |  |
| 1                          | 1                                              | 0         | CPU Operation (2nd Opcode and 3rd Opcode Fetch) |  |
| 1                          | 1                                              | 1         | CPU Operation (MC Except Opcode Fetch)          |  |
| 0                          | Х                                              | 1         | DMA Operation                                   |  |
| 0                          | 0                                              | 0         | HALT Mode                                       |  |
| 1                          | 0 1 SLEEP Mode (Including SYSTEM<br>STOP Mode) |           |                                                 |  |
| Notes:<br>X = Do not care. |                                                |           |                                                 |  |

MC = Machine Cycle.

**TENDO**, **TEND1**. Transfer End 0 and 1 (Outputs, active Low). This output is asserted active during the most recent WRITE cycle of a DMA operation. It is used to indicate the end of the block transfer. **TENDO** is multiplexed with CKA1.

**TEST.** Test (Output, not in DIP version). This pin is for test and should be left open.

 $T_{OUT}$ . Timer Out (Output).  $T_{OUT}$  is the output from PRT channel 1. This line is multiplexed with A18 of the address bus.

**TXAO, TXA1.** Transmit Data 0 and 1 (Outputs). These signals are the transmitted data from the ASCI channels. Transmitted data changes are with respect to the falling edge of the transmit clock.

**TXS.** Clocked Serial Transmit Data (Output). This line is the transmitted data from the CSI/O channel.

**WAIT.** Wait (Input, active Low). WAIT indicates to the MPU that the addressed memory or I/O devices are not ready for data transfer. This input is sampled on the falling edge of T2 (and subsequent WAIT states). If the input is sampled Low, then the additional WAIT states are inserted until the WAIT input is sampled High, at which time execution continues.

**WR.** WRITE (Output, active Low, 3-state). WR indicates that the CPU data bus holds valid data to be stored at the addressed I/O or memory location.

**XTAL.** Crystal Oscillator Connection (Input). This pin should be left open if an external clock is used instead of a crystal. The oscillator input is not a TTL level (see <u>DC Characteristics</u>).

Several pins are used for different conditions, depending on the circumstance.



Figure 7. CSI/O Block Diagram

# **OPERATION MODES**

**Z80 versus 64180 Compatibility.** The Z8S180/Z8L180 is descended from two different "ancestor" processors, ZiLOG's original Z80 and the Hitachi 64180. The Operating Mode Control Register (OMCR), illustrated in Figure 8, can be programmed to select between certain Z80 and 64180 differences.



Figure 8. Operating Control Register (OMCR: I/O Address = 3EH)

**M1E** ( $\overline{M1}$  Enable). This bit controls the  $\overline{M1}$  output and is set to a 1 during RESET.

When M1E = 1, the  $\overline{M1}$  output is asserted Low during opcode fetch cycles, Interrupt Acknowledge cycles, and the first machine cycle of an  $\overline{NMI}$  acknowledge.

On the Z8S180/Z8L180, this choice makes the processor fetch a RETI instruction one time. When fetching a RETI from a zero-wait-state memory location, the processor uses three clock bus cycles. These bus cycles are not fully Z80-timing compatible.

When M1E = 0, the processor does not drive  $\overline{M1}$  Low during the instruction fetch cycles. After fetching a RETI instruction with normal timing, the processor goes back and refetches the instruction using fully Z80-compatible cycles that include driving  $\overline{M1}$  Low. This option may be required by some external Z80 peripherals to properly decode the RETI instruction. Figure 9 and Table 5 show the RETI sequence when M1E is 0.



Figure 9. RETI Instruction Sequence with M1E = 0

## **OPERATION MODES** (Continued)

The Z8S180/Z8L180 leaves HALT mode in response to:

- Low on RESET
- Interrupt from an enabled on-chip source
- External request on NMI
- Enabled external request on INTO, INT1, or INT2

In case of an interrupt, the return address is the instruction following the HALT instruction. The program can either branch back to the HALT instruction to wait for another interrupt or can examine the new state of the system/application and respond appropriately.





**SLEEP Mode**. This mode is entered by keeping the IOSTOP bit (ICR5) and bits 3 and 6 of the CPU Control Register (CCR3, CCR6) all zero and executing the SLP instruction. The oscillator and PHI output continue operating, but are blocked from the CPU core and DMA channels to reduce power consumption. DRAM refresh stops, but interrupts and granting to an external Master can occur. Except when the bus is granted to an external Master, A19–0 and all control signals except HALT are maintained High. HALT is Low. I/O operations continue as before the SLP instruction, except for the DMA channels.

The Z8S180/Z8L180 leaves SLEEP mode in response to a Low on RESET, an interrupt request from an on-chip source,

an external request on  $\overline{\text{NMI}}$ , or an external request on  $\overline{\text{INTO}}$ ,  $\overline{\text{INT1}}$ , or  $\overline{\text{INT2}}$ .

If an interrupt source is individually disabled, it cannot bring the Z8S180/Z8L180 out of SLEEP mode. If an interrupt source is individually enabled, and the IEF bit is 1 so that interrupts are globally enabled (by an EI instruction), the highest priority active interrupt occurs with the return address being the instruction after the SLP instruction. If an interrupt source is individually enabled, but the IEF bit is 0 so that interrupts are globally disabled (by a DI instruction), the Z8S180/Z8L180 leaves SLEEP mode by simply executing the following instruction(s).



Figure 15. Z8S180/Z8L180 IDLE Mode Exit Due To External Interrupt

While the Z8S180/Z8L180 is in IDLE mode, it grants the bus to an external Master if the BREXT bit (CCR5) is 1. Figure 16 depicts the timing for this sequence.

**Note:** A response to a bus request takes 8 clock cycles longer than in normal operation.

After the external Master negates the Bus Request, the Z8S180/Z8L180 disables the PHI clock and remains in IDLE mode.

ing the bus to an external Master during STANDBY mode, when the BREXT bit in the CPU Control Register (CCR5) is 1.

As described previously for SLEEP and IDLE modes, when the MPU leaves STANDBY mode due to  $\overline{\text{NMI}}$  Low or an enabled  $\overline{\text{INTO}}$ - $\overline{\text{INT2}}$  Low when the IEF, flag is 1 due to an IE instruction, it starts by performing the interrupt with the return address being that of the instruction following the SLP instruction. If the Z8S180/Z8L180 leaves STANDBY mode due to an external interrupt request that's enabled in the INT/TRAP Control Register, but the IEF, bit is 0 due to a DI instruction, the processor restarts by executing the instruction(s) following the SLP instruction. If  $\overline{INTO}$ , or  $\overline{INT1}$ or  $\overline{INT2}$  goes inactive before the end of the clock stabilization delay, the Z8S180/Z8L180 stays in STANDBY mode.

Figure 17 indicates the timing for leaving STANDBY mode due to an interrupt request.

**Note:** The Z8S180/Z8L180 takes either 64 or  $2^{17}$  (131,072) clocks to restart, depending on the CCR3 bit.



While the Z8S180/Z8L180 is in STANDBY mode, it grants the bus to an external Master if the BREXT bit (CCR5) is 1. Figure 18 indicates the timing of this sequence. The device takes 64 or  $2^{17}$  (131,072) clock cycles to grant the bus depending on the CCR3 bit. The latter (not the QUICK RE-COVERY) case may be prohibitive for many demand-driven external Masters. If so, QUICK RECOVERY or IDLE mode can be used.

# AC CHARACTERISTICS – Z8S180 (Continued)

| Table 8. Z8S180 AC Characteristics (Continued)                                                         |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| $V_{DD} = 5V \pm 10\%$ or $V_{DD} = 3.3V \pm 10\%$ ; 33-MHz Characteristics Apply Only to 5V Operation |  |  |  |  |  |

|        |                   |                                                              | Z8S180 | —20 MHz                     | Z8S180 | —33 MHz                    |      |
|--------|-------------------|--------------------------------------------------------------|--------|-----------------------------|--------|----------------------------|------|
| Number | Symbol            | ltem                                                         | Min    | Max                         | Min    | Max                        | Unit |
| 32     | t <sub>INTH</sub> | INT Hold Time from PHI Fall                                  | 10     | _                           | 10     | _                          | ns   |
| 33     | t <sub>NMIW</sub> | NMI Pulse Width                                              | 35     | _                           | 25     | _                          | ns   |
| 34     | t <sub>BRS</sub>  | BUSREQ Set-up Time to PHI Fall                               | 10     | _                           | 10     | _                          | ns   |
| 35     | t <sub>BRH</sub>  | BUSREQ Hold Time from PHI Fall                               | 10     | _                           | 10     |                            | ns   |
| 36     | t <sub>BAD1</sub> | PHI Rise to BUSACK Fall Delay                                | _      | 25                          | _      | 15                         | ns   |
| 37     | t <sub>BAD2</sub> | PHI Fall to BUSACK Rise Delay                                | _      | 25                          | _      | 15                         | ns   |
| 38     | t <sub>BZD</sub>  | PHI Rise to Bus Floating Delay Time                          | _      | 40                          | _      | 30                         | ns   |
| 39     | t <sub>MEWH</sub> | MREQ Pulse Width (High)                                      | 35     | —                           | 25     | —                          | ns   |
| 40     | t <sub>MEWL</sub> | MREQ Pulse Width (Low)                                       | 35     | _                           | 25     | _                          | ns   |
| 41     | t <sub>RFD1</sub> | PHI Rise to RFSH Fall Delay                                  | _      | 20                          |        | 15                         | ns   |
| 42     | t <sub>RFD2</sub> | PHI Rise to RFSH Rise Delay                                  | _      | 20                          |        | 15                         | ns   |
| 43     | t <sub>HAD1</sub> | PHI Rise to HALT Fall Delay                                  | _      | 15                          |        | 15                         | ns   |
| 44     | t <sub>HAD2</sub> | PHI Rise to HALT Rise Delay                                  | _      | 15                          | _      | 15                         | ns   |
| 45     | t <sub>DRQS</sub> | DREQ1 Set-up Time to PHI Rise                                | 20     | _                           | 15     | _                          | ns   |
| 46     | t <sub>DRQH</sub> | DREQ1 Hold Time from PHI Rise                                | 20     | _                           | 15     | _                          | ns   |
| 47     | t <sub>TED1</sub> | PHI Fall to TENDi Fall Delay                                 | _      | 25                          | _      | 15                         | ns   |
| 48     | t <sub>TED2</sub> | PHI Fall to TENDi Rise Delay                                 | _      | 25                          | _      | 15                         | ns   |
| 49     | t <sub>ED1</sub>  | PHI Rise to E Rise Delay                                     | _      | 30                          | _      | 15                         | ns   |
| 50     | t <sub>ED2</sub>  | PHI Fall or Rise to E Fall Delay                             | _      | 30                          | _      | 15                         | ns   |
| 51     | P <sub>WEH</sub>  | E Pulse Width (High)                                         | 25     | _                           | 20     | _                          | ns   |
| 52     | P <sub>WEL</sub>  | E Pulse Width (Low)                                          | 50     | _                           | 40     | _                          | ns   |
| 53     | t <sub>Er</sub>   | Enable Rise Time                                             | _      | 10                          | _      | 10                         | ns   |
| 54     | t <sub>Ef</sub>   | Enable Fall Time                                             | _      | 10                          | _      | 10                         | ns   |
| 55     | t <sub>TOD</sub>  | PHI Fall to Timer Output Delay                               | _      | 75                          | _      | 50                         | ns   |
| 56     | t <sub>STDI</sub> | CSI/O Transmit Data Delay Time (Internal<br>Clock Operation) | _      | 2                           | _      | 2                          | tcyc |
| 57     | t <sub>STDE</sub> | CSI/O Transmit Data Delay Time (External Clock Operation)    | _      | 7.5 t <sub>CYC</sub><br>+75 | —      | 75 t <sub>CYC</sub><br>+60 | ns   |
| 58     | t <sub>SRSI</sub> | CSI/O Receive Data Set-up Time (Internal<br>Clock Operation) | 1      | _                           | 1      | _                          | tcyc |
| 59     | t <sub>SRHI</sub> | CSI/O Receive Data Hold Time (Internal<br>Clock Operation)   | 1      | _                           | 1      | _                          | tcyc |
| 60     | t <sub>SRSE</sub> | CSI/O Receive Data Set-up Time (External<br>Clock Operation) | 1      | _                           | 1      | _                          | tcyc |
| 61     | t <sub>SRHE</sub> | CSI/O Receive Data Hold Time (External<br>Clock Operation)   | 1      | _                           | 1      | _                          | tcyc |
| 62     | t <sub>RES</sub>  | RESET Set-up Time to PHI Fall                                | 40     | _                           | 25     | _                          | ns   |
|        |                   |                                                              |        |                             |        |                            |      |

|        |                  |                                       | Z8S180- | —20 MHz | Z8S180- | –33 MHz |      |
|--------|------------------|---------------------------------------|---------|---------|---------|---------|------|
| Number | Symbol           | Item                                  | Min     | Max     | Min     | Max     | Unit |
| 63     | t <sub>REH</sub> | RESET Hold Time from PHI Fall         | 25      | _       | 15      | _       | ns   |
| 64     | t <sub>osc</sub> | Oscillator Stabilization Time         | _       | 20      | _       | 20      | ns   |
| 65     | t <sub>EXR</sub> | External Clock Rise Time (EXTAL)      | _       | 5       |         | 5       | ns   |
| 66     | t <sub>EXF</sub> | External Clock Fall Time (EXTAL)      | _       | 5       | _       | 5       | ns   |
| 67     | t <sub>RR</sub>  | RESET Rise Time                       | —       | 50      |         | 50      | ms   |
| 68     | t <sub>RF</sub>  | RESET Fall Time                       | —       | 50      |         | 50      | ms   |
| 69     | t <sub>IR</sub>  | Input Rise Time (except EXTAL, RESET) | _       | 50      |         | 50      | ns   |
| 70     | t <sub>IF</sub>  | Input Fall Time (except EXTAL, RESET) | —       | 50      | —       | 50      | ns   |

# Table 8. Z8S180 AC Characteristics (Continued) $V_{DD} = 5V \pm 10\%$ or $V_{DD} = 3.3V \pm 10\%$ ; 33-MHz Characteristics Apply Only to 5V Operation



Figure 21. CPU Timing (INTO Acknowledge Cycle, Refresh Cycle, BUS RELEASE Mode, HALT Mode, SLEEP Mode, SYSTEM STOP Mode)

#### TIMING DIAGRAMS (Continued)



#### Notes:

 $^{*}T_{\text{DRQS}}$  and  $T_{\text{DRQH}}$  are specified for the rising edge of the clock followed by  $T_{3}.$ 

 $^{*\,*}T_{DRQS}$  and  $T_{DRQH}$  are specified for the rising edge of the clock.

#### Figure 23. DMA Control Signals



Figure 29. CSI/O Receive/Transmit Timing



External Clock Rise Time and Fall Time Input Rise Time and Fall Time (Except EXTAL, RESET)

Figure 30. Rise Time and Fall Times

# ASCI CHANNEL CONTROL REGISTER A (Continued)

vious contents of TDRE are held. TE is cleared to 0 in IOSTOP mode during RESET.

**RTSO:** Request to Send Channel 0 (Bit 4 in CNTLA0 Only). If bit 4 of the System Configuration Register is 0, the RTSO/TXS pin exhibits the RTSO function. RTSO allows the ASCI to control (start/stop) another communication devices transmission (for example, by connecting to that device's  $\overline{CTS}$  input). RTSO is essentially a 1-bit output port, having no side effects on other ASCI registers or flags.

Bit 4 in CNTLA1 is used.

 $CKA1D = 1, CKA1/\overline{TEND0} pin = \overline{TEND0}$ 

 $CKA1D = 0, CKA1/\overline{TEND0} pin = CKA1$ 

These bits are cleared to 0 on reset.

**MPBR/EFR:** Multiprocessor Bit Receive/Error Flag Reset (Bit 3). When multiprocessor mode is enabled (MP in CNTLB = 1), MPBR, when read, contains the value of the MPB bit for the most recent receive operation. When written to 0, the EFR function is selected to reset all error flags (OVRN, FE, PE and BRK in the ASEXT Register) to 0. MPBR/EFR is undefined during RESET.

#### MOD2, 1, 0: ASCI Data Format Mode 2,1,0 (bits 2-0).

These bits program the ASCI data format as follows.

#### MOD2

- $= 0 \rightarrow 7$  bit data
- $= 1 \rightarrow 8$  bit data

MOD1

- $= 0 \rightarrow No parity$
- = 1→Parity enabled

#### MOD0

=  $0 \rightarrow 1$  stop bit =  $1 \rightarrow 2$  stop bits

The data formats available based on all combinations of MOD2, MOD1, and MOD0 are indicated in Table 9.

Table 9. Data Formats

| MOD2 | MOD1 | MOD0 | Data Format                             |
|------|------|------|-----------------------------------------|
| 0    | 0    | 0    | Start + 7 bit data + 1 stop             |
| 0    | 0    | 1    | Start + 7 bit data + 2 stop             |
| 0    | 1    | 0    | Start + 7 bit data + parity +<br>1 stop |
| 0    | 1    | 1    | Start + 7 bit data + parity + 2 stop    |
| 1    | 0    | 0    | Start + 8 bit data + 1 stop             |
| 1    | 0    | 1    | Start + 8 bit data + 2 stop             |
| 1    | 1    | 0    | Start + 8 bit data + parity +<br>1 stop |
| 1    | 1    | 1    | Start + 8 bit data + parity +<br>2 stop |

40

ASCIO requests an interrupt when  $\overline{\text{DCDO}}$  goes High. RIE is cleared to 0 by RESET.

**DCDO:** Data Carrier Detect (Bit 2 STATO). This bit is set to 1 when the pin is High. It is cleared to 0 on the first READ of STATO following the pin's transition from High to Low and during RESET. When bit 6 of the ASEXTO register is 0 to select auto-enabling, and the pin is negated (High), the receiver is reset and its operation is inhibited.

**CTS1E**: **Clear To Send (Bit 2 STAT1).** Channel 1 features an external  $\overline{\text{CTS1}}$  input, which is multiplexed with the receive data pin RSX for the CSI/O. Setting this bit to 1 selects the CTS1 function; clearing the bit to 0 selects the RXS function.

**TDRE: Transmit Data Register Empty (Bit 1).** TDRE = 1 indicates that the TDR is empty and the next transmit data byte is written to TDR. After the byte is written to TDR, TDRE is cleared to 0 until the ASCI transfers the byte from TDR to the TSR and then TDRE is again set to 1. TDRE is set to 1 in IOSTOP mode and during RESET. On ASCIO, if the CTSO pin is auto-enabled in the ASEXTO register and the pin is High, TDRE is reset to 0.

**TIE: Transmit Interrupt Enable (Bit 0).** TIE should be set to 1 to enable ASCI transmit interrupt requests. If TIE = 1, an interrupt is requested when TDRE = 1. TIE is cleared to 0 during RESET.

## ASCI TRANSMIT DATA REGISTERS

Register addresses 06H and 07H hold the ASCI transmit data for channel 0 and channel 1, respectively.

## **ASCI Transmit Data Registers Channel 0**

#### Mnemonic TDR0 Address 06H



Figure 36. ASCI Register

## **ASCI Transmit Data Registers Channel 1**

Mnemonic TDR1 Address 07H



Figure 37. ASCI Register

## DMA BYTE COUNT REGISTER CHANNEL 0

The DMA Byte Count Register Channel 0 specifies the number of bytes to be transferred. This register contains 16 bits and may specify up to 64-KB transfers. When one byte is transferred, the register is decremented by one. If n bytes should be transferred, n must be stored before the DMA operation.

**Note:** All DMA Count Register channels are undefined during RESET.

#### **DMA Byte Count Register Channel 0 Low**

Mnemonic BCR0L Address 26H





## DMA Byte Count Register Channel 0 High

Mnemonic BCR0H Address 27H



Figure 62. DMA Byte Count Register 0 High

## DMA Byte Count Register Channel 1 Low

Mnemonic BCR1L Address 2EH



Figure 63. DMA Byte Count Register 1 Low

#### DMA Byte Count Register Channel 1 High

Mnemonic BCR1H Address 2FH



Figure 64. DMA Byte Count Register 1 High

Table 16 indicates all DMA transfer mode combinations of DMO, DM1, SMO, and SM1. Because I/O to/from I/O transfers are not implemented, 12 combinations are available.

| DM1        | DM0         | SM1        | SM0  | Transfer Mode   | Address Increment/Decrement |
|------------|-------------|------------|------|-----------------|-----------------------------|
| 0          | 0           | 0          | 0    | Memory→Memory   | SAR0 + 1, DAR0 + 1          |
| 0          | 0           | 0          | 1    | Memory→Memory   | SAR0-1, DAR0+1              |
| 0          | 0           | 1          | 0    | Memory*→Memory  | SAR0 fixed, DAR0+1          |
| 0          | 0           | 1          | 1    | I/O→Memory      | SAR0 fixed, DAR0+1          |
| 0          | 1           | 0          | 0    | Memory→Memory   | SAR0+1, DAR0-1              |
| 0          | 1           | 0          | 1    | Memory→Memory   | SAR0-1, DAR0-1              |
| 0          | 1           | 1          | 0    | Memory *→Memory | SAR0 fixed, DAR0-1          |
| 0          | 1           | 1          | 1    | I/O→Memory      | SAR0 fixed, DAR0-1          |
| 1          | 0           | 0          | 0    | Memory→Memory * | SAR0+1, DAR0 fixed          |
| 1          | 0           | 0          | 1    | Memory→Memory * | SAR0-1, DAR0 fixed          |
| 1          | 0           | 1          | 0    | Reserved        |                             |
| 1          | 0           | 1          | 1    | Reserved        |                             |
| 1          | 1           | 0          | 0    | Memory→I/O      | SAR0+1, DAR0 fixed          |
| 1          | 1           | 0          | 1    | Memory→I/O      | SAR0-1, DAR0 fixed          |
| 1          | 1           | 1          | 0    | Reserved        |                             |
| 1          | 1           | 1          | 1    | Reserved        |                             |
| ote: * Inc | cludes memo | ory mapped | I/O. |                 |                             |

#### Table 16. Transfer Mode Combinations

**MMOD: Memory Mode Channel 0 (Bit 1).** When channel 0 is configured for memory to/from memory transfers there is no Request Handshake signal to control the transfer timing. Instead, two automatic transfer timing modes are selectable: burst (MMOD = 1) and cycle steal (MMOD = 0). For burst memory to/from memory transfers, the DMAC takes control of the bus continuously until the DMA transfer

completes (as indicated by the byte count register = 0). In cycle steal mode, the CPU is provided a cycle for each DMA byte transfer cycle until the transfer is completed.

For channel 0 DMA with I/O source or destination, the selected Request signal times the transfer ignoring MMOD. MMOD is cleared to 0 during RESET.

# DMA/WAIT CONTROL REGISTER

The DMA/WAIT Control Register (DCNTL) controls the insertion of wait states into DMAC (and CPU) accesses of memory or I/O. Also, the register defines the Request signal

for each channel as level or edge sense. DCNTL also sets the DMA transfer mode for channel 1, which is limited to memory to/from I/O transfers.



Figure 73. DMA/WAIT Control Register (DCNTL: I/O Address = 32H)

**MWI1, MWI0: Memory Wait Insertion (Bits 7–6).** This bit specifies the number of wait states introduced into CPU or DMAC memory access cycles. MWI1 and MWI0 are set to 1 during RESET.

| MWI1 | MWIO | Wait State |
|------|------|------------|
| 0    | 0    | 0          |
| 0    | 1    | 1          |
| 1    | 0    | 2          |
| 1    | 1    | 3          |
|      |      |            |

**IWI1, IWI0: I/O Wait Insertion (Bits 5–4).** This bit specifies the number of wait states introduced into CPU or DMAC I/O access cycles. IWI1 and IWI0 are set to 1 during RESET.

| IWI1 | IWIO | Wait State |
|------|------|------------|
| 0    | 0    | 1          |
| 0    | 1    | 2          |
| 1    | 0    | 3          |
| 1    | 1    | 4          |
|      |      |            |

**Note:** These wait states are added to the 3-clock I/O cycle that is used to access the on-chip I/O registers. It is equally valid to regard these as 0 to 3 wait states added to a 4-clock external I/O cycle.

DMS1, DMS0: DMA Request Sense (Bits 3–2). DMS1 and DMS0 specify the DMA request sense for channel 0 and channel 1 respectively. When reset to 0, the input is level sense. When set to 1, the input is edge sense. DMS1 and DMS0 are cleared to 0 during RESET.

| DMSi | Sense       |
|------|-------------|
| 1    | Edge Sense  |
| 0    | Level Sense |

Typically, for an input/source device, the associated DMS bit should be programmed as 0 for level sense. The device takes a relatively long time to update its Request signal after the DMA channel reads data (in the first of the two machine cycles involved in transferring a byte).

An output/destination device takes much less time to update its Request signal after the DMA channel starts a WRITE operation to it (the second machine cycle of the two cycles involved in transferring a byte). With zero-wait state I/O cycles, a device cannot update its request signal in the required time, so edge sensing must be used.

A one-wait-state I/O cycle also does not provide sufficient time for updating, so edge sensing is again required.

**DIM1, DIMO: DMA Channel 1 I/O and Memory Mode** (Bits 1–0). Specifies the source/destination and address modifier for channel 1 memory to/from I/O transfer modes. DIM1 and DIMO are cleared to 0 during RESET.

Table 17. Channel 1 Transfer Mode

| DIM1 | DMI0 | Transfer Mode | Address<br>Increment/Decrement |
|------|------|---------------|--------------------------------|
| 0    | 0    | Memory→I/O    | MAR1 +1, IAR1 fixed            |
| 0    | 1    | Memory→I/O    | MAR1 -1, IAR1 fixed            |
| 1    | 0    | I/O→Memory    | IAR1 fixed, MAR1 +1            |
| 1    | 1    | I/O→Memory    | IAR1 fixed, MAR1 -1            |



Figure 76. TRAP Timing-3<sup>rd</sup> Opcode Undefined