## Simple Byte Parity Applications Featuring the FAST® 74F899

Maintaining data integrity during transmission and retrieval from storage devices is a constant challenge for computer designers. Meeting this challenge is increasingly important for the ongoing evolution of higher-performance high-density memory systems, ranging from low-end PCs to high-end work stations and mainframes. Of the various methods used to improve data integrity in the transmission, storage, and retrieval of data/address words in computer systems, two of the most common are: (1) Error Detection and Correction (EDAC) and (2) Simple Byte Parity (SBP).

EDAC is generally found in higher-end systems. This technique uses modified Hamming code to detect and correct single-bit errors in whole data words. For example, the FAST 74F632 EDAC device is typically used to insure data integrity from storage devices. The 74F632 generates a 7-bit check word from an incoming 32-bit data word. The check word is then stored in memory along with the data word during the memory write cycle. During the memory read cycle, the EDAC processes the 39 bit word to determine if errors exist. Only single-bit errors in the 32-bit data word are flagged and corrected by the EDAC. Single-bit errors in the check word and 2-bit errors in any of the 39-bit positions of the word are flagged but cannot be corrected. Three or more simultaneous-bit errors can cause EDAC to perceive no error, correctable error, or uncorrectable error and will produce erroneous results in all three cases. Gross errors of all 39 bits low or high will be recognized and flagged.

SBP implementations can be found in a broad spectrum of computer systems. Typically a parity tree circuit initially evaluates the byte and adds a parity status bit based on the odd/even bit content of the byte. If subsequent evaluation of the byte indicates a parity status bit change, then an error condition is flagged. SBP is effective at flagging single-bit errors within each byte plus parity word, but cannot determine the error location or correct the bit error within the 9-bit word. Some multiple-bit errors within each byte plus parity word will also be flagged, i.e., 3-, 5-, 7-, and 9-bit errors. SBP is commonly used to improve data integrity during transmission on the buses and across backplanes. SBP is also easily used in lieu of EDAC in managing the integrity of data flowing to and from storage devices. System response to detection of parity error typically will be a resend of data or an initiation of diagnostics.

The data word width used in a system can influence the designer's choice of SBP or EDAC for the application. For systems with data word width up to 64 bits, SBP can be

National Semiconductor Application Note 753 J. Chapin G. Connolly J. Davis February 1991



more attractive versus EDAC in terms of the memory and board routing overhead. For example, 32-bit data systems need to route four extra parity bits for SBP versus 7 bits extra for EDAC. The system memory will be similarly burdened by having to store the wider EDAC words. For 64-bit data words, EDAC achieves parity on the overhead to support eight extra bits of EDAC versus the eight extra SBP Bits. Another factor influencing the designer's choice is the effectiveness of error detection. In the 32-bit 74F632 EDAC example discussed earlier, we noted that single- and dualbit errors in the whole 39-bit word were accurately flagged but that three or more bit errors will be processed incorrectly. With the 32-bit SBP system, 1-, 3-, 5-, 7-, and 9-bit errors in each data byte plus parity bit will be accurately flagged. For a SBP system, parity is traditionally generated and transmitted without simultaneously checking for correct parity generation. Upon receipt of the word, data plus parity, the receiver will re-generate parity and check against the original transmitted parity bit. Logic devices are typically used in various combinations to implement these systems, i.e., 74F373/573, 74F280, and 74F541 or 74F573 and 74F657 or equivalent devices or PLD's. The 74F657 is particularly useful in that it will generate and transmit parity and will perform a parity check upon a direction reversal, i.e., readback mode. However, SBP systems using the 74F657 tend to be awkward in checking parity. After parity generation, system buses need to be TRI-STATE®, device direction reversed and the system buses re-enabled prior to doing the parity check. This is time consuming, inefficient, and degrades the system performance.

The desire for enhanced byte parity system performance has led to development of National Semiconductor's 74F899. This single device incorporates latches and dualparity generators onto a single die, eliminating the need for unnecessary bus direction reversal to check parity.

## THE 74F899 IN BYTE PARITY SYSTEMS

The 74F899 is a 9-bit latchable transceiver with parity generation and simultaneous check capability. The 74F899 is packaged in the 28-pin PLCC. Owing to its functional complexity and flexibility of use, it can be efficiently applied in high-performance SBP systems. *Figure 1* illustrates the function blocks comprising the 74F899. Note that this single chip contains the approximate functional complexity of eight discrete IC's; two 74F843's, two 74F820's, two 74F827's. a 74F157, and a 74F86. The various modes of operation for the 74F899 are shown in Table I. imple Byte Parity Applications Featuring the FAST 74F899

FAST® and TRI-STATE® are registered trademarks of National Semiconductor Corporation

© 1995 National Semiconductor Corporation TL/F/10905

RRD-B30M75/Printed in U. S. A



| TABLE I. Function Table |     |     |     |     |                                                                                                                                                                                                                                                                    |
|-------------------------|-----|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Inputs                  |     |     |     |     | Operation                                                                                                                                                                                                                                                          |
| GAB                     | GBA | SEL | LEA | LEB |                                                                                                                                                                                                                                                                    |
| н                       | н   | Х   | х   | х   | Busses A and B are TRI-STATE.                                                                                                                                                                                                                                      |
| н                       | L   | L   | L   | н   | Generates parity from B[0–7] based on O/ $\overline{E}$ (Note 1). Generated parity $\rightarrow$ APAR. Generated parity checked against BPAR and output as $\overline{\text{ERRB}}$ .                                                                              |
| Н                       | L   | L   | н   | Н   | Generates parity from B[0–7] based on $O/\overline{E}$ . Generated parity $\rightarrow$ APAR. Generated parity checked against BPAR and output as $\overline{ERRB}$ . Generated parity also fed back through the A latch for generate/check as $\overline{ERRA}$ . |
| Н                       | L   | L   | x   | L   | Generates parity from B latch data based on O/ $\overline{E}$ . Generated parity $\rightarrow$ APAR. Generated parity checked against latched BPAR and output as $\overline{ERRB}$ .                                                                               |
| Н                       | L   | н   | x   | н   | BPAR/B[0-7] $\rightarrow$ APAR/A0-7] Feed-through mode. Generated parity checked against BPAR and output as ERRB.                                                                                                                                                  |
| Н                       | L   | Н   | н   | н   | $BPAR/B[0-7] \rightarrow APAR/A[0-7]$<br>Feed-through mode. Generated parity checked against BPAR and output as ERRB.<br>Generated parity also fed back through the A latch for generate/check as ERRA.                                                            |
| L                       | Н   | L   | н   | L   | Generates parity for A[0–7] based on O/ $\overline{E}$ . Generated parity $\rightarrow$ BPAR. Generated parity checked against APAR and output as $\overline{ERRA}$ .                                                                                              |
| L                       | н   | L   | н   | н   | Generates parity from A[0–7] based on $O/\overline{E}$ . Generated parity $\rightarrow$ BPAR. Generated parity checked against APAR and output as $\overline{ERRA}$ . Generated parity also fed back through the B latch for generate/check as $\overline{ERRB}$ . |
| L                       | Н   | L   | L   | x   | Generates parity from A latch data based on O/ $\overline{E}$ . Generated parity $\rightarrow$ BPAR. Generated parity checked against latched APAR and output as $\overline{ERRA}$ .                                                                               |
| L                       | Н   | Н   | н   | L   | APAR/A[0-7] $\rightarrow$ BPAR/B[0-7]<br>Feed-through mode. Generated parity checked against APAR and output as ERRA.                                                                                                                                              |
| L                       | н   | н   | н   | н   | APAR/A[0-7] $\rightarrow$ BPAR/B[0-7]<br>Feed-through mode. Generated parity checked against APAR and output as ERRA.<br>Generated parity also fed back through the B latch for generate/check as ERRB.                                                            |

H = HIGH Voltage Level

L = LOW Voltage Level

X = Immaterial

### Note 1: $O/\overline{E} = ODD/\overline{EVEN}$

### FUNCTIONALITY DISCUSSION

Referring to *Figure 1*, note that use of two parity generators is key to the 74F899's enhanced functional flexibility. With both latches transparent, the 74F899 performs bidirectional, realtime checking of the incoming byte and its parity bit. For example, when transferring data from A side to B side, parity is regenerated for the byte at  $A_{0-7}$ , compared against APAR, and flagged at ERRA. The  $A_{0-7}$  byte and its original parity bit APAR is output to  $B_{0-7}$  and BPAR respectively. This is known at the feedthrough mode when  $\overline{SEL} = high$ . The regenerated parity bit is output at BPAR in generate mode when  $\overline{SEL} = low$ . The byte and parity bit at B side are fed through the transparent B side latch. Parity is regenerated to be approximately of the side latch.

ed for the B<sub>0-7</sub> byte, compared against BPAR, and flagged at ERRB. In this example, realtime parity checking was performed on both sides during data transmission without having to TRI-STATE the B side bus. In feedthrough mode, APAR feeds through to BPAR and vice versa, and the device behaves as a 9-bit latchable transceiver with optional bidirectional parity checking. The parity checking is termed "optional" since if the APAR/BPAR bit is actual parity relevant to bytes  $A_{0-7}/B_{0-7}$ , only then will the response at ERRA/ERRB be relevant. In the generate mode (internally-generated parity bit is output), the device essentially behaves as a 8-bit latchable transceiver with bidirectional parity generate and optional bidirectional parity check capability. Again, the term "optional" applies as mentioned above.

The device can be configured for use in systems with odd or even parity. The  $I_{OH}/I_{OL}$  drive capability is -3/24 mA for the  $A_{0-7}$  and APAR outputs. The  $B_{0-7}$  and BPAR outputs, being designed to drive the system backplane, will drive -15/64 mA. The error outputs, ERRA and ERRB are active low with standard FAST bi-state drive for greatest flexibility. (Refer to Table I for more details on the 74F899's functional operation.)

An additional feature of the 74F899 is an ability to be configured for system diagnostics by identifying parity generation errors. Diagnostics can be performed via manipulation of the ODD/EVEN and/or APAR (BPAR) signals when in the feedthrough configuration and with the respective latches transparent. The ability to read-back via the latches also assists software programmers in debugging a system. Some noteworthy performance features of the 74F899 include:

- Data to Latch Enable  $t_S/t_H = 5/0$  ns (min),
- Data to Generated Parity/Error = 18 ns (max),
- Data In to Data Out (transparent) = 14 ns (max),
- $I_{CC}$  max = 210 mA, and ESD protection = 4000V min.

# COMPARISON OF 74F899 PERFORMANCE WITH DISCRETE LOGIC IMPLEMENTATION

The 74F899's enhanced functional flexibility and superior performance are best illustrated by direct comparison with various discrete logic SBP implementations for parity generation and checking. The basic assumption is made that all practical discrete applications will necessitate an input data latch capability and TRI-STATE outputs in consideration of CPU efficiency and bus-interface compatibility.





*Figure 2a* illustrates the use of standard logic devices to generate—but not check parity—in a parity generate/transmit application where checking is done separately at the receiver. Compare this circuit's performance with the equivalent function performed by the 74F899 shown in *Figure 2b*. Note that despite *Figure 2a* circuit's functional simplicity, the 74F899 implementation is closely matched in power con-

sumption ( $I_{CC}$ ). Both implementations propagate the data byte in 14 ns, but the 74F899 is considerably quicker in outputting the parity bit onto the bus at 18 ns versus the 35 ns of *Figure 2a*. As shown in the timing diagrams, the 74F899's generate mode inherently provides realtime parity transmission check capability through the transparent B side latch and also provides the classic readback parity check capability.













*Figure 5a* illustrates the use of 74F657s in a manner which begins to approximate the functional capabilities of the 74F899, i.e., bidirectional parity generate with check. Comparison to the 74F899 implementation in *Figure 5b* shows the 74F899 to again be the superior performer in all areas. Although both implementations perform realtime incoming parity checks and readback checks, only the 74F899 is capable of the realtime check of outgoing transmitted data/ parity.

## THE 74F899 CONFIGURED FOR DIAGNOSTICS

Figure 6a illustrates the 74F899 configured for diagnostics in parity generate mode. Parity is regenerated from the in-

coming data byte  $A_{0-7}$ . Incoming parity APAR is checked against the regenerated bit and any error is flagged at ERRA. The data byte and its regenerated parity bit is passed to the B-bus. With LEB HIGH, the data on the B-bus is fed back into the device and a second generation/check is performed with error flagged at ERRB. ANDing of the ERRA and ERRB signals provides a single error flag (ERR) for parity discrepancies on both buses. This configuration is useful for detecting and diagnosing bus shorts/open circuits and/or parity generation errors internal or external to the 74F899. The ANDing of ERRA/ERRB could also initiate a readback operation for comparison against the original data word transmitted.





*Figure 6b* illustrates the 74F899 uniquely configured for diagnostics in feedthrough mode. In this configuration, transmission errors will be flagged even if parity is not inputed. For example, with the 74F899 configured for even parity, if the  $A_{0-7}$  input byte is evaluated for parity and found to be odd, and if the APAR (9th) bit is intentionally not a parity bit and it is a valid low (even), then ERRA will go low indicating the 74F899's perception of a parity error.  $A_{0-7}$  is passed to B<sub>0-7</sub> and APAR is passed to BPAR while the transparent B

side latch permits re-evaluation and corresponding perception of a parity error at ERRB. The Exclusive-OR sees that ERRA = ERRB and therefore no transmission error has occurred. Conversely, had a single 3-, 5-, 7-, or 9-bit change on the B side (any combination of B<sub>0-7</sub> and BPAR bits) occurred in transmission, then ERRA would not equal ERRB and the XOR comparison would flag the error(s). This configuration is also useful for diagnosing a bus short/open on the receive side of the device or internal 74F899 parity generation errors.

## SUMMARY AND CONCLUSIONS

Simple Byte Parity implementations using the 74F899 should be considered where enhancements to data transmission integrity are needed and should include applications where EDAC is traditionally used.

The principal enhancements offered by the 74F899 in SBP applications over a discrete implementation include:

- Replacement of up to eight logic devices with a single 28-pin PLCC package.
- Significantly lower power consumption than discrete implementations having functional similarity to the 74F899, i.e., bidirectional parity generate and check.
- Superior throughput in a system environment: Real-time error checking versus the readback method common with other implementations.
- Superior diagnostic capability within a system.
- Capability for functional configuration as a 9-bit 74F245 or 74F543, i.e., feedthrough mode.

Lit. # 100753

## LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

- Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
- A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.



National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and National reserves the right at any time without notice to change said circuitry and specifications.