INTRODUCTION

The '51 family is arguably the most popular 8-bit embedded controller lineup thanks to efficient yet powerful architecture, multi-sourcing by the world's top semiconductor companies and unprecedented third-party tool support. A byproduct of the chip's popularity is a lot of technical know-how embodied in legions of experienced system designers and software programmers.

However, since the chips continue to attract new applications and customers, it shouldn't be taken for granted that 'everyone' already knows how to design it in. Evidence to the contrary is the fact that many of the FAQs (Frequently Asked Questions) continue to be frequently asked.

This application note is written to assist those designers new to the '51 family who typically fit into one or more of the following categories:

– Designers of extremely cost conscious systems that could previously only afford discrete logic or 4-bit solutions now upgrading their designs with superior price/performance and easier to program 8-bit microprocessors.

– Designers that previously used different micros and are now switching to the '51 family.

– New designers, most of whom were quite young at the time of the '51 introduction when design techniques were actively disseminated.

In addition, even experienced designers might find it useful to review this application note, since many of the traditional design techniques and 'conventional wisdom' have been superseded by faster CPUs and memories, changing timing specifications and more sophisticated application requirements. Indeed, those who have simply done it the way somebody else did it before are advised to confirm the validity of their design assumptions.

The application note starts with a basic description of the '51 family memory organization and expansion bus characteristics. Since all the technical details are completely documented in the data sheet and other application notes (see the references section at the end), this section simply highlights the basic operation and timing considerations.

Next, the operation and characteristics of the most often used memories – specifically JEDEC standard byte-wide EPROMs and SRAMs – are described. Specifications are presented for a variety of actual memories.

Having described the CPU and memories, timing analysis is performed for a typical system configuration. The goal of this section is to illustrate how to answer one of the most frequently asked FAQs – “What speed memory should I use with my xxMHz CPU?”.

'51 FAMILY MEMORY ORGANIZATION

Though dozens of derivatives, are offered, all '51 family members share a common memory architecture and similar expansion bus. For this application note, the 80C31/8XC51 (Figure 1) will be used. The only difference between these two devices is that the 80C31 has no on-chip instruction memory while the 8XC51 has 4KB of ROM (80C51) or EPROM (87C51) instruction memory on-chip. The entire range of '51 family derivatives encompasses devices with 0KB (80C31) to 64KB (8XCE560) of on-chip instruction memory of various types including ROM, EPROM (window package), OTP (One Time Programmable), and even EEPROM.

A primary characteristic is that the '51 is logically a ‘Harvard’ machine referring to an organization consisting of separate instruction and data buses. One key byproduct is that the '51 family offers twice the memory expandability (64KB each of code and data) compared to most other 8-bit micros (typically 64KB total).

Figure 1. 80C31/8XC51 Pinout
As shown in Figure 2, the CPU operates in one of two modes determined at reset (RST pin) by the state of the EA (External Access) pin. If EA is asserted, on-chip instruction (but not data) memory is disabled and the entire 64KB of instruction space is accessed externally (this is the only option for the 80C31). Otherwise (EA deasserted), on-chip instruction memory is enabled and only addresses beyond the end of on-chip instruction memory (i.e., ≥ 1000H for the 8XC51) are accessible externally.

The situation for on-chip data memory (i.e., RAM) is somewhat different. First, all '51 family devices include a basic complement of on-chip RAM comprised of CPU register banks, SFRs (Special Function Registers, i.e., built-in I/O functions such as UART, timer, etc.) and general purpose RAM. The on-chip data memory for the 80C31/8XC51 is shown in Figures 3 and 4. By convention, which is used in this application note, a CPU said to have ‘xx’ bytes of RAM (which varies from 64 bytes to 1.5 KB across the '51 family) actually contains ‘xx’ bytes of ‘general purpose RAM’ in addition to the space (128 bytes) allocated to SFRs.

Unlike instruction memory, the state of the EA pin at reset doesn’t affect on-chip data RAM which is always enabled and accessible. Another difference is related to the way the presence of on-chip RAM affects the external data memory space. For CPUs with up to 256 bytes of on-chip RAM, the full 64KB external data space is available. Devices with more than 256 bytes of RAM map the excess portion (i.e., 768 bytes for a CPU with 1K bytes of RAM) to the bottom of the external address space (Figure 5). In this case, an SFR bit (ARD – Auxiliary RAM Disable) determines whether the accesses to the lower space are on- or off-chip.
**80C31/8XC51 Expansion Bus Interface**

'S1 family devices with 40 or more pins generally feature four I/O ports (P0–P3). P0, P2 and a portion of P3 (two pins, RD and WR), along with dedicated ALE (Address Latch Enable) and PSEN (Program Store Enable) pins, comprise the expansion bus interface.

**P0.0–P0.7**

For both program and data access, P0 is used as a multiplexed address/data bus (AD0–7) that outputs the low order address bits (A0–A7) and inputs/outputs the 8-bit data (D0–D7). Note that P0 is open collector, so pull-up resistors are typically required when interfacing to external memory or I/O chips.

**P2.0–P2.7**

For all external program accesses, P2 outputs the high order address bits (A8–A15). The same is true for external data accesses with 16-bit addresses (MOVX A,@DPTR and MOVX @DPTR,A).

**ALE (Address Latch Enable)**

ALE is used to demultiplex the AD0–7 bus. At the beginning of the external cycle ALE is high and the CPU emits A0–A7 which should be externally latched when ALE goes low. Note that ALE is always active, even during internal program and data accesses.

**PSEN (Program Store Enable)**

PSEN is the read strobe for external instruction access. Unlike ALE, PSEN is not asserted during internal accesses.

**RD (Data Read)**

RD is the read strobe for external data access and (like PSEN) is not asserted during internal accesses.

**WR (Data Write)**

WR is the write strobe for external data access and (like PSEN and RD) is not asserted during internal accesses.

Thus, there are three types of external access – instruction read (PSEN), data read (RD) and data write (WR) as shown in Figures 6, 7, and 8.

From this brief description, a number of system design implications can be drawn.

ALE is essentially a continuous clock that runs at 1/6 the oscillator frequency regardless of the mix of internal and external accesses. However, note that one ALE cycle is skipped during external data access.

The skipping of the ALE cycle and assertion of RD or WR only occur during external data access. The MOVX instruction, and only the MOVX instruction, performs external data access. Thus, if the program contains no MOVX instructions, ALE can be used as a timebase (i.e., no skipping) and RD and WR as general purpose outputs.

External program reads (PSEN), whatever the address or cause (i.e., fetch beyond the end of internal instruction memory or EA pin asserted at reset) always use 16-bit addresses and thus require all pins of P0 and P2. [P0 & P2 can be used for general purpose I/O during non-PSEN times? P0 SFR is overwritten by PSEN but what about P2?]

External data accesses affect on P0 and P2 is a little more complicated. 16-bit address accesses (MOVX using DPTR) always drive P0 and P2 with A0–A15. However, 8-bit address accesses (MOVX using Ri) instead drive P2 with the value programmed into the P2 SFR, i.e., P2 is essentially general purpose I/O during an 8-bit address external data access.

However, while the P0 SFR is overwritten by any external data access, the P2 SFR is only modified temporarily for the duration of a 16-bit address (DPTR) access. Subsequently, the P2 SFR is restored to whatever value it contained prior to the external data access.
**Figure 6. External Program Memory Fetches**

**Figure 7. External Data Memory Read Cycle**
Table 1 summarizes the usage and modification of the P0 and P2 SFRs depending on the cycle type. Exploiting this information, system designers can make optimal use of all pins depending on the system configuration. For instance, systems that make no external program accesses and only 8-bit address external data accesses are free to use P2 for general purpose I/O. Just remember that CPUs with more than 256 bytes of on-chip RAM must use 16-bit addresses (DPTR) to perform external data access.

### Table 1. P0 and P2 SFR Usage During External Memory Access

<table>
<thead>
<tr>
<th>EXTERNAL ACCESS TYPE</th>
<th>DURING ACCESS</th>
<th>AFTER ACCESS</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>P0 SFR</td>
<td>P2 SFR</td>
</tr>
<tr>
<td>Instruction Access</td>
<td>0FFH</td>
<td>0FFH</td>
</tr>
<tr>
<td>Data Access – 8-bit Address (MOVX using Ri)</td>
<td>0FFH</td>
<td>Prev. Value</td>
</tr>
<tr>
<td>Data Access – 16-bit Address (MOVX using DPTR)</td>
<td>0FFH</td>
<td>0FFH</td>
</tr>
</tbody>
</table>
EPROMs

Before continuing, it should be pointed out that the original reason for the '51 supported external code – limited ROM-only on-chip space – is hardly applicable today. Windowed EPROM-based CPUs appeared long ago and recently low-cost no-window OTP EPROM devices have become quite popular. Now, even EEPROM-based devices are starting to appear. As for capacity, Philips currently offers derivatives with up to 64KB of on-chip memory including EPROM (windowed and OTP) and ROM. That being said, there are still situations calling for external code memory. Systems requiring relatively high capacity, say 32KB–64KB and beyond, may still be best served by external EPROM, though the advantage will continue to wane. Conversely, due to the dynamics of the memory market in which ‘old’ devices quickly become non-price competitive, low-capacity applications (say 1KB–16KB) are, even without considering the intrinsic advantages of single-chip form factor, arguably best served with on-chip memory.

Using external EPROM can be appropriate when an existing design is simply being upgraded to higher speed without PCB change. Also, certain products such as ‘general-purpose’ single-board computers need external memory since different code will be programmed by each customer. Along the same lines, ‘Rev.0’ products may use external EPROM until the code stabilizes, after which the design can migrate to a single-chip. Finally, some applications, such as handheld translators or dictionaries, call for large capacity (EPROM) ROMs.

The JEDEC (Joint Electron Devices Engineering Council – an international standards body) standard defines the pinout applied to a number of memory technologies including ROM, EPROM, bulk- and byte-erasable EEPROM, etc. However, though the general function is well-defined, detailed timing specifications are left to each manufacturer and may differ slightly. Figure 9 shows the pinout, Figure 10 shows the block diagram, and Table 2 shows the truth table of a 512kbit (64KB) EPROM organized as 64Kx8.

The bulk of the functionality is defined by the sixteen address lines A0–A15 that select a byte for output on the eight data lines O0–O7. Only two control lines are necessary – Chip Enable (CE) and Output Enable (OE). Notice that deasserting CE places the EPROM in ‘standby’ mode, consuming typically 1/2 to 1/3 the active (CE asserted) power. Also, observe that both CE and OE must be asserted to enable the data output drivers.

Referring to the timing diagram (Figure 11) shows that operation of the EPROM is quite simple, typically characterized by only a few specifications. The first, tAA, defines the maximum time after the address stabilizes that the EPROM will return valid data. This parameter is commonly referred to as the ‘access time’ of the device.

Similarly, tCE defines the maximum time after the CE input is asserted that the EPROM will return data. This spec is typically, though not always, the same as tAA.

tOE defines the maximum time from OE assertion to valid data output much like tCE. However, because OE only enables the output drivers as opposed to powering up the device, tOE is typically much less than tCE.

Having delivered the data, the remaining two specs deal with what happens at the end of the cycle, i.e., following the deassertion of either CE or OE (remember, both are required to enable the output). tOH indicates the minimum time the data is guaranteed to remain valid after CE/OE deassertion. The other side of the coin, tOF, defines the maximum time after which the output is guaranteed to completely float.

Table 3 shows the specifications for 70ns EPROMs from two different suppliers. Comparing the difference in specs highlights the point that not all ‘xx’ nanosecond EPROMs are created equal. Notice the significant difference in output enable (tOE) and float (tOF) times as well as tCE/tOE ratios.

Further, notable differences can be observed even within a single suppliers product line. Table 4 shows a spectrum of EPROMs comprised of high-speed selections from one supplier and low-speed selections from another.

For the high-speed supplier, notice how tAA and tCE are equal (as expected) down to 35ns but then start to diverge. This points out the need for careful spec review since many designers might presume a tCE of 35ns implies a 35ns, not 30ns, ‘access time’. Also, except for tAA itself, none of the timings change in a ‘linear’ way across speed ranges. For instance tCE gets ‘stuck’ at 35ns for both the –35 and –30 parts while both tCE and tOF plateau at 18ns for the –45, –35 and –30 selections. A byproduct is that key ratios (ex: tAA/tCE, tAA/tOE, tCE/tOE, etc.) vary for practically every part. For example, the tAA/tOE ratio for the –70 part is almost 3:1 (70ns/25ns) while it’s less than 2:1 (30ns/18ns) for the –30.

On the other hand, the low-speed supplier specs extrapolate from speed-grade to speed-grade in a more consistent and intuitive way. For instance tAA always equals tCE and the variance of timing ratios between speed-grades is reduced.

Table 2. 512KB EPROM Truth Table

<table>
<thead>
<tr>
<th>MODE</th>
<th>CE</th>
<th>OE/VPP</th>
<th>A0</th>
<th>A9</th>
<th>DATA</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>VIL</td>
<td>VIL</td>
<td>A0</td>
<td>A9</td>
<td>O7–O0</td>
</tr>
<tr>
<td>Output Disable</td>
<td>X</td>
<td>VIH</td>
<td>A0</td>
<td>A9</td>
<td>Hi-Z</td>
</tr>
<tr>
<td>Stand-by</td>
<td>VIH</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>Hi-Z</td>
</tr>
</tbody>
</table>

Figure 9. 512KB EPROM Pinout
**80C51 External Memory Interfacing**

- **Figure 10. 512KB EPROM Block Diagram**
  - Address Decoder
  - Programmable Array
  - Multiplexer
  - Power Down
  - Output Enable Decoder

- **Figure 11. 512KB EPROM Timing Diagram**
  - Address
  - CE
  - OE
  - Data Out
  - Valid

**Table 3. Comparing Two ‘70ns’ 27512 EPROMs**

<table>
<thead>
<tr>
<th>PARAMETER</th>
<th>SUPPLIER A</th>
<th>SUPPLIER B</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{AA}$ (max)</td>
<td>70</td>
<td>70</td>
</tr>
<tr>
<td>$t_{CE}$ (max)</td>
<td>70</td>
<td>70</td>
</tr>
<tr>
<td>$t_{OE}$ (max)</td>
<td>25</td>
<td>40</td>
</tr>
<tr>
<td>$t_{DF}$ (max)</td>
<td>25</td>
<td>30</td>
</tr>
<tr>
<td>$t_{OH}$ (min)</td>
<td>0</td>
<td>5</td>
</tr>
</tbody>
</table>

**Table 4. Spectrum of 27512 EPROM Specs**

<table>
<thead>
<tr>
<th>PARAMETER</th>
<th>SUPPLIER A</th>
<th>SUPPLIER C</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{AA}$ (max)</td>
<td>25</td>
<td>30</td>
</tr>
<tr>
<td>$t_{CE}$ (max)</td>
<td>30</td>
<td>35</td>
</tr>
<tr>
<td>$t_{OE}$ (max)</td>
<td>12</td>
<td>18</td>
</tr>
<tr>
<td>$t_{DF}$ (max)</td>
<td>12</td>
<td>18</td>
</tr>
<tr>
<td>$t_{OH}$ (min)</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
SRAMs
Compared to EPROMs, SRAMs are less subject to competition from ever higher integrated CPUs. Across the entire Philips ’51 family the largest on-chip RAM offered is 2KB, with the majority of CPUs featuring only 64–512 bytes. Thus an application that requires 2KB–64KB or more of data definitely calls for external SRAM. SRAM is also useful as instruction memory in those applications (such as a PC-plug in) that exploit ‘downloadable’ code to vary their functionality at runtime.

Figure 12 shows the pinout, Figure 13 shows the block diagram, and Table 5 shows the truth table for a 256k bit (32K bytes) SRAM organized as 32Kx8. Reflecting JEDEC standardization, the pinout and functionality is nearly the same as EPROMs, the major difference being addition of a WE (Write Enable) line. Once again, CE is responsible for controlling power consumption and OE simply enables the output reflected in the tCE/tOE differential. For all practical purposes, an SRAM is little distinguishable from an EPROM as far as reads are concerned.

**Table 5. 256KB SRAM Truth Table**

<table>
<thead>
<tr>
<th>CE</th>
<th>OE</th>
<th>WE</th>
<th>MODE</th>
<th>VCC CURRENT</th>
<th>I/O PIN</th>
</tr>
</thead>
<tbody>
<tr>
<td>H</td>
<td>X</td>
<td>X</td>
<td>Not Selected</td>
<td>I SB, I SB1</td>
<td>Hi-Z</td>
</tr>
<tr>
<td>L</td>
<td>L</td>
<td>H</td>
<td>Read</td>
<td>ICC</td>
<td>D OUT</td>
</tr>
<tr>
<td>L</td>
<td>H</td>
<td>L</td>
<td>Write</td>
<td>ICC</td>
<td>D IN</td>
</tr>
<tr>
<td>L</td>
<td>L</td>
<td>L</td>
<td>Write</td>
<td>ICC</td>
<td>D IN</td>
</tr>
</tbody>
</table>
Figure 14 shows the read cycle timing for an 85ns SRAM which is quite similar to that of an EPROM. Depending on the supplier, the naming of certain specs may be slightly different, but for ease of comparison this application note translates to a common nomenclature. This SRAM (as do some EPROMS), defines separate CE and OE data float specs (tCHZ, tOHZ) instead of a single tDF. Since the SRAM (unlike the EPROM) can be written, it also specifies the other side of the data float coin (i.e., enable to output driven) with tCLZ and tOLZ.

Now let’s examine how WE factors into the SRAM operation. When WE is asserted, the SRAMs output buffers are disabled while the input buffers are enabled to receive data.

Figure 15 shows the write cycle timing which is slightly more complicated than reads. Write time (tWP) is defined as the time during which both CE and WE are asserted. Thus, various setup and hold timings that are specified relative to the ‘end’ of the write cycle (such as tDW, tDH, tWR, etc.) should refer to whichever signal (CE or WE) terminates first.

tWC simply defines the write cycle time which, along with tRC, is the same as the ‘access time’, i.e., 85ns. This is in contrast to other types of memory (notably DRAMs) in which the cycle time may be longer than the access time due to ‘precharge’ delay.

tCF and tAW specify the minimum time from valid CE and address inputs to the end of the write cycle (CE or WE high, whichever comes first). They are the write cycle corollary to the read cycles tCE and tAA specs and in this (the usual, but not always as we saw for EPROMs) case are the same. The SRAM also defines an address setup to the beginning of the write cycle (tAS).

Now let’s examine how WE factors into the SRAM operation. When WE is asserted, the SRAMs output buffers are disabled while the input buffers are enabled to receive data.

Figure 15 shows the write cycle timing which is slightly more complicated than reads. Write time (tWP) is defined as the time during which both CE and WE are asserted. Thus, various setup and hold timings that are specified relative to the ‘end’ of the write cycle (such as tDW, tDH, tWR, etc.) should refer to whichever signal (CE or WE) terminates first.

tWC simply defines the write cycle time which, along with tRC, is the same as the ‘access time’, i.e., 85ns. This is in contrast to other types of memory (notably DRAMs) in which the cycle time may be longer than the access time due to ‘precharge’ delay.

tCF and tAW specify the minimum time from valid CE and address inputs to the end of the write cycle (CE or WE high, whichever comes first). They are the write cycle corollary to the read cycles tCE and tAA specs and in this (the usual, but not always as we saw for EPROMs) case are the same. The SRAM also defines an address setup to the beginning of the write cycle (tAS).

Now let’s examine how WE factors into the SRAM operation. When WE is asserted, the SRAMs output buffers are disabled while the input buffers are enabled to receive data.

Figure 15 shows the write cycle timing which is slightly more complicated than reads. Write time (tWP) is defined as the time during which both CE and WE are asserted. Thus, various setup and hold timings that are specified relative to the ‘end’ of the write cycle (such as tDW, tDH, tWR, etc.) should refer to whichever signal (CE or WE) terminates first.

tWC simply defines the write cycle time which, along with tRC, is the same as the ‘access time’, i.e., 85ns. This is in contrast to other types of memory (notably DRAMs) in which the cycle time may be longer than the access time due to ‘precharge’ delay.

tCF and tAW specify the minimum time from valid CE and address inputs to the end of the write cycle (CE or WE high, whichever comes first). They are the write cycle corollary to the read cycles tCE and tAA specs and in this (the usual, but not always as we saw for EPROMs) case are the same. The SRAM also defines an address setup to the beginning of the write cycle (tAS).

Now let’s examine how WE factors into the SRAM operation. When WE is asserted, the SRAMs output buffers are disabled while the input buffers are enabled to receive data.

Figure 15 shows the write cycle timing which is slightly more complicated than reads. Write time (tWP) is defined as the time during which both CE and WE are asserted. Thus, various setup and hold timings that are specified relative to the ‘end’ of the write cycle (such as tDW, tDH, tWR, etc.) should refer to whichever signal (CE or WE) terminates first.

tWC simply defines the write cycle time which, along with tRC, is the same as the ‘access time’, i.e., 85ns. This is in contrast to other types of memory (notably DRAMs) in which the cycle time may be longer than the access time due to ‘precharge’ delay.

tCF and tAW specify the minimum time from valid CE and address inputs to the end of the write cycle (CE or WE high, whichever comes first). They are the write cycle corollary to the read cycles tCE and tAA specs and in this (the usual, but not always as we saw for EPROMs) case are the same. The SRAM also defines an address setup to the beginning of the write cycle (tAS).

Now let’s examine how WE factors into the SRAM operation. When WE is asserted, the SRAMs output buffers are disabled while the input buffers are enabled to receive data.

Figure 15 shows the write cycle timing which is slightly more complicated than reads. Write time (tWP) is defined as the time during which both CE and WE are asserted. Thus, various setup and hold timings that are specified relative to the ‘end’ of the write cycle (such as tDW, tDH, tWR, etc.) should refer to whichever signal (CE or WE) terminates first.

tWC simply defines the write cycle time which, along with tRC, is the same as the ‘access time’, i.e., 85ns. This is in contrast to other types of memory (notably DRAMs) in which the cycle time may be longer than the access time due to ‘precharge’ delay.

tCF and tAW specify the minimum time from valid CE and address inputs to the end of the write cycle (CE or WE high, whichever comes first). They are the write cycle corollary to the read cycles tCE and tAA specs and in this (the usual, but not always as we saw for EPROMs) case are the same. The SRAM also defines an address setup to the beginning of the write cycle (tAS).

Now let’s examine how WE factors into the SRAM operation. When WE is asserted, the SRAMs output buffers are disabled while the input buffers are enabled to receive data.

Figure 15 shows the write cycle timing which is slightly more complicated than reads. Write time (tWP) is defined as the time during which both CE and WE are asserted. Thus, various setup and hold timings that are specified relative to the ‘end’ of the write cycle (such as tDW, tDH, tWR, etc.) should refer to whichever signal (CE or WE) terminates first.

tWC simply defines the write cycle time which, along with tRC, is the same as the ‘access time’, i.e., 85ns. This is in contrast to other types of memory (notably DRAMs) in which the cycle time may be longer than the access time due to ‘precharge’ delay.

tCF and tAW specify the minimum time from valid CE and address inputs to the end of the write cycle (CE or WE high, whichever comes first). They are the write cycle corollary to the read cycles tCE and tAA specs and in this (the usual, but not always as we saw for EPROMs) case are the same. The SRAM also defines an address setup to the beginning of the write cycle (tAS).

Now let’s examine how WE factors into the SRAM operation. When WE is asserted, the SRAMs output buffers are disabled while the input buffers are enabled to receive data.

Figure 15 shows the write cycle timing which is slightly more complicated than reads. Write time (tWP) is defined as the time during which both CE and WE are asserted. Thus, various setup and hold timings that are specified relative to the ‘end’ of the write cycle (such as tDW, tDH, tWR, etc.) should refer to whichever signal (CE or WE) terminates first.

tWC simply defines the write cycle time which, along with tRC, is the same as the ‘access time’, i.e., 85ns. This is in contrast to other types of memory (notably DRAMs) in which the cycle time may be longer than the access time due to ‘precharge’ delay.

tCF and tAW specify the minimum time from valid CE and address inputs to the end of the write cycle (CE or WE high, whichever comes first). They are the write cycle corollary to the read cycles tCE and tAA specs and in this (the usual, but not always as we saw for EPROMs) case are the same. The SRAM also defines an address setup to the beginning of the write cycle (tAS).
80C31/8XC51 – 33MHz INTERFACE EXAMPLE

One major contributor to the longevity of the '51 family is that Philips has continued to upgrade the maximum clock rate. In the case of the 80C31/8XC51, speed selections up to 33MHz are available. Boosting performance to nearly 3 MIPS (≈360ns instruction cycle) offers an easy upgrade path for existing designs as well as enabling new ones.

Of course, higher performance is only possible with faster memories. Fortunately, thanks largely to the ‘need for speed’ on desktop PCs, memory suppliers have responded to the call. Let’s perform a detailed analysis of an example 33MHz design, pointing out the useful tips, and possible traps, along the way. Note that, like memories, individual members of the '51 family may exhibit slightly different specs. However, the principles and techniques explained in this application note are generally applicable for any CPU at any clock rate.

Table 6, reproduced from the data sheet for convenience, details the timing specification for each of the three external bus cycle types – instruction read (PSEN), data read (RD) and data write (WR).

Rather than explain every spec up front, let’s simply propose and evaluate a design to focus on the relevant, and possibly critical, timing parameters.

First of all, since the CPU is available in many speed grades, notice that most specs are stated in terms of $t_{\text{CLCL}}$, i.e., the clock cycle. For a 33MHz part, $t_{\text{CLCL}}$ is 30.3ns. To ease calculations, this can be rounded to 30ns with the caveat final timing should be confirmed, especially if a marginal situation arises. Observing that the maximum $t_{\text{CLCL}}$ multiplication factor shown on the datasheet is 9 ($t_{\text{AVDV}}$), watch out for margins of ≈3ns (i.e., $9 \times 0.3\text{ns} = 2.7\text{ns}$) or less when approximating.
### Table 6. AC Electrical Characteristics for 12–33MHz Philips North America Devices

$T_{amb} = 0^\circ$C to $+70^\circ$C or $-40^\circ$C to $+85^\circ$C, $V_{CC} = 5V$ ±20%, $V_{SS} = 0V$ (80C31/51 $^{1,2,4}$, 12, 16, and 24MHz versions).

$T_{amb} = 0^\circ$C to $+70^\circ$C or $-40^\circ$C to $+85^\circ$C, $V_{CC} = 5V$ ±10%, $V_{SS} = 0V$ (87C51 12, 16 AND 24MHz versions) 80C31/80C51 33MHz version; For 87C51 (33MHz only) $T_{amb} = 0^\circ$C to $+70^\circ$C, $V_{CC} = 5V$ ±5%

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>FIGURE</th>
<th>PARAMETER</th>
<th>VARIABLE CLOCK</th>
<th>MIN</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{CLCL}$</td>
<td>Oscillator frequency: SC80C31/51</td>
<td>Speed Versions</td>
<td>C</td>
<td>3.5</td>
<td>12</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>G</td>
<td>3.5</td>
<td>16</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>P</td>
<td>3.5</td>
<td>24</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Y</td>
<td>3.5</td>
<td>33</td>
<td>MHz</td>
</tr>
<tr>
<td>$t_{LL}$</td>
<td>ALE pulse width</td>
<td>16</td>
<td>2$t_{CLCL}$–40</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{AVLL}$</td>
<td>Address valid to ALE low</td>
<td>16</td>
<td>$t_{CLCL}$–13</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{LLAX}$</td>
<td>Address hold after ALE low</td>
<td>16</td>
<td>$t_{CLCL}$–20</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{LLIV}$</td>
<td>ALE low to valid instruction in</td>
<td>16</td>
<td>4$t_{CLCL}$–65</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{LLPL}$</td>
<td>ALE low to PSEN low</td>
<td>16</td>
<td>$t_{CLCL}$–13</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{PLPH}$</td>
<td>PSEN pulse width</td>
<td>16</td>
<td>3$t_{CLCL}$–20</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{PLUV}$</td>
<td>PSEN low to valid instruction in</td>
<td>16</td>
<td>3$t_{CLCL}$–45</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{PXIX}$</td>
<td>Input instruction hold after PSEN</td>
<td>16</td>
<td>0</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{PXIZ}$</td>
<td>Input instruction float after PSEN</td>
<td>16</td>
<td>$t_{CLCL}$–10</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{AVIV}$</td>
<td>Address to valid instruction in</td>
<td>16</td>
<td>5$t_{CLCL}$–55</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{PLAZ}$</td>
<td>PSEN low to address float</td>
<td>16</td>
<td>10</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Data Memory**

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>FIGURE</th>
<th>PARAMETER</th>
<th>VARIABLE CLOCK</th>
<th>MIN</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{RLFH}$</td>
<td>RD pulse width</td>
<td>17,18</td>
<td>6$t_{CLCL}$–100</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WLWH}$</td>
<td>WR pulse width</td>
<td>17,18</td>
<td>6$t_{CLCL}$–100</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{RLDV}$</td>
<td>RD low to valid data in</td>
<td>17,18</td>
<td>5$t_{CLCL}$–90</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{RRDX}$</td>
<td>Data hold after RD</td>
<td>17,18</td>
<td>0</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{RHDX}$</td>
<td>Data float after RD</td>
<td>17,18</td>
<td>2$t_{CLCL}$–28</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{LLDV}$</td>
<td>ALE low to valid data in</td>
<td>17,18</td>
<td>8$t_{CLCL}$–150</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{AVDV}$</td>
<td>Address to valid data in</td>
<td>17,18</td>
<td>9$t_{CLCL}$–165</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{LLWL}$</td>
<td>ALE low to RD or WR low</td>
<td>17,18</td>
<td>3$t_{CLCL}$–50</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{AVWL}$</td>
<td>Address valid to WR or RD low</td>
<td>17,18</td>
<td>3$t_{CLCL}$+50</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{QVWX}$</td>
<td>Data valid to WR transition</td>
<td>17,18</td>
<td>$t_{CLCL}$–20</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WHQX}$</td>
<td>Data hold after WR</td>
<td>17,18</td>
<td>$t_{CLCL}$–20</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{RLAZ}$</td>
<td>RD low to address float</td>
<td>17,18</td>
<td>0</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WHHL}$</td>
<td>RD or WR high to ALE high</td>
<td>17,18</td>
<td>$t_{CLCL}$–20</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**External Clock**

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>FIGURE</th>
<th>PARAMETER</th>
<th>VARIABLE CLOCK</th>
<th>MIN</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{CHCX}$</td>
<td>High time</td>
<td>19</td>
<td>12</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{CLCX}$</td>
<td>Low time</td>
<td>19</td>
<td>12</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{CLCH}$</td>
<td>Rise time</td>
<td>19</td>
<td>20</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{CHCL}$</td>
<td>Fall time</td>
<td>19</td>
<td>20</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTES:**

1. Parameters are valid over operating temperature range unless otherwise specified.
2. Load capacitance for port 0, ALE, and PSEN = 100pF; load capacitance for all other outputs = 80pF.
3. For all Philips North America speed versions only.
4. Interfacing the 80C31/51 to devices with float times up to 50ns is permitted. This limited bus contention will not cause damage to port 0 drivers.
EXPLANATION OF THE AC SYMBOLS
Each timing symbol has five characters. The first character is always 't' (= time). The other characters, depending on their positions, indicate the name of a signal or the logical status of that signal. The designations are:
A – Address
C – Clock
D – Input data
H – Logic level high
I – Instruction (program memory contents)
L – Logic level low, or ALE
P – PSEN
Q – Output data
R – RD signal
t – Time
V – Valid
W – WR signal
X – No longer a valid logic level
Z – Float

Examples: tAVLL = Time for address valid to ALE low.
          tLLPL= Time for ALE low to PSEN low.

Figure 16. External Program Memory Read Cycle

Figure 17. External Data Memory Read Cycle
Figure 18. External Data Memory Write Cycle

Figure 19. External Clock Drive
EPROM INTERFACE

Let's start with the ‘classic’ circuit shown in Figure 20 that uses a transparent latch to demultiplex the address/data bus AD0–7 (P0). The latch, a ‘573 which combines the function of the well-known ‘373 with an easy to layout ‘broadside’ pinout) shown in Figure 21, is controlled with two pins – E (Enable) and OE (Output Enable). It's called transparent because as soon as E is asserted, the inputs will begin to flow to the outputs and are subsequently latched on the trailing edge of E. This is exactly the behavior called for to demultiplex the CPU AD0–7 bus (P0) with the ALE output from the CPU. Usually, OE is simply connected to ground enabling the output at all times.

Now is a good time to say a few words about ‘glue’ logic like the ‘573. Based on the previous memory spec comparison, it should be no surprise that all glue logic, including latches, buffers, decoders, etc. not to mention PLDs, is not created equal.

For instance, as shown in Table 7, there are a myriad of ‘TTL’ variants – HC, HCT, LS, ALS, AS, FAST, etc. – covering a rather broad (~5:1) range of speed and power. The important point to note is that these absolutely small differences and delays were easier to ignore in yesterday’s slow speed designs, but can become critical as the CPU clock rate increases.

The first step is to confirm the CPU meets the setup and hold times for the chosen latch. Referring back to the CPU timing (Table 6, Figures 16, 17, 18, and 19)...

\[ t_s < t_{AVLL} \] (address valid to ALE low) = \[ t_{CLCL} - 13 = 17\text{ns} \]

\[ t_h < t_{LLAX} \] (address hold after ALE low) = \[ t_{CLCL} - 20 = 10\text{ns} \]

In this case, the choice of TTL technology proves non-critical. For reference, \[ t_s \] & \[ t_h \] cover a spectrum from 15 & 5ns for an HCT ’574 to 3 & 0ns for a FAST ’574.

The next decision is how to connect the EPROM CE and OE control lines. A simple ‘no glue’ solution is to simply ground CE. This has the benefit of eliminating the \[ t_{CE}/t_{OE} \] differential as a component of access time, though at the expense of higher power consumption. With CE grounded, access time depends only on OE which is connected to the CPU PSEN line.

Note that this scheme (grounding CE) limits code expansion to a single EPROM, otherwise decoding is required. However, this is not an unreasonable restriction given the typical code size of ’51 applications relative to the high density of modern EPROMs.

Finally, it is important to remember that applications exploiting the low power modes of the CPU (IDLE and POWERDOWN) must accommodate the behavior of ALE and PSEN. Specifically, during IDLE, ALE and PSEN = 0 and during POWERDOWN, ALE and PSEN = 1. In general, this requires externally gating CE, ALE, OE, etc. Since the optimal solution is very dependent on the particulars of the configuration and application, the issue is not addressed further in this application note.
### Table 7. Spectrum of TTL Performance

$V_{CC} = 5V; \ T_{amb} = 25^\circ C; \ C_L = 15pF$

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Technology</th>
<th>HCMOS</th>
<th>Metal Gate CMOS</th>
<th>Standard TTL</th>
<th>Low-Power Schottky TTL</th>
<th>Schottky TTL</th>
<th>Advanced Low-Power Schottky TTL</th>
<th>Advanced Schottky TTL</th>
<th>Fairchild Advanced Schottky TTL</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Family</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>74HC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4000 CD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>HE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### Power dissipation, typ. (mW)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Technology</th>
<th>$V_{CC} = 5V; \ T_{amb} = 25^\circ C; \ C_L = 15pF$</th>
</tr>
</thead>
<tbody>
<tr>
<td>Gate</td>
<td></td>
<td></td>
</tr>
<tr>
<td>static</td>
<td></td>
<td>0.0000025</td>
</tr>
<tr>
<td>dynamic @100kHz</td>
<td>0.075</td>
<td>0.1</td>
</tr>
<tr>
<td>Counter</td>
<td></td>
<td></td>
</tr>
<tr>
<td>static</td>
<td></td>
<td>0.000005</td>
</tr>
<tr>
<td>dynamic @100kHz</td>
<td>0.125</td>
<td>0.120</td>
</tr>
</tbody>
</table>

#### Propagation delay (ns)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Technology</th>
<th>$V_{CC} = 5V; \ T_{amb} = 25^\circ C; \ C_L = 15pF$</th>
</tr>
</thead>
<tbody>
<tr>
<td>Gate</td>
<td></td>
<td></td>
</tr>
<tr>
<td>typical</td>
<td></td>
<td>8</td>
</tr>
<tr>
<td>maximum</td>
<td></td>
<td>14</td>
</tr>
<tr>
<td>Counter</td>
<td></td>
<td></td>
</tr>
<tr>
<td>typical</td>
<td></td>
<td>45</td>
</tr>
<tr>
<td>minimum</td>
<td></td>
<td>25</td>
</tr>
</tbody>
</table>

#### Delay/power product (pJ)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Technology</th>
<th>$V_{CC} = 5V; \ T_{amb} = 25^\circ C; \ C_L = 15pF$</th>
</tr>
</thead>
<tbody>
<tr>
<td>Gate</td>
<td></td>
<td></td>
</tr>
<tr>
<td>@100kHz</td>
<td></td>
<td>0.52</td>
</tr>
<tr>
<td>Counter</td>
<td></td>
<td></td>
</tr>
<tr>
<td>maximum</td>
<td></td>
<td>1.6</td>
</tr>
</tbody>
</table>

#### Maximum clock frequency (MHz)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Technology</th>
<th>$V_{CC} = 5V; \ T_{amb} = 25^\circ C; \ C_L = 15pF$</th>
</tr>
</thead>
<tbody>
<tr>
<td>D-type flip-flop</td>
<td>typical</td>
<td>55</td>
</tr>
<tr>
<td>minimum</td>
<td></td>
<td>30</td>
</tr>
<tr>
<td>Counter</td>
<td></td>
<td></td>
</tr>
<tr>
<td>typical</td>
<td></td>
<td>45</td>
</tr>
<tr>
<td>minimum</td>
<td></td>
<td>25</td>
</tr>
</tbody>
</table>

#### Output Drive (mA)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Technology</th>
<th>$V_{CC} = 5V; \ T_{amb} = 25^\circ C; \ C_L = 15pF$</th>
</tr>
</thead>
<tbody>
<tr>
<td>standard outputs</td>
<td>4</td>
<td>0.51</td>
</tr>
<tr>
<td>bus outputs</td>
<td>6</td>
<td>1.6</td>
</tr>
</tbody>
</table>

#### Fan-out (LS-loads)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Technology</th>
<th>$V_{CC} = 5V; \ T_{amb} = 25^\circ C; \ C_L = 15pF$</th>
</tr>
</thead>
<tbody>
<tr>
<td>standard outputs</td>
<td>10</td>
<td>1</td>
</tr>
<tr>
<td>bus outputs</td>
<td>15</td>
<td>4</td>
</tr>
</tbody>
</table>

1996 May 15
EPROM TIMING ANALYSIS

With a design established, it is now possible to perform an initial timing evaluation. The procedure is simply to step through each EPROM spec one by one to identify a speed grade that meets all the relevant CPU timing requirements.

Starting with \( t_{AA} \) (EPROM), it is apparent that address access time for the EPROM must be less than the CPU \( t_{AVIV} \) (address to valid instruction in). However, don’t forget that the '573 propagation delay must also be factored in. The conclusion is expressed in the form of an equation as...

\[
t_{AA} \ (\text{EPROM}) < t_{AVIV} \ (\text{CPU}) - t_{PROP} \ (\text{TTL})
\]

\( t_{PROP} \) depending on the choice of TTL technology, varies from approximately 10ns (FAST) to 40ns (HCT). Throughout this application note, \( t_{PROP} \) for the latch is assumed to be 10ns.

Substituting the CPU data sheet value for \( t_{AVIV} \) (5\( t_{CLCL} \)-55) and solving yields a required \( t_{AA} \) of...

\[
t_{AA} < ((5t_{CLCL})-55)-t_{PROP} = ((5\times30)-55)-10 = 85\text{ns}
\]

According to the EPROM spec chart (refer back to Table 4), this calls for a ‘–70’ (70ns) EPROM.

Since \( CE \) is grounded, it meets the \( t_{CE} \) spec of any EPROM and need not be considered in this design.

The only ‘access-time’ related spec remaining to check is \( t_{OE} \). Connected directly to the CPU PSEN with no intervening TTL, the equation is simply...

\[
t_{OE} < t_{PLIV} = 3t_{CLCL}-45 = (3\times30)-45 = 45\text{ns}
\]

...a spec easily met by the –70 EPROM \( t_{OE} \) max. = 25ns).

Able to access the EPROM successfully, all that’s left is to verify the EPROM data hold (\( t_{OH} \)) and float (\( t_{DF} \)) specs.

The EPROM \( t_{OH} \) spec is 0ns (whatever the speed), i.e., the EPROM output is not held after deselection. On the CPU side, since PSEN is controlling the EPROM selection (via \( CE \)), the corresponding spec is \( t_{PXIX} \) (input instruction hold after PSEN) which is also 0ns. This may sound tight but actually isn’t a problem. First, there’s the simple fact that the CPU will ‘see’ PSEN go high before the EPROM by virtue of the package and PCB wiring delays. Second, though it’s convenient for the EPROM manufacturer to spec 0ns, it’s clear that the outputs can’t shut off in zero time.

Finally, \( t_{DF} \) can be checked against the CPU \( t_{PXIZ} \) (input instruction float after PSEN) spec.

\[
t_{DF} < t_{PXIZ} = t_{CLCL}-10 = (30-10) = 20\text{ns}
\]

Oops, unfortunately a ‘–70’ EPROM, with \( t_{DF} \) max. 25ns, can’t meet this spec. This is a bus contention situation in which the next cycle address driven by the CPU will collide with the remnants of the previous cycle EPROM output. Though access time is certainly important, the lesson is that ‘unaccess’ (i.e., float) time can’t be overlooked.

So, what are the options to resolve the problem?

The straightforward solution is to select an EPROM with better \( t_{DF} \) spec by moving to a faster speed grade (for instance, the –55 which cuts \( t_{DF} \) to an acceptable 20ns). Alternatively, another vendor may offer a ‘–70’ with better \( t_{DF} \) spec (note the difference between supplier A & B –90 \( t_{DF} \) spec as an example).

Another option is to insert a buffer or transceiver with a fast shutoff in the datapath as shown in Figure 22. Take care to choose a TTL technology is actually faster. For instance, the output disable time for a FAST 244 is a speedy 6ns, but that for an HCT 244 a leisurely 31ns which doesn’t help at all.

Also, make sure solving the problem at the ‘back-end’ of the cycle doesn’t just push it to the ‘front-end’. Remember that propagation delay through the buffer or transceiver must now be subtracted from available access time (\( t_{AA} \), \( t_{OE} \)). Re-evaluating the access times shows that \( t_{PROP} \) must be less than 15ns, or a faster EPROM has to be selected anyway. For reference, \( t_{PROP} \) for a FAST 244 is only 7ns but an unhelpful 28ns for HCT.

A final, and rather widely used, option is to simply ignore the problem. Referring back to Table 6, note 4 at the bottom of the page points out that the Philips CPU P0 drivers are designed to tolerate contention (i.e., \( t_{DF} \) up to 50ns). Determining whether the memory is similarly robust requires confirmation by the particular EPROM supplier.

---

**Figure 22. CPU + Latch + EPROM + Xcvr Diagram**
80C51 External Memory Interfacing

SRAM INTERFACE

Though other configurations are possible, this example illustrates the most common one in which the SRAM is used for data-only (as opposed to instruction or instruction & data) storage. Should the SRAM be used for instruction storage, the previous CPU instruction access timings used in evaluating the EPROM interface apply.

Instead of grounding the SRAM CE line, since it requires only 15 address lines (i.e., 32Kx8), it is connected to the CPU A15 (P2.7). Thus, the SRAM occupies the lower 32K bytes of the data space, leaving the upper 32KB for I/O expansion. The SRAM CE and WE lines are connected to the CPU RD and WR lines respectively as shown in Figure 23.

This configuration can take advantage of the previously mentioned operating characteristics of P2 (A8–A15), specifically the fact that P2 (and thus A15 which is connected to the SRAM CE line) reverts to prior levels programmed into the SFR when not performing an external data access. By programming P2.7 (A15) to output a 1, the SRAM will be deselected when it is not being accessed, saving power. Further, unlike the EPROM case, no extra control line gating logic is needed to accommodate the CPU low power (IDLE and POWERDOWN) modes.

SRAM Timing Analysis

The process of evaluating the 32Kx8 SRAM interface is similar to that for the EPROM, recognizing that the CPU external data access (RD, WR) timing is different than instruction access (PSEN) and both read and write cycles must be checked.

Starting with the read cycle, tRC is clearly not an issue since the CPU data access bus cycle of 360ns is well beyond the 85ns SRAM spec.

For a data read, the SRAM tAA is compared with the CPU tAVDV (address to valid data in). Once again, as for the EPROM, propagation delay through the address latch is considered (10ns assumed)...

\[ t_{AA} < t_{AVDV} + t_{PROP} = (9 \times 30) - 165 = 95ns \]
...which meets the –85 SRAM tAA spec of 85ns.

Since CE is no longer grounded, it must be evaluated as well. Connected to A15 without intervening TTL, the equation is simply the same as that for tAA without tPROP derating...

\[ t_{CE} < t_{AVDV} = (9 \times 30) - 165 = 105ns \]
...meeting the SRAM tCE spec of 85ns with even more margin.

The SRAM CE is connected to the CPU RD line so tOE is evaluated as...

\[ t_{OE} < t_{RLDV} = (5 \times 30) - 90 = 60ns \]
...meeting the SRAM tOE spec of 45ns.

Unlike the EPROM, the SRAM guarantees some output data hold time (tOH = 5ns min) while the CPU still only requires 0ns (tRHDX).

Though the EPROM had a problem with float time (tDF) note that for data cycles...

\[ t_{DF} < t_{RHDX} = (2 \times 30) - 28 = 32ns \]
...showing that the SRAM tDF spec (30ns), though worse than the EPROM spec (25ns for –70), is actually met. This highlights the more relaxed timing of CPU data access compared to instruction access.

On the other side of the data float equation, is it possible for the SRAM to start to return data before the address has been removed from the CPU AD0–7 bus thus causing bus contention? The SRAM will start to drive the bus within 5ns (tOLZ) of CE assertion.

Fortunately, the CPU tRLAZ spec of 0ns guarantees that the address is off the bus at the time RD (connected to the SRAM OE) is asserted.

This completes the SRAM read cycle evaluation and shows there is plenty of margin due to the relaxed nature of data access timing. Now, let's move on to the write cycle evaluation.

Once again, the SRAM tWC (as was tRC) spec of 85ns is easily met since the CPU data access bus cycle is 360ns (12*30ns).

The SRAM tAW (address valid to end of write) is compared against the sum of the CPU tAVWL (address valid to write low) and tWLWH (write low to write high) specs again considering the latch propagation delay...

\[ t_{AW} < t_{AVWL} + t_{WLWH} - t_{PROP} \]
...or...

\[ t_{AW} < (4 \times 30) + (6 \times 30) - 105 = 115ns \]
...which easily meets the SRAM tAW spec of 75ns.

Meanwhile, the SRAM tAS spec defines the time addresses must be setup prior to the assertion of WE which is connected to the CPU WR line so...

\[ t_{AS} < t_{AVWL} - t_{PROP} = (4 \times 30) - 105 = 35ns \]
...again easily met by the tAS spec of 0ns.

Since the SRAM CE pin is simply connected to the CPU A15 without intervening TTL, calculation of tCW (CE to write end) is the same as for tAW without derating for tPROP...\n
\[ t_{CW} < t_{AVWL} + t_{WLWH} = 125ns \]
...meeting the tCW spec (75ns, same as tAW) with an additional tPROP (10ns) margin.
Remembering that the SRAM write pulse is defined as the overlap of WE and CE, \( t_{WP} \) (write pulse width) is simply defined by \( t_{WLWH} \):

\[
t_{WP} < t_{WLWH} = (6t_{CLCL}) - 100 = (6 \times 30) - 100 = 80ns
\]

...which meets the SRAM \( t_{WP} \) spec of 60ns.

The SRAM \( t_{WR} \) (write recovery) spec defines how long the addresses must be held after the end of write, which is the end of CPU WR in this design. Since addresses are guaranteed to remain stable while ALE is low, this becomes \( t_{WHLH} \) (RD or WR high to ALE high):

\[
t_{WR} < t_{CLCL} - 20 = 30 - 20 = 10ns
\]

...which just meets the SRAM spec of 10ns.

As for \( t_{DS} \) (data setup to end of write), the corresponding CPU timing is derived by summing \( t_{QVWX} \) (data valid to WR transition) and \( t_{WLWH} \) (WR pulse width) so...

\[
t_{DS} < t_{QVWX} + t_{WLWH} = (t_{CLCL} - 20) + ((6t_{CLCL}) - 100)
\]

thus...

\[
t_{DS} < (30 - 20) + ((6 \times 30) - 100) = 90ns
\]

...easily meeting the SRAM spec of 45ns.

The SRAM hold spec \( t_{DH} \) is simply compared with \( t_{WHQX} \) (data hold after write):

\[
t_{DH} < t_{CLCL} - 20 = 30 - 20 = 10ns
\]

...which meets the SRAM 0ns hold spec.

As for possible bus contention with previous SRAM read data, the SRAM spec indicates the data bus shouldn’t be driven until \( t_{OHZ} \) after the end of a previous read cycle to the same SRAM. Whether this presents a problem depends on the system configuration.

In this example, the SRAM is being used for data access only (i.e., connected to RD and WR). Noting that external data cycles are always separated by an (internal or external) instruction fetch, it is impossible for back-to-back accesses to occur with a data-only memory.

Though not a factor in this example, meeting the \( t_{OHZ} \) spec could be of concern in a system that 1) overlaps code and data into a single 64K space (i.e., by ANDing PSREN and RD) and 2) fetches a data write instruction (ex: MOVX @DPTR,A) from the same SRAM to which the write is targeted. In this case, the tail end of the opcode (MOVX) fetch may collide with the beginning of the subsequent address (DPTR) output if the \( t_{OHZ} \) spec isn’t met.

In this (and only this) rather rare situation, the SRAM \( t_{OHZ} \) spec must meet the tighter CPU instruction float \( t_{PXIZ} = t_{CLCL} - 10 \), i.e., 20ns @ 33MHz) rather than the more relaxed data float \( t_{RHDZ} = 2t_{CLCL} - 28 \), i.e., 32ns @ 33MHz) timing. As stated in the earlier EPROM analysis, this can be accomplished by selecting a faster SRAM chip, isolating the SRAM data bus with a fast shutdown transceiver or confirming the SRAM can operate reliably and correctly despite the bus contention.

**SUMMARY AND CONCLUSIONS**

This application note examined the detailed timing of a 33MHz 80C31/8XC51 system based on actual EPROM and SRAM specifications. Beyond the particulars of this example, the techniques shown are applicable to any design.

One important point illuminated was the degree to which CPU, memory and glue logic specs can vary and thus must be considered on a supplier-by-supplier, speed grade-by-speed grade basis.

For instance, ostensibly equivalent parts from different suppliers may vary in one or more parameters, an example being ‘−70’ EPROMs from two different suppliers which differ in a number of important specs.

Furthermore, even parts from a single supplier may exhibit non-intuitive spec variations across derivatives, speed-grades or process technology. In particular, a part that is ‘twice as fast’ in terms of one spec does not imply that other specs are similarly improved.

These caveats apply to memories, TTL & glue logic and even CPUs themselves, whether from different suppliers or derivatives within a single suppliers catalog.

The development of very fast memories has largely removed ‘access time’ as a barrier for high-speed ‘51 family-based designs. However, despite the natural tendency to focus on ‘access time’, other specifications prove equally, if not more, critical.

Most notably ‘float time’, as it relates to bus contention, cannot be overlooked. Though in practice some degree of bus contention may be tolerable, no recommendation other than to meet the specs can be officially made. Philips explicitly guarantees acceptable behavior of their 80C31/8XC51 in this regard (i.e., note #4) but only the other chip suppliers can vouch for the integrity of their parts.