# 9401 # CRC GENERATOR/CHECKER FAIRCHILD TTL MACROLOGIC DESCRIPTION - The 9401 Cycle Redundancy Check (CRC) Generator/Checker provides an advanced tool for implementing the most widely used error detection scheme in serial digital data handling systems. A 3-bit control input selects one-of-eight generator polynomials. The list of polynomials includes CRC-16 and CRC-CCITT as well as their reciprocals (reverse polynomials). Automatic right justification is incorporated for polynomials of degree less than 16. Separate clear and preset inputs are provided for floppy disc and other applications. The Error output indicates whether or not a transmission error has occurred. Another control input inhibits feedback during check word transmission. The 9401 is fully compatible with all TTL families. - **GUARANTEED 10 MHz DATA RATE** - EIGHT SELECTABLE POLYNOMIALS - **ERROR INDICATOR** - SEPARATE PRESET AND CLEAR CONTROLS - **AUTOMATIC RIGHT JUSTIFICATION** - **FULLY COMPATIBLE WITH ALL TTL LOGIC FAMILIES** - 14-PIN PACKAGE - TYPICAL APPLICATIONS: FLOPPY AND OTHER DISC STURAGE SYSTEMS DIGITAL CASSETTE AND CARTRIDGE SYSTEMS **DATA COMMUNICATION SYSTEMS** | PIN NAMES | | LOADING (Note a) | | | |---------------------------------|----------------------------------|------------------|-----------|--| | | | HIGH | LOW | | | S <sub>0</sub> - S <sub>2</sub> | Polynomial Select Inputs | 1.0 U.L. | 0.23 U.L. | | | o - | Data Input | 1.0 U.L | 0.23 U.L. | | | <u> </u> | Clock (Operates on HIGH-to- | 1.0 U.L. | 0.23·U.L. | | | | LOW Transition) Input | | | | | CWE | Check Word Enable Input | 1.0 U.L | 0.23 U.L. | | | P | Preset (Active LOW) Input | 1.0 U.L | 0.23 U.L. | | | MR | Master Reset (Active HIGH) Input | 1.0 U.L. | 0.23 U.L. | | | Q | Data Output (Note b) | 10 U.L | 5 U.L. | | | ER | Error Output (Note b) | 10 U.L. | 5 U.L. | | | | | | | | ### NOTES: - a. 1 TTL Unit Load (U.L.) = 40 µA HIGH/1.6 mA LOW. - The output LOW drive factor is 2.5 U.L. for Military (XM) and 5 U.L. for Commercial (XC) Temperature Ranges. ## CONNECTION DIAGRAM DIP (TOP VIEW) VCC = Pin 14 GND = Pin 7 Pins 6 and 9 not connected. The Flatpak version has the same pinouts (Connection Diagram) as the Dual In-line Package. ## FAIRCHILD . 9401 FUNCTIONAL DESCRIPTION – The 9401 is a 16-bit programmable device which operates on serial data streams and provides a means of detecting transmission errors. Cyclic encoding and decoding schemes for error detection are based on polynomial manipulation in modulo arithmetic. For encoding, the data stream (message polynomial) is divided by a selected polynomial. This division results in a remainder which is appended to the message as check bits. For error checking, the bit stream containing both data and check bits is divided by the same selected polynomial. If there are no detectable errors, this division results in a zero remainder. Although it is possible to choose many generating polynomials of a given degree, standards exist that specify a small number of useful polynomials. The 9401 implements the polynomials listed in *Table 1* by applying the appropriate logic levels to the select pins S<sub>0</sub>, S<sub>1</sub> and S<sub>2</sub>. The 9401 consists of a 16-bit register, a Read Only Memory (ROM) and associated control circuitry as shown in the block diagram. The polynomial control code presented at inputs $S_0$ , $S_1$ and $S_2$ is decoded by the ROM, selecting the desired polynomial by establishing shift mode operation on the register with Exclusive OR gates at appropriate inputs. To generate the check bits, the data stream is entered via the Data inputs (D), using the HIGH-to-LOW transition of the Clock input $(\overline{CP})$ . This data is gated with the most significant output (Q) of the register, and controls the Exclusive OR gates (Figure 1). The Check Word Enable (CWE) must be held HIGH while the data is being entered. After the last data bit is entered, the CWE is brought LOW and the check bits are shifted out of the register and appended to the data bits using external gating (Figure 2). To check an incoming message for errors, both the data and check bits are entered through the D input with the CWE input held HIGH. The 9401 is not in the data path, but only monitors the message. The Error Output becomes valid after the last check bit has been entered into the 9401 by a HIGH-to-LOW transition of $\overline{CP}$ . If no detectable errors have occurred during the data transmission, the resultant internal register bits are all LOW and the Error Output (ER) is LOW. If a detectable error has occurred, ER is HIGH. A HIGH on the Master Reset input (MR) asynchronously clears the register. A LOW on the Preset input $(\overline{P})$ asynchronously sets the entire register if the control code inputs specify a 16-bit polynomial; in the case of 12 or 8-bit check polynomials only the most significant 12 or 8 register bits are set and the remaining bits are cleared. TABLE 1 | | 1ABLE 1 | | | | | | | | | |-------------|----------------|----------------|----------------|---------------------------|-------------------|--|--|--|--| | SELECT CODE | | E | POLYNOMIAL | REMARKS | | | | | | | ļ | S <sub>2</sub> | S <sub>1</sub> | S <sub>O</sub> | | | | | | | | ŀ | L. | | L | ×16+×15+×2+1 | CRC-16 | | | | | | | L | | н | x16+x14+x+1 | CRC-16 REVERSE | | | | | | | L | н | ١ . | X16+X15+X13+X7+X4+X2+X1+1 | | | | | | | Ì | L | н | н | X12+X11+X3+X2+X+1 | CRC-12 | | | | | | | н | | [ | x8+x7+x5+x4+x+1 | | | | | | | | н | | н | x8+1 | LRC-8 | | | | | | | Н | Н | L | x16+x12+x5+1 | CRC-CCITT | | | | | | | н | Н н | н | x16+x11+x4+1 | CRC-CCITT REVERSE | | | | | Fig. 1 EQUIVALENT CIRCUIT FOR X16+X15+X2+1 # DC CHARACTERISTICS OVER OPERATING TEMPERATURE RANGE (unless otherwise noted) | | PARAMETER | | LIMITS | | | UNITS | TEST CONDITIONS (Note 1) | | |--------|------------------------------|--------------------|--------------|-------|-------|------------|--------------------------------------------------|--| | SYMBOL | | | MIN 2.0 | TYP | 0.7 | 0 | Guaranteed Input HIGH Voltage | | | | | | | | | V | | | | VIH | Input HIGH Voltage | Oltage | | | | | Guaranteed Input LOW Voltage | | | VIL | Input LOW Voltage | | | | 0.8 | <b>'</b> | Guaranteed mbot core correge | | | | | xc | | -0.9 | -1.5 | V | VCC = MIN, IIN = -18 mA | | | VCD | Input Clamp Diode Volta | XM | 2.4 | 3.4 | | 1 | V <sub>CC</sub> = MIN, I <sub>OH</sub> = -400 µA | | | Vон | Output HIGH Voltage | | 2.4 | 3.4 | | <b>'</b> ' | | | | | | xc | 2.7 | 0.35 | 0.4 | T v | VCC = MIN, IOL = 4.0 mA | | | VOL | Output LOW Voltage | XM & XC | | 0.45 | 0.5 | V | VCC = MIN, IQL = 8.0 mA | | | | | xc | | 1.0 | 40 | μА | VCC = MAX, VIN = 2.7 V | | | | Input HIGH Current | Logue HIGH Current | | 1.0 | 1.0 | mA | VCC = MAX, VIN = 5.5 V | | | 'In | | | ļ | -0.22 | -0.36 | mA | VCC = MAX, VIN = 0.4 V | | | IIL | Input LOW Current | | <del> </del> | -0.22 | -100 | mA | VCC = MAX, VOUT = 0 V (Note 3 | | | los | Output Short Circuit Current | | -15 | 70 | | mA | VCC = MAX, Inputs Open | | | Icc | Supply Current | | 70 | 110 | 1 | 100 | | | AC CHARACTERISTICS: VCC = 5.0 V, TA = 25°C | SYMBOL f <sub>max</sub> | PARAMETER Maximum Clock Frequency | LIMITS | | | | | | |-------------------------|--------------------------------------------------------------------------------------|-----------|-----------------------|-----|-------|--------------|-----------| | | | MIN<br>10 | TYP<br>(Note 2)<br>18 | MAX | UNITS | CONDITIONS | | | | | | | | | | | | TPHL | Propagation Delay, Clock, MR to Data Output Propagation Delay, Preset to Data Output | | 30 | 55 | ns | Fig. 3, 4, 5 | CL = 15 p | | TPHL | | | 40 | 60 | ns | | | | TPLH<br>TPHL | Propagation Delay, Clock, | | 40 | 60 | ns | | | | የPHL<br>የPLH | Propagation Delay, Clock, MR or Preset to Error Output | | 40 | 60 | ns | | | AC SET-UP REQUIREMENTS: V<sub>CC</sub> = 5.0 V, T<sub>A</sub> = 25°C | SYMBOL | PARAMETER Clock Pulse Width (LOW) | LIMITS | | | UNITS | CONDITIONS | | |----------------|---------------------------------------|--------|-----|-------------|--------------------------------------------------|------------|------------| | | | MIN | TYP | MAX | ns | | | | | | 35 | | | | Fig. 2 | | | ₩ÇP (L) | | 55 | 35 | | ns | | 1 | | <sub>5</sub> D | Set-up Time, Data to Clock | | 35 | <del></del> | ns | | CL = 15 pF | | CWE | Set-up Time, CWE to Clock | 55 | 35 | | | Fig. 6 | | | 30110 | Hold Time, Data and CWE to Clock | 0 | -10 | | ns | | | | <u>h</u> | | 40 30 | | ns | Fig. 4 | 1 | | | wP (L) | Preset Pulse Width (LOW) | | | | <del> </del> | Fig. 6 | 7 | | WMR (H) | Master Reset Pulse Width (HIGH) | 35 | 25 | | ns | | | | (MINITE (LI) | Recovery Time, MR and Preset to Clock | 50 | 25 | | ns | Fig. 4, 5 | į | 1. For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions for the applicable device type. 2. Typical limits are at V<sub>CC</sub> = 5.0 V, T<sub>A</sub> = 25°C. 3. Not more than one output should be shorted at a time. ## NOTES: - Check word Enable is HIGH while data is being clocked, LOW during transmission of check bits. 9401 must be reset or preset before each computation. CRC check bits are generated and appended to data bits. Fig. 2 CHECK WORD GENERATION Fig. 3 PROPAGATION DELAYS, CP TO Q AND CP TO ER Fig. 4 PROPAGATION DELAYS, P TO Q AND ER PLUS RECOVERY TIME P TO CP Fig. 5 PROPAGATION DELAYS, MR TO Q AND ER PLUS RECOVERY TIME, MR TO CP Fig. 6 SET-UP AND HOLD TIMES, D TO CP AND CWE TO CP