

# DS80C310 High-Speed Micro

#### www.maxim-ic.com

## **FEATURES**

- 80C32-compatible
  - 8051 pin- and instruction set-compatible
  - Full duplex serial port
  - Three 16-bit timer/counters
  - 256 bytes scratchpad RAM
  - Multiplexed address/data bus
  - Addresses 64 kB ROM and 64 kB RAM
- High-Speed Architecture
  - 4 clocks/machine cycle (8051 = 12)
  - Runs DC to 33 MHz clock rates
  - Single-cycle instruction in 121 ns
  - Dual data pointer
  - Optional variable length MOVX to access fast/slow RAM /peripherals
- 10 total interrupt sources with 6 external
- Internal power-on reset circuit
- Upwardly compatible with the DS80C320
- Available in 40-pin PDIP, 44-pin PLCC, and 44-pin TQFP

#### PACKAGE OUTLINE





#### DESCRIPTION

The DS80C310 is a fast 80C31/80C32-compatible microcontroller. It features a redesigned processor core without wasted clock and memory cycles. As a result, it executes every 8051 instruction between 1.5 and 3 times faster than the original architecture for the same crystal speed. Typical applications will see a speed improvement of 2.5 times using the same code and the same crystal. The DS80C310 offers a

**Note:** Some revisions of this device may incorporate deviations from published specifications known as errata. Multiple revisions of any device may be simultaneously available through various sales channels. For information about device errata, click here: <a href="http://www.maxim-ic.com/errata">http://www.maxim-ic.com/errata</a>.

1 of 23 012401

maximum crystal speed of 33 MHz, resulting in apparent execution speeds of 82.5 MHz (approximately 2.5X).

The DS80C310 is pin-compatible with the standard 80C32 and includes standard resources such as three timer/counters, 256 bytes of RAM, and a serial port. It also provides dual data pointers (DPTRs) to speed block data memory moves. It also can adjust the speed of MOVX data memory access between two and nine machine cycles for flexibility in selecting external memory and peripherals. The DS80C310 offers upward compatibility with the DS80C320.

## ORDERING INFORMATION:

| PART<br>NUMBER | PACKAGE            | MAX. CLOCK SPEED | TEMPERATURE<br>RANGE |
|----------------|--------------------|------------------|----------------------|
| DS80C310-MCG   | 40-pin plastic DIP | 25 MHz           | 0°C to 70°C          |
| DS80C310-QCG   | 44-pin PLCC        | 25 MHz           | 0°C to 70°C          |
| DS80C310-ECG   | 44-pin TQFP        | 25 MHz           | 0°C to 70°C          |
| DS80C310-MCL   | 40-pin plastic DIP | 33 MHz           | 0°C to 70°C          |
| DS80C310-QCL   | 44-pin PLCC        | 33 MHz           | 0°C to 70°C          |
| DS80C310-ECL   | 44-pin TQFP        | 33 MHz           | 0°C to 70°C          |

# **DS80C310 BLOCK DIAGRAM** Figure 1



# **PIN DESCRIPTION** Table 1

|     |       | TION         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|-------|--------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIP | PLCC  | TQFP         | SIGNAL<br>NAME | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 40  | 44    | 38           | $V_{CC}$       | V <sub>CC</sub> -+5V.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 20  | 22,23 | 16,17,       | GND            | GND- Digital circuit ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     | 1     | 39           |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9   | 10    | 4            | RST            | <b>RST - Input</b> . The RST input pin contains a Schmitt voltage input to recognize external active high reset inputs. The pin also employs an internal pulldown resistor to allow for a combination of wired OR external Reset sources.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 18  | 20    | 14           | XTAL2          | <b>XTAL1, XTAL2</b> - The crystal oscillator pins XTAL1 and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19  | 21    | 15           | XTAL1          | XTAL2 provide support for parallel resonant, AT cut crystals. XTAL1 acts also as an input in the event that an external clock source is used in place of a crystal. XTAL2 serves as the output of the crystal amplifier.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 29  | 32    | 26           | PSEN           | PSEN - Output. The Program Store Enable output. This signal is commonly connected to external ROM memory as a chip enable. PSEN is active low. PSEN is driven high when data memory (RAM) is being accessed through the bus and during a reset condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 30  | 33    | 27           | ALE            | ALE - Output. The Address Latch Enable output functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |       |              |                | as clock to latch the external address LSB from the multiplexed address/data bus on Port 0. This signal is commonly connected to the latch enable of an external 373 family transparent latch.ALE is forced high when the DS80C310 is in a Reset condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 39  | 43    | 37           | AD0 (P0.0)     | AD0-7 (Port 0) - I/O. Port 0 is the multiplexed address/data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 38  | 42    | 36           | AD1 (P0.1)     | bus. During the time when ALE is high, the LSB of a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 37  | 41    | 35           | AD2 (P0.2)     | memory address is presented. When ALE falls to a logic 0,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 36  | 40    | 34           | AD3 (P0.3)     | the port transitions to a bidirectional data bus. This bus is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 35  | 39    | 33           | AD4 (P0.4)     | used to read external ROM and read/write external RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 34  | 38    | 32           | AD5 (P0.5)     | memory or peripherals. Port 0 has no true port latch and can                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 33  | 37    | 31           | AD6 (P0.6)     | not be written directly by software. The reset condition of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 32  | 36    | 30           | AD7 (P0.7)     | Port 0 is high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1-8 | 2-9   | 40-44<br>1-3 | P1.0-P1.7      | Port 1 - I/O. Port 1 functions as both an 8-bit bidirectional I/O port and an alternate functional interface for Timer 2 I/O and new External Interrupts. The reset condition of Port 1 is with all bits at a logic 1. In this state, a weak pullup holds the port high. This condition also serves as an input mode, since any external circuit that writes to the port will overcome the weak pullup. When software writes a 0 to any port pin, the DS80C310 will activate a strong pulldown that remains on until either a 1 is written or a reset occurs. Writing a 1 after the port has been at 0 will cause a strong transition driver to turn on, followed by a weaker sustaining pullup. Once the momentary strong driver turns off, the port once again becomes the output high (and input) state. The alternate modes of Port 1 are outlined as follows: |

| DIP      | PLCC     | TQFP     | SIGNAL<br>NAME  | DESCRIPTION                                                              |
|----------|----------|----------|-----------------|--------------------------------------------------------------------------|
|          |          |          | 1111112         | Port Alternate Function                                                  |
| 1        | 2        | 40       |                 | P1.0 T2 External I/O for Timer/Counter 2                                 |
| 2        | 3        | 41       |                 | P1.1 T2EX Timer/Counter 2 Capture/Reload Trigger                         |
| 3        | 4        | 42       |                 | P1.2 none (DS80C320 has a serial port RXD)                               |
| 4        | 5        | 43       |                 | P1.3 none (DS80C320 has a serial port TXD)                               |
| 5        | 6        | 44       |                 | P1.4 INT2 External Interrupt 2 (Positive Edge Detect)                    |
| 6        | 7        | 1        |                 | P1.5 INT3 External Interrupt 3 (Negative Edge Detect)                    |
| 7        | 8        | 2        |                 | P1.6 INT4 External Interrupt 4 (Positive Edge Detect)                    |
| 8        | 9        | 3        |                 | P1.7 INT5 External Interrupt 5 (Negative Edge Detect)                    |
| 21       | 24       | 18       | A8 (P2.0)       | <b>A8-15 (Port 2) -Output.</b> Port 2 serves as the MSB for external     |
| 22       | 25       | 19       | A9 (P2.1)       | addressing. P2.7 is A15 and P2.0 is A8. The DS80C310 will                |
| 23       | 26       | 20       | A10(P2.2)       | automatically place the MSB of an address on P2 for external             |
| 24       | 27       | 21       | A11(P2.3)       | ROM and RAM access. Although Port 2 can be accessed like                 |
| 25       | 28       | 22       | A12(P2.4)       | an ordinary I/O port, the value stored on the Port 2 latch will          |
| 26       | 29       | 23       | A13 P2.5)       | never be seen on the pins (due to memory access). Therefore              |
| 27       | 30       | 24       | A14(P2.6)       | writing to Port 2 in software is only useful for the instructions        |
| 28       | 31       | 25       | A15(P2.7)       | MOVX A, @ Ri or MOVX @ Ri, A. These instructions use the                 |
|          |          |          |                 | Port 2 internal latch to supply the external address MSB; the            |
|          |          |          |                 | Port 2 latch value will be supplied as the address information.          |
| 10-17    | 11,      | 5,7-13   | P3.0-3.7        | <b>Port 3 - I/O.</b> Port 3 functions as both an 8-bit bidirectional I/O |
|          | 13-19    |          |                 | port and an alternate functional interface for external Interrupts,      |
|          |          |          |                 | Serial Port 0, Timer 0 and 1 Inputs, RD and WR strobes. The              |
|          |          |          |                 | reset condition of Port 3 is with all bits at a logic 1. In this         |
|          |          |          |                 | state, a weak pullup holds the port high. This condition also            |
|          |          |          |                 | serves as an input mode, since any external circuit that writes          |
|          |          |          |                 | to the port will overcome the weak pullup. When software                 |
|          |          |          |                 | writes a 0 to any port pin, the DS80C310 will activate a strong          |
|          |          |          |                 | pulldown that remains on until either a 1 is written or a reset          |
|          |          |          |                 | occurs. Writing a 1 after the port has been at 0 will cause a            |
|          |          |          |                 | strong transition driver to turn on, followed by a weaker                |
|          |          |          |                 | sustaining pullup. Once the momentary strong driver turns off,           |
|          |          |          |                 | the port once again becomes both the output high and input               |
|          |          |          |                 | state. The alternate modes of Port 3 are outlined below.                 |
| 1.0      | 1.1      | ~        |                 | Port Alternate Mode                                                      |
| 10       | 11       | 5        |                 | P3.0 RXD0 Serial Port 0 Input                                            |
| 11       | 13       | 7        |                 | P3.1 TXD0 Serial Port 0 Output                                           |
| 12       | 14<br>15 | 8<br>9   |                 | P3.2 INTO External Interrupt 0                                           |
| 13       | 15<br>16 |          |                 | P3.3 INT1 External Interrupt 1                                           |
| 14<br>15 | 16<br>17 | 10<br>11 |                 | P3.4 T0 Timer 0 External Input                                           |
| 16       | 18       | 12       |                 | P3.5 T1 Timer 1 External Input                                           |
| 17       | 19       | 13       |                 | P3.6 WR External Data Memory Write Strobe                                |
|          |          |          |                 | P3.7 RD External Data Memory Read Strobe                                 |
| 31       | 35       | 29       | $\overline{EA}$ | $\overline{EA}$ - Input. This pin must be connected to ground for proper |
|          |          |          |                 | operation.                                                               |
| -        | 12       | 6        | NC              | NC - Reserved. These pins should not be connected. They                  |
|          | 34       | 28       |                 | are reserved for use with future devices in this family.                 |

## COMPATIBILITY

The DS80C310 is a fully static CMOS 8051-compatible microcontroller designed for high performance. In most cases the DS80C310 can drop into an existing socket for the 80C31 or 80C32 to improve the operation significantly. In general, software written for existing 8051-based systems works without modification on the DS80C310. The exception is critical timing since the High-Speed Micro performs its instructions much faster than the original for any given crystal selection. The DS80C310 runs the standard 8051 family instruction set and is pin compatible with DIP, PLCC or TQFP packages. The DS80C310 is a streamlined version of the DS80C320. It maintains upward compatibility but has fewer peripherals.

The DS80C310 provides three 16-bit timer/counters, a full-duplex serial port, and 256 bytes of direct RAM. I/O ports have the same operation as a standard 8051 product. Timers will default to a 12-clock per cycle operation to keep their timing compatible with original 8051 family systems. However, timers are individually programmable to run at the new 4 clocks per cycle if desired.

The DS80C310 provides several new hardware functions that are controlled by Special Function registers. A summary of the Special Function Registers is provided in Table 2.

#### PERFORMANCE OVERVIEW

The DS80C310 features a high-speed 8051 compatible core. Higher speed comes not just from increasing the clock frequency, but from a newer, more efficient design.

This updated core does not have the dummy memory cycles that are present in a standard 8051. A conventional 8051 generates machine cycles using the clock frequency divided by 12. In the DS80C310, the same machine cycle takes four clocks. Thus the fastest instruction, 1 machine cycle, executes three times faster for the same crystal frequency. Note that these are identical instructions. The majority of instructions on the DS80C310 will see the full 3 to 1 speed improvement. Some instructions will get between 1.5 and 2.4 to 1 improvement. All instructions are faster than the original 8051.

The numerical average of all opcodes gives approximately a 2.5 to 1 speed improvement. Improvement of individual programs will depend on the actual instructions used. Speed-sensitive applications would make the most use of instructions that are three times faster. However, the sheer number of 3 to 1 improved opcodes makes dramatic speed improvements likely for any code. These architecture improvements and 0.8 µm CMOS produce a peak instruction cycle in 121 ns (8.25 MIPs). The Dual Data Pointer feature also allows the user to eliminate wasted instructions when moving blocks of memory.

#### INSTRUCTION SET SUMMARY

All instructions in the DS80C310 perform the same functions as their 8051 counterparts. Their effect on bits, flags, and other status functions is identical. However, the timing of each instruction is different. This applies both in absolute and relative number of clocks.

For absolute timing of real time events, the timing of software loops can be calculated using a table in the High-Speed Microcontroller User's Guide. However, counter/timers default to run at the older 12 clocks per increment. In this way, timer-based events occur at the standard intervals with software executing at higher speed. Timers optionally can run at 4 clocks per increment to take advantage of faster processor operation.

The relative time of two instructions might be different in the new architecture than it was previously. For example, in the original architecture the "MOVX A, @ DPTR" instruction and the "MOV direct, direct" instruction used two machine cycles or 24 oscillator cycles. Therefore, they required the same amount of

time. In the DS80C310, the MOVX instruction takes as little as two machine cycles or eight oscillator cycles but the "MOV direct, direct" uses three machine cycles or 12 oscillator cycles. While both are faster than their original counterparts, they now have different execution times. This is because the DS80C310 usually uses one instruction cycle for each instruction byte. The user concerned with precise program timing should examine the timing of each instruction for familiarity with the changes. Note that a machine cycle now requires just four clocks, and provides one ALE pulse per cycle. Many instructions require only one cycle, but some require five. In the original architecture, all were one or two cycles except for MUL and DIV. Refer to the High-Speed Microcontroller User's Guide for details and individual instruction timing.

# **SPECIAL FUNCTION REGISTERS**

Special Function Registers (SFRs) control most special features of the DS80C310. The High-Speed Microcontroller User's Guide describes all SFRs. Functions that are not part of the standard 80C32 are in bold.

# **SPECIAL FUNCTION REGISTERS** Table 2

| OI LOIAL |        |       |       |       |       |       |       |        |         |
|----------|--------|-------|-------|-------|-------|-------|-------|--------|---------|
| REGISTER | BIT 7  | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0  | ADDRESS |
| SP       |        |       |       |       |       |       |       |        |         |
| DPL      |        |       |       |       |       |       |       |        |         |
| DPH      |        |       |       |       |       |       |       |        |         |
| DPL1     |        |       |       |       |       |       |       |        |         |
| DPH1     |        |       |       |       |       |       |       |        |         |
| DPS      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | SEL    |         |
| PCON     | SMOD   | SM0D0 | -     | -     | GF1   | GF0   | STOP  | IDLE   |         |
| TCON     | TF1    | TR1   | TF0   | TR0   | IE1   | IT1   | IE0   | IT0    |         |
| TMOD     | GATE   | C/T   | M1    | M0    | GATE  | C/T   | M1    | M0     |         |
| TL0      |        |       |       |       |       |       |       |        |         |
| TL1      |        |       |       |       |       |       |       |        |         |
| TH0      |        |       |       |       |       |       |       |        |         |
| TH1      |        |       |       |       |       |       |       |        |         |
| CKCON    | -      | -     | T2M   | T1M   | TOM   | MD2   | MD1   | MD0    |         |
| P1       | P1.7   | P1.6  | P1.5  | P1.4  | P1.3  | P1.2  | P1.1  | P1.0   |         |
| EXIF     | IE5    | IE4   | IE3   | IE2   | -     | -     | -     | -      |         |
| SCON     | SMO/FE | SM1   | SM2   | REN   | TB8   | RB8   | TI    | RI     |         |
| SBUF     |        |       |       |       |       |       |       |        |         |
| P2       | P2.7   | P2.6  | P2.5  | P2.4  | P2.3  | P2.2  | P2.1  | P2.0   |         |
| ΙΕ       | EA     | -     | ET2   | ES0   | ET1   | EX1   | ET0   | EX0    |         |
| SADDR0   |        |       |       |       |       |       |       |        |         |
| P3       | P3.7   | P3.6  | P3.5  | P3.4  | P3.3  | P3.2  | P3.1  | P3.0   |         |
| IP       | -      | -     | PT2   | PSO   | PT1   | PX1   | PT0   | PX0    |         |
| SADEN0   |        |       |       |       |       |       |       |        |         |
| STATUS   | 0      | HIP   | LIP   | 1     | 1     | 1     | 1     | 1      |         |
| T2CON    | TF2    | EXF2  | RCLK  | TCLK  | EXEN2 | TR2   | C/T2  | CP/RL2 |         |
| T2MOD    | -      | -     | _     | _     | _     | -     | T2OE  | DCEN   |         |
| RCAP2L   |        |       |       |       |       |       | 1202  | 2 021  |         |
| RCAP2H   |        |       |       |       |       |       |       |        |         |
| TL2      |        |       |       |       |       |       |       |        |         |
| TH2      |        |       |       |       |       |       |       |        |         |
| PSW      | CY     | AC    | F0    | RS1   | RS0   | OV    | FL    | P      |         |
| WDCON    | -      | POR   | -     | -     | -     | -     | -     | -      |         |
| ACC      |        |       |       |       |       |       |       |        |         |
| EIE      | -      | _     | _     | _     | EX5   | EX4   | EX3   | EX2    |         |
| В        |        |       |       |       |       |       |       |        |         |
| EIP      | -      | -     | -     | _     | PX5   | PX4   | PX3   | PX2    |         |

#### MEMORY ACCESS

The DS80C310 contains no on-chip ROM, and 256 bytes of scratchpad RAM. Off-chip memory is accessed using the multiplexed address/data bus on P0 and the MSB address on P2. Timing diagrams are provided in the Electrical Specifications. Program memory (ROM) is accessed at a fixed rate determined by the crystal frequency and the actual instructions. As mentioned above, an instruction cycle requires four clocks. Data memory (RAM) is accessed according to a variable speed MOVX instruction as described below.

## STRETCH MEMORY CYCLE

The DS80C310 allows the application software to adjust the speed of data memory access. The micro is capable of performing the MOVX in as few as two instruction cycles. However, this value can be stretched as needed so that both fast memory and slow memory or peripherals can be accessed with no glue logic. Even in highspeed systems, it may not be necessary or desirable to perform data memory access at full speed. In addition, there are a variety of memory mapped peripherals such as LCD displays or UARTs that are not fast.

The Stretch MOVX is controlled by the Clock Control Register at SFR location 8Eh as described below. This allows the user to select a stretch value between 0 and 7. A Stretch of 0 will result in a two-machine cycle MOVX. A Stretch of 7 will result in a MOVX of nine machine cycles. Software can dynamically change this value depending on the particular memory or peripheral.

On reset, the Stretch value will default to a one resulting in a three-cycle MOVX. Therefore, RAM access will not be performed at full speed. This is a convenience to existing designs that may not have fast RAM in place. When maximum speed is desired, the software should select a Stretch value of 0. When using very slow RAM or peripherals, a larger stretch value can be selected. Note that this affects data memory only and the only way to slow program memory (ROM) access is to use a slower crystal.

Using a Stretch value between 1 and 7 causes the microcontroller to stretch the read/write strobe and all related timing. This results in a wider read/write strobe allowing more time for memory/peripherals to respond. The timing of the variable speed MOVX is shown in the Electrical Specifications. Note that full speed access is not the reset default case. Table 3 shows the resulting strobe widths for each Stretch value. The memory stretch is implemented using the Clock Control Special Function Register at SFR location 8Eh. The stretch value is selected using bits CKCON.2-0. In the table, these bits are referred to as M2 through M0. The first stretch (default) allows the use of common 120 ns or 150 ns RAMs without dramatically lengthening the memory access.

| DATA | <b>MFMORY</b> | CYCL F | STRFTCH | VALUES Table 3 |
|------|---------------|--------|---------|----------------|
|      |               | OIOLL  |         | VALUED TABLES  |

| CK        | CON.      | 2-0 |               | RD OR WR STROBE | STROBE W. | IDTH TIME |
|-----------|-----------|-----|---------------|-----------------|-----------|-----------|
| <b>M2</b> | <b>M1</b> | M0  | MEMORY CYCLES | WIDTH IN CLOCKS | @ 25 MHz  | @ 33 MHz  |
| 0         | 0         | 0   | 2             | 2               | 80 ns     | 60ns      |
| 0         | 0         | 1   | 3(default)    | 4               | 160 ns    | 121ns     |
| 0         | 1         | 0   | 4             | 8               | 320 ns    | 242ns     |
| 0         | 1         | 1   | 5             | 12              | 480 ns    | 364ns     |
| 1         | 0         | 0   | 6             | 16              | 640 ns    | 485ns     |
| 1         | 0         | 1   | 7             | 20              | 800 ns    | 606ns     |
| 1         | 1         | 0   | 8             | 24              | 960 ns    | 727ns     |
| 1         | 1         | 1   | 9             | 28              | 1120 ns   | 848ns     |
|           |           |     |               |                 |           |           |

#### **DUAL DATA POINTER**

Data memory block moves can be accelerated using the DS80C310 Dual Data Pointer (DPTR). The standard 8032 DPTR is a 16-bit value that is used to address off-chip data RAM or peripherals. In the DS80C310, the standard data pointer is called DPTR and is located at SFR addresses 82h and 83h. These are the standard locations. No modification of standard code is needed to use DPTR. The new DPTR is located at SFR 84h and 85h and is called DPTR1. The DPTR Select bit (DPS) chooses the active pointer and is located at the lsb of the SFR location 86h. No other bits in register 86h have any effect and are set to 0. The user switches between data pointers by toggling the lsb of register 86h. The increment (INC) instruction is the fastest way to accomplish this. All DPTR-related instructions use the currently selected DPTR for any activity. Therefore only one instruction is required to switch from a source to a destination address. Using the Dual Data Pointer saves code from needing to save source and destination addresses when doing a block move. Once loaded, the software simply switches between DPTR0 and 1. The relevant register locations are as follows.

| DPL  | 82h | Low byte original DPTR  |
|------|-----|-------------------------|
| DPH  | 83h | High byte original DPTR |
| DPL1 | 84h | Low byte new DPTR       |
| DPH1 | 85h | High byte new DPTR      |
| DPS  | 86h | DPTR Select (lsb)       |

#### STOP MODE ENHANCEMENTS

Setting bit 1 of the Power Control register (PCON; 87h) invokes the Stop mode. Stop mode is the lowest power state since it turns off all internal clocking. The  $I_{CC}$  of a standard Stop mode is approximately 1  $\mu$ A (but is specified in the Electrical Specifications). The CPU will exit Stop mode from an external interrupt or a reset condition. Internally generated interrupts are not useful since they require clocking activity.

The DS80C310 allows a resume from Stop using an INT2-5, which are edge-triggered interrupts. The start-up timing is managed by an internal crystal counter. A delay of 65,536 clocks occurs to give the crystal enough time to start and stabilize.

#### PERIPHERAL OVERVIEW

The DS80C310 provides the same peripheral functions as the standard 80C32. It is compatible with the DS80C320 but does not offer all of the peripherals.

#### TIMER RATE CONTROL

There is one important difference between the DS80C310 and 8051 regarding timers. The original 8051 used 12 clocks per cycle for timers as well as for machine cycles. The DS80C310 architecture normally uses 4 clocks per machine cycle. However, in the area of timers and serial ports, the DS80C310 will default to 12 clocks per cycle on reset. This allows existing code with real-time dependencies such as baud rates to operate properly.

If an application needs higher speed timers or serial baud rates, the user can select individual timers to run at the 4-clock rate. The Clock Control register (CKCON; 8Eh) determines these timer speeds. When the relevant CKCON bit is a logic 1, the DS80C310 uses 4 clocks per cycle to generate timer speeds. When the bit is a 0, the DS80C310 uses 12 clocks for timer speeds. The reset condition is a 0. CKCON.5 selects the speed of Timer 2. CKCON.4 selects Timer 1 and CKCON.3 selects Timer 0. Note that unless a user desires very fast timing, it is unnecessary to alter these bits. Note that the timer controls are independent.

## **POWER ON RESET**

The DS80C310 will hold itself in reset during a power-up until 65,536 clock cycles have elapsed. The power-on reset used by the DS80C310 differs somewhat from other members of the High-Speed Microcontroller family. The crystal oscillator may start anywhere between 1.0V and 4.5V but is not specified. This diminates the need for an RC reset circuit. For voltage-specific precision brownout detection, an external component will be needed. When the device goes through a power-on reset, the POR flag will be set in the WDCON (D8h) register at bit 6.

## **INTERRUPTS**

The DS80C310 provides 10 interrupt sources with two priority levels. Software can assign high or low priority to all sources. All interrupts that are new to the 8051 have a lower natural priority than the originals.

## **INTERRUPT SOURCES AND PRIORITIES** Table 4

| NAME | DESCRIPTION                   | VECTOR | NATURAL<br>PRIORITY |
|------|-------------------------------|--------|---------------------|
| ĪNT0 | External Interrupt 0          | 03h    | 1                   |
| TF0  | Timer 0                       | 0Bh    | 2                   |
| INT1 | External Interrupt 1          | 13h    | 3                   |
| TF1  | Timer 1                       | 1Bh    | 4                   |
| SCON | T1 or R1 from the serial port | 23h    | 5                   |
| TF2  | Timer 2                       | 2Bh    | 6                   |
| INT2 | External Interrupt 2          | 43h    | 7                   |
| ĪNT3 | External Interrupt 3          | 4Bh    | 8                   |
| INT4 | External Interrupt 4          | 53h    | 9                   |
| ĪNT5 | External Interrupt 5          | 5Bh    | 10                  |

## **ABSOLUTE MAXIMUM RATINGS\***

Voltage on Any Pin Relative to Ground
Operating Temperature
O°C to 70°C
Storage Temperature
-55°C to +125°C
Soldering Temperature
260°C for 10 seconds

\* This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operation sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods of time may affect reliability.

## DC ELECTRICAL CHARACTERISTICS

| PARAMETER                                                          | SYMBOL              | MIN  | TYP  | MAX                  | UNITS | NOTES |
|--------------------------------------------------------------------|---------------------|------|------|----------------------|-------|-------|
| Supply Voltage                                                     | V <sub>CC</sub>     | 4.0  | 5.0  | 5.5                  | V     | 1     |
| Supply Current Active Mode @ 33 MHz                                | $I_{CC}$            |      | 30   |                      | mA    | 2     |
| Supply Current Idle Mode @ 33 MHz                                  | $I_{\mathrm{IDLE}}$ |      | 15   |                      | mA    | 3     |
| Supply Current Stop Mode                                           | $I_{STOP}$          |      | 1    |                      | μΑ    | 4     |
| Input Low Level                                                    | $V_{\rm IL}$        | -0.3 |      | +0.8                 | V     | 1     |
| Input High Level (Except XTAL1 and RST)                            | $V_{\mathrm{IH}}$   | 2.0  |      | V <sub>CC</sub> +0.3 | V     | 1     |
| Input High Level XTAL1 and RST                                     | $V_{IH2}$           | 3.5  |      | V <sub>CC</sub> +0.3 | V     | 1     |
| Output Low Voltage Ports 1,3<br>@ I <sub>OL</sub> = 1.6 mA         | $V_{OL1}$           |      | 0.15 | 0.45                 | V     | 1     |
| Output Low Voltage Port 0,2, ALE, PSEN @ I <sub>OL</sub> =3.2 mA   | $V_{\rm OL2}$       |      | 0.15 | 0.45                 | V     | 1, 5  |
| Output High Voltage Port 1, 3, ALE, PSEN @ I <sub>OH</sub> =-50 µA | V <sub>OH1</sub>    | 2.4  |      |                      | V     | 1, 6  |
| Output High Voltage @ I <sub>OH</sub> =-1.5mA Ports 1,3            | $V_{\mathrm{OH2}}$  | 2.4  |      |                      | V     | 1, 7  |
| Output High Voltage Port 0, 2, ALE, PSEN @ I <sub>OH</sub> =-8 mA  | $V_{OH3}$           | 2.4  |      |                      | V     | 1,5   |
| Input Low Current Ports 1, 3<br>@ 0.45V                            | $I_{IL}$            |      |      | -55                  | μΑ    | 10    |
| Transition Current from 1 to 0<br>Ports 1,3 @ 2V                   | $I_{TL}$            |      |      | -650                 | μΑ    | 8     |
| Input Leakage Port 0, Bus Mode                                     | $I_{\rm L}$         | -300 |      | 300                  | μΑ    | 9     |
| RST Pulldown Resistance                                            | R <sub>RST</sub>    | 50   |      | 170                  | ΚΩ    |       |

## NOTES FOR DC ELECTRICAL CHARACTERISTICS:

All parameters apply to both commercial and industrial temperature operation unless otherwise noted.

- 1. All voltages are referenced to ground.
- 2. Active current is measured with a 33 MHz clock source driving XTAL1, V<sub>CC</sub> =RST=5.5V, all other pins disconnected.

- 3. Idle mode current is measured with a 33 MHz clock source driving XTAL1, V<sub>CC</sub> =5.5V, RST at ground, all other pins disconnected.
- 4. Stop mode current measured with XTAL1 and RST grounded,  $V_{\rm CC}$  =5.5V, all other pins disconnected.
- 5. When addressing external memory.
- 6. RST=V<sub>CC</sub>. This condition mimics operation of pins in I/O mode.
- 7. During a 0 to 1 transition, a one-shot drives the ports hard for two clock cycles. This measurement reflects port in transition mode.
- 8. Ports 1 and 3 source transition current when being pulled down externally. It reaches its maximum at approximately 2V.
- 9. 0.45<V<sub>IN</sub> <V<sub>CC</sub>. Not a high-impedance input. This port is a weak address holding latch because Port 0 is dedicated as an address bus on the DS80C310. Peak current occurs near the input transition point of the latch, approximately 2V.
- 10. Current required from external circuit to hold a logic low level on an I/O pin while the corresponding port latch bit is set to 1. This is only the current required to hold the low level; transitions from 1 to 0 on an I/O pin will also have to overcome the transition current.

# TYPICAL Icc VERSUS FREQUENCY Figure 2



# **AC ELECTRICAL CHARACTERISTICS**

|                                    |                     | <b>25</b> I | MHz | VARIABI                 | LE CLOCK                 |       |
|------------------------------------|---------------------|-------------|-----|-------------------------|--------------------------|-------|
| PARAMETER                          | SYMBOL              | MIN         | MAX | MIN                     | MAX                      | NOTES |
| Oscillator Freq. (Ext. Osc.)       | 1/+                 | 0           | 33  | 0                       | 33                       | MHz   |
| (Ext. Crystal)                     | 1/t <sub>CLCL</sub> | 1           | 33  | 1                       | 33                       | WIIIZ |
| ALe Pulse Width                    | $t_{ m LHLL}$       | 40          |     | 1.5t <sub>CLCL</sub> -5 |                          | ns    |
| Port 0 Address Valid to ALE Low    | $t_{ m AVLL}$       | 10          |     | $0.5t_{\text{CLCL}}$ -5 |                          | ns    |
| Address Hold after ALE Low         | $t_{\rm LLAX1}$     | 10          |     | $0.5t_{CLCL}$ -5        |                          | ns    |
| ALE Low to Valid Instruction In    | $t_{ m LLIV}$       |             | 56  |                         | $2.5t_{\text{CLCL}}$ -20 | ns    |
| ALE Low to PSEN Low                | $t_{LLPL}$          | 10          |     | $0.5t_{\text{CLCL}}$ -5 |                          | ns    |
| PSEN Pulse Width                   | $t_{PLPH}$          | 55          |     | 2t <sub>CLCL</sub> -5   |                          | ns    |
| PSEN Low to Valid Instr. In        | $t_{\rm PLIV}$      |             | 41  |                         | $2t_{CLCL}$ -20          | ns    |
| Input Instruction Hold after PSEN  | $t_{\mathrm{PXIX}}$ | 0           |     | 0                       |                          | ns    |
| Input Instruction Float after PSEN | $t_{\mathrm{PXIZ}}$ |             | 26  |                         | t <sub>CLCL</sub> -5     | ns    |
| Port 0 Address to Valid Instr. In  | $t_{ m AVIV}$       |             | 71  |                         | $3t_{CLCL}$ -20          | ns    |
| Port 2 Address to Valid Instr. In  | t <sub>AVIV2</sub>  |             | 81  |                         | $3.5t_{\text{CLCL}}$ -25 | ns    |
| PSEN Low to Address Float          | $t_{PLAZ}$          |             | 0   |                         | 0                        | ns    |

# NOTES FOR AC ELECTRICAL CHARACTERISTICS

All parameters apply to both commercial and industrial temperature range operation unless otherwise noted. All signals characterized with load capacitance of 80 pF except Port 0, ALE,  $\overline{\text{PSEN}}$ , and WR with 100 pF. Interfacing to memory devices with float times (turn off times) over 25 ns may cause contention. This will not damage the parts, but will cause an increase in operating current. Specifications assume a 50% duty cycle for the oscillator. Port 2 and ALE timing will change in relation to duty cycle variation.

# **MOVX CHARACTERISTICS**

|                                                          |                     | VARIA                    | BLE CLOCK                              |       |                     |
|----------------------------------------------------------|---------------------|--------------------------|----------------------------------------|-------|---------------------|
| PARAMETER                                                | SYMBOL              | MIN                      | MAX                                    | UNITS | STRETCH             |
| Data Access ALE Pulse Width                              | t                   | 1.5t <sub>CLCL</sub> -5  |                                        | ne    | $t_{MCS}=0$         |
|                                                          | $t_{LHLL2}$         | $2t_{CLCL}$ -5           |                                        | ns    | $t_{MCS} > 0$       |
| Address Hold after ALE Low for                           | t                   | $0.5t_{CLCL}$ -5         |                                        | ns    | $t_{MCS}=0$         |
| MOVX Write                                               | $t_{\rm LLAX2}$     | t <sub>CLCL</sub> -5     |                                        | 118   | $t_{MCS} > 0$       |
| RD Pulse Width                                           | $t_{RLRH}$          | $2t_{CLCL}$ -5           |                                        | ns    | $t_{MCS}=0$         |
|                                                          | чккн                | t <sub>MCS</sub> -10     |                                        | 113   | $t_{MCS} > 0$       |
| WR Pulse Width                                           | $t_{\rm WLWH}$      | $2t_{CLCL}$ -5           |                                        | ns    | $t_{MCS}=0$         |
|                                                          | WLWH                | t <sub>MCS</sub> -10     |                                        | 113   | t <sub>MCS</sub> >0 |
| RD Low to Valid Data In                                  | $t_{RLDV}$          |                          | $2t_{CLCL}$ -20                        | ns    | $t_{MCS}=0$         |
|                                                          | 4KLD V              |                          | $t_{MCS}$ -20                          | 113   | $t_{MCS} > 0$       |
| Data Hold after Read                                     | $t_{RHDX}$          | 0                        |                                        | ns    |                     |
| Data Float after Read                                    | $t_{RHDZ}$          |                          | $t_{CLCL}$ -5                          | ns    | $t_{MCS}=0$         |
|                                                          | KIIDZ               |                          | $2t_{CLCL}$ -5                         | 110   | $t_{MCS} > 0$       |
| ALE Low to Valid Data In                                 | $t_{ m LLDV}$       |                          | $2.5t_{CLCL}$ -20                      | ns    | $t_{MCS}=0$         |
|                                                          | *LLD v              |                          | $t_{CLCL} + t_{MCS} - 40$              | 113   | $t_{MCS} > 0$       |
| Port 0 Address to Valid Data In                          |                     |                          | $3t_{CLCL}$ -20                        |       | $t_{MCS}=0$         |
|                                                          | $t_{AVDV1}$         |                          | $1.5t_{\text{CLCL+}}t_{\text{MCS}}$ -  | ns    | $t_{MCS} > 0$       |
|                                                          |                     |                          | 20                                     |       |                     |
| Port 2 Address to Valid Data In                          | $t_{AVDV2}$         |                          | 3.5t <sub>CLCL</sub> -20               | ns    | $t_{MCS}=0$         |
|                                                          | TIVDVE              |                          | $2t_{\text{CLCL+}} t_{\text{MCS-}} 20$ |       | $t_{MCS}>0$         |
| ALE Low to RD or WR Low                                  | $t_{ m LLWL}$       | 0.5t <sub>CLCL</sub> -5  | $0.5t_{CLCL}+5$                        | ns    | $t_{MCS}=0$         |
|                                                          |                     | t <sub>CLCL</sub> -5     | t <sub>CLCL</sub> +5                   |       | $t_{MCS}>0$         |
| Port 0 Address to RD or WR Low                           | $t_{AVWL1}$         | t <sub>CLCL</sub> -5     |                                        | ns    | $t_{\text{MCS}}=0$  |
|                                                          | 717 WEI             | 2t <sub>CLCL</sub> -5    |                                        |       | t <sub>MCS</sub> >0 |
| Port 2 Address to $\overline{RD}$ or $\overline{WR}$ Low | $t_{ m AVWL2}$      | 1.5t <sub>CLCL</sub> -10 |                                        | ns    | $t_{MCS}=0$         |
|                                                          |                     | $2.5t_{\text{CLCL}}$ -10 |                                        |       | $t_{MCS} > 0$       |
| Data Valid to WR Transition                              | $t_{QVWX}$          | -5                       |                                        | ns    |                     |
| Data Hold after Write                                    | $t_{ m WHQX}$       | t <sub>CLCL</sub> -5     |                                        | ns    | $t_{MCS}=0$         |
|                                                          | чинца               | 2t <sub>CLCL</sub> -5    |                                        | 11.5  | $t_{MCS} > 0$       |
| RD Low to Address Float                                  | $t_{RLAZ}$          |                          | -0.5t <sub>CLCL</sub> -5               | ns    |                     |
| RD or WR High to ALE High                                | $t_{\mathrm{WHLH}}$ | 0                        | 10                                     | ns    | $t_{MCS}=0$         |
|                                                          | чипьп               | t <sub>CLCL</sub> -5     | $t_{CLCL}+5$                           | 110   | $t_{MCS} > 0$       |

**NOTE:**  $t_{MCS}$  is a time period related to the Stretch memory cycle selection. The following table shows the value of  $t_{MCS}$  for each Stretch selection.

| M2 | M1 | M0 | MOVX CYCLES                | t <sub>MCS</sub>     |
|----|----|----|----------------------------|----------------------|
| 0  | 0  | 0  | 2 machine cycles           | 0                    |
| 0  | 0  | 1  | 3 machine cycles (default) | 4 t <sub>CLCL</sub>  |
| 0  | 1  | 0  | 4 machine cycles           | 8 t <sub>CLCL</sub>  |
| 0  | 1  | 1  | 5 machine cycles           | 12 t <sub>CLCL</sub> |
| 1  | 0  | 0  | 6 machine cycles           | 16 t <sub>CLCL</sub> |
| 1  | 0  | 1  | 7 machine cycles           | 20 t <sub>CLCL</sub> |
| 1  | 1  | 0  | 8 machine cycles           | 24 t <sub>CLCL</sub> |
| 1  | 1  | 1  | 9 machine cycles           | 28 t <sub>CLCL</sub> |

# **EXTERNAL CLOCK CHARACTERISTICS**

| PARAMETER       | SYMBOL            | MIN | TYP | MAX | UNITS | NOTES |
|-----------------|-------------------|-----|-----|-----|-------|-------|
| Clock High Time | t <sub>CHCX</sub> | 10  |     |     | ns    |       |
| Clock Low Time  | t <sub>CLCX</sub> | 10  |     |     | ns    |       |
| Clock Rise Time | t <sub>CLCL</sub> |     |     | 5   | ns    |       |
| Clock Fall Time | t <sub>CHCL</sub> |     |     | 5   | ns    |       |

# **SERIAL PORT MODE 0 TIMING CHARACTERISTICS**

| PARAMETER                    | SYMBOL        | MIN | TYP                 | MAX | UNITS | NOTES |
|------------------------------|---------------|-----|---------------------|-----|-------|-------|
| Serial Port Clock Cycle Time |               |     | 12t <sub>CLCL</sub> |     | ns    |       |
| SM2=0, 12 clocks per cycle   | $t_{ m XLXL}$ |     | $4t_{CLCL}$         |     | ns    |       |
| SM2=1, 4 clocks per cycle    |               |     |                     |     | 115   |       |
| Output Data Setup to Clock   |               |     | 10t <sub>CLCL</sub> |     |       |       |
| Rising                       | torny         |     | 3t <sub>CLCL</sub>  |     | ns    |       |
| SM2=0, 12 clocks per cycle   | $t_{ m QVXH}$ |     | SICLCL              |     | ns    |       |
| SM2=1, 4 clocks per cycle    |               |     |                     |     |       |       |
| Output Data Hold from        |               |     |                     |     |       |       |
| Clock Rising                 | tyryoy        |     | $2t_{CLCL}$         |     | ns    |       |
| SM2=0, 12 clocks per cycle   | $t_{XHQX}$    |     | $t_{CLCL}$          |     | ns    |       |
| SM2=1, 4 clocks per cycle    |               |     |                     |     |       |       |
| Input Data Hold after Clock  |               |     |                     |     |       |       |
| Rising                       | t             |     | $t_{CLCL}$          |     | ns    |       |
| SM2=0, 12 clocks per cycle   | $t_{ m XHDX}$ |     | $t_{CLCL}$          |     | ns    |       |
| SM2=1, 4 clocks per cycle    |               |     |                     |     |       |       |
| Clock Rising Edge to Input   |               |     | 11t <sub>CLCL</sub> |     |       |       |
| Data Valid                   | tyryny        |     |                     |     | ns    |       |
| SM2=0, 12 clocks per cycle   | $t_{ m XHDV}$ |     | $3t_{CLCL}$         |     | ns    |       |
| SM2=1, 4 clocks per cycle    |               |     |                     |     |       |       |

## **EXPLANATION OF AC SYMBOLS**

In an effort to remain compatible with the original 8051 family, this device specifies the same parameters as such devices, using the same symbols. For completeness, the following is an explanation of the symbols.

- t Time
- A Address
- C Clock
- D Input data
- H Logic level high
- L Logic level low
- I Instruction
- P PSEN
- Q Output data
- R  $\overline{RD}$  signal
- V Valid
- W WR signal
- X No longer a valid logic level
- Z Tristate

# **EXTERNAL PROGRAM MEMORY READ CYCLE**



# **EXTERNAL DATA MEMORY READ CYCLE**



# **DATA MEMORY WRITE CYCLE**



# DATA MEMORY WRITE WITH STRETCH=1



# **DATA MEMORY WRITE WITH STRETCH=2**



FOUR CYCLE DATA MEMORY WRITE STRETCH VALUE=2

# **EXTERNAL CLOCK DRIVE**



# **SERIAL PORT MODE 0 TIMING**

SERIAL PORT 0 (SYNCHRONOUS MODE) HIGH-SPEED OPERATION SM2=1=>TXD CLOCK=XTAL/4





# 40-PIN PDIP (600-MIL)







ALL DIMENSIONS ARE IN INCHES.

| PKG | 40-PIN |       |  |
|-----|--------|-------|--|
| DIM | MIN    | MAX   |  |
| A   | -      | 0.200 |  |
| A1  | 0.015  | -     |  |
| A2  | 0.140  | 0.160 |  |
| b   | 0.014  | 0.022 |  |
| c   | 0.008  | 0.012 |  |
| D   | 1.980  | 2.085 |  |
| Е   | 0.600  | 0.625 |  |
| E1  | 0.530  | 0.555 |  |
| e   | 0.090  | 0.110 |  |
| L   | 0.115  | 0.145 |  |
| eB  | 0.600  | 0.700 |  |

# **44-PIN PLCC**

#### NOTE:

♠ PIN-1 IDENTIFIER TO BE LOCATED IN ZONE INDICATED.
2. CONTROLLING DIMENSIONS ARE IN INCHS.







| PKG | 44-PIN    |       |  |
|-----|-----------|-------|--|
| DIM | MIN       | MAX   |  |
| A   | 0.165     | 0.180 |  |
| A1  | 0.090     | 0.120 |  |
| A2  | 0.020     | -     |  |
| В   | 0.026     | 0.033 |  |
| B1  | 0.013     | 0.021 |  |
| С   | 0.009     | 0.012 |  |
| CH1 | 0.042     | 0.048 |  |
| D   | 0.685     | 0.695 |  |
| D1  | 0.650     | 0.656 |  |
| D2  | 0.590     | 0.630 |  |
| Е   | 0.685     | 0.695 |  |
| E1  | 0.650     | 0.656 |  |
| E2  | 0.590     | 0.630 |  |
| e1  | 0.050 BSC |       |  |
| N   | 44        | _     |  |

# **44-PIN TQFP**



## SUGGESTED PAD LAYOUT 44 PIN TQFP, 10\*10\*1.0



| PKG | 44-PIN    |       |  |
|-----|-----------|-------|--|
| DIM | MIN       | MAX   |  |
| A   | -         | 1.20  |  |
| A1  | 0.05      | 0.15  |  |
| A2  | 0.95      | 1.05  |  |
| D   | 11.80     | 12.20 |  |
| D1  | 10.00 BSC |       |  |
| Е   | 11.80     | 12.20 |  |
| E1  | 10.00 BSC |       |  |
| L   | 0.45      | 0.75  |  |
| e   | 0.80 BSC  |       |  |
| В   | 0.30      | 0.45  |  |
| C   | 0.09      | 0.20  |  |

56-G4012-001

## **DATA SHEET REVISION SUMMARY**

The following represent the key differences between 02/19/98 and 09/01/98 version of the DS80C310 data sheet. Please review this summary carefully.

- 1. Add note to clarify  $I_{IL}$  specification.
- 2. Change serial port mode 0 timing diagram label from t<sub>QVXL</sub> to t<sub>QVXH</sub>.
- 3. Changed minimum oscillator frequency to 1 MHz when using external crystal.
- 4. Corrected "Data memory write with stretch" diagrams to show falling edge of ALE coincident with rising edge of C3 clock.