

# MM54C922/MM74C922 16-Key Encoder MM54C923/MM74C923 20-Key Encoder

## **General Description**

These CMOS key encoders provide all the necessary logic to fully encode an array of SPST switches. The keyboard scan can be implemented by either an external clock or external capacitor. These encoders also have onchip pull-up devices which permit switches with up to 50 k $\Omega$  on resistance to be used. No diodes in the switch array are needed to eliminate ghost switches. The internal debounce circuit needs only a single external capacitor and can be defeated by omitting the capacitor. A Data Available output goes to a high level when a valid keyboard entry has been made. The Data Available output returns to a low level when the entered key is released, even if another key is depressed. The Data Available will return high to indicate acceptance of the new key after a normal debounce period; this two key roll over is provided between any two switches.

An internal register remembers the last key pressed even after the key is released. The TRI-STATE® outputs

provide for easy expansion and bus operation and are LPTTL compatible.

#### **Features**

- 50 kΩ maximum switch on resistance
- On or off chip clock
- On chip row pull-up devices
- 2 key roll-over
- Keybounce elimination with single capacitor
- Last key register at outputs
- TRI-STATE outputs LPTTL compatible
- Wide supply range

3V to 15V

Low power consumption

# **Connection Diagrams**

#### Dual-In-Line Package



Order Number MM54C922N or MM74C922N See Package ROW Y3 - 3
ROW Y4 - 4
ROW Y5 - 5
ROSCILLATOR - 6
REYBOUNCE MASK - 7
COLUMN X4 - 8
COLUMN X3 - 9
GND - 10
GND -

Dual-In-Line Package

19 DATA OUT A

TOP VIEW
Order Number MM54C923N
or MM74C923N
See Package 20A

## **Absolute Maximum Ratings** (Note 1)

Voltage at Any Pin
Operating Temperature Range
MM54C922, MM54C923
MM74C922, MM74C923
Storage Temperature Range

 $V_{\mbox{\footnotesize CC}} - 0.3 \mbox{\footnotesize V}$  to  $V_{\mbox{\footnotesize CC}}$  +  $0.3 \mbox{\footnotesize V}$ 

-55°C to +125°C -40°C to +85°C -65°C to +150°C Package Dissipation
Operating V<sub>CC</sub> Range
V<sub>CC</sub>

Lead Temperature (Soldering, 10 seconds)

500 mW 3V to 15V 18V 300°C

DC Electrical Characteristics Min/Max limits apply across temperature range unless otherwise specified.

|                    | PARAMETER                                                 | CONDITIONS                                                                                                                                  | MIN                                          | TYP                | MAX                | UNITS                  |
|--------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--------------------|--------------------|------------------------|
| CMOS T             | OCMOS                                                     |                                                                                                                                             |                                              |                    |                    |                        |
| V <sub>T+</sub>    | Positive-Going Threshold Voltage at<br>Osc and KBM Inputs | $V_{CC} = 5V$ , $I_{IN} \ge 0.7 \text{ mA}$<br>$V_{CC} = 10V$ , $I_{IN} \ge 1.4 \text{ mA}$<br>$V_{CC} = 15V$ , $I_{IN} \ge 2.1 \text{ mA}$ | 3<br>6<br>9                                  | 3.6<br>6.8<br>10   | 4.3<br>8.6<br>12.9 | \  \  \  \  \  \  \  \ |
| V <sub>T</sub> -   | Negative-Going Threshold Voltage at Osc and KBM Inputs    | $V_{CC}$ = 5V, $I_{IN} \ge 0.7 \text{ mA}$<br>$V_{CC}$ = 10V, $I_{IN} \ge 1.4 \text{ mA}$<br>$V_{CC}$ = 15V, $I_{IN} \ge 2.1 \text{ mA}$    | 0.7<br>1.4<br>2.1                            | 1.4<br>3.2<br>5    | 2<br>4<br>6        | V<br>V                 |
| V <sub>IN(1)</sub> | Logical "1" Input Voltage, Except<br>Osc and KBM Inputs   | V <sub>CC</sub> = 5V,<br>V <sub>CC</sub> = 10V,<br>V <sub>CC</sub> = 15V,                                                                   | 3.5<br>8<br>12.5                             | 4.5<br>9<br>13.5   |                    | V<br>V<br>V            |
| VIN(0)             | Logical "0" Input Voltage, Except Osc and KBM Inputs      | V <sub>CC</sub> = 5V,<br>V <sub>CC</sub> = 10V,<br>V <sub>CC</sub> = 15V,                                                                   |                                              | 0.5<br>1<br>1.5    | 1.5<br>2<br>2.5    | V<br>V<br>V            |
| I <sub>rp</sub>    | Row Pull-Up Current at Y1, Y2, Y3, Y4 and Y5 Inputs       | V <sub>CC</sub> = 5V, V <sub>IN</sub> = 0.1 V <sub>CC</sub><br>V <sub>CC</sub> = 10V<br>V <sub>CC</sub> = 15V                               |                                              | -2<br>-10<br>-22   | -5<br>-20<br>-45   | μΑ<br>μΑ<br>μΑ         |
| VOUT(1             | ) Logical "1" Output Voltage                              | $V_{CC} = 5V$ , $I_{O} = -10\mu A$<br>$V_{CC} = 10V$ , $I_{O} = -10\mu A$<br>$V_{CC} = 15V$ , $I_{O} = -10\mu A$                            | 4.5<br>9<br>13.5                             |                    |                    | V<br>V<br>V            |
| VOUT(0             | ) Logical "0" Output Voltage                              | $V_{CC} = 5V$ , $I_{O} = 10\mu A$<br>$V_{CC} = 10V$ , $I_{O} = 10\mu A$<br>$V_{CC} = 15V$ , $I_{O} = 10\mu A$                               |                                              |                    | 0.5<br>1<br>1.5    | V<br>V<br>V            |
| R <sub>on</sub>    | Column "ON" Resistance at X1, X2, X3 and X4 Outputs       | $V_{CC} = 5V$ , $V_{O} = 0.5V$<br>$V_{CC} = 10V$ , $V_{O} = 1V$<br>$V_{CC} = 15V$ , $V_{O} = 1.5V$                                          |                                              | 500<br>300<br>200  | 1400<br>700<br>500 | Ω<br>Ω                 |
| Icc                | Supply Current                                            | V <sub>CC</sub> = 5V, Osc at 0V<br>V <sub>CC</sub> = 10V<br>V <sub>CC</sub> = 15V                                                           |                                              | 0.55<br>1.1<br>1.7 | 1.1<br>1.9<br>2.6  | mA<br>mA<br>mA         |
| IN(1)              | Logical "1" Input Current at Output Enable                | V <sub>CC</sub> = 15V, V <sub>IN</sub> = 15V                                                                                                |                                              | 0.005              | 1.0                | μА                     |
| <sup>1</sup> IN(0) | Logical "0" Input Current at Output Enable                | V <sub>CC</sub> = 15V, V <sub>IN</sub> = 0V                                                                                                 | -1.0                                         | -0.005             |                    | μΑ                     |
| CMOS/LI            | PTTL INTERFACE                                            |                                                                                                                                             |                                              |                    |                    |                        |
| VIN(1)             | Logical "1" Input Voltage, Except Osc and KBM Inputs      | 54C, V <sub>CC</sub> = 4.5V<br>74C, V <sub>CC</sub> = 4.75V                                                                                 | V <sub>CC</sub> -1.5<br>V <sub>CC</sub> -1.5 |                    |                    | V V                    |
| VIN(0)             | Logical "0" Input Voltage, Except<br>Osc and KBM Inputs   | 54C, V <sub>CC</sub> = 4.5V <sub>.</sub><br>74C, V <sub>CC</sub> = 4.75V                                                                    |                                              |                    | 0.8<br>0.8         | v<br>v                 |
| /OUT(1)            | Logical "1" Output Voltage                                | 54C, V <sub>CC</sub> = 4.5V,<br>I <sub>O</sub> = -360µA                                                                                     | 2.4                                          |                    |                    | V                      |
|                    |                                                           | 74C, V <sub>CC</sub> ≈ 4.75V,<br>I <sub>O</sub> = -360μA                                                                                    | 2.4                                          |                    |                    | V                      |
| VOUT(0)            | Logical "0" Output Voltage                                | 54C, V <sub>CC</sub> = 4.5V,<br>I <sub>O</sub> = -360μA                                                                                     |                                              |                    | 0.4                | V                      |
|                    |                                                           | 74C, V <sub>CC</sub> = 4.75V,<br>I <sub>O</sub> = -360μA                                                                                    |                                              |                    | 0.4                | \ \ \                  |

### DC Electrical Characteristics (Cont'd.)

| PARAMETER                                                                            | CONDITIONS                                                             | MIN   | TYP  | MAX | UNITS |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------------|-------|------|-----|-------|--|--|--|--|--|--|--|
| OUTPUT DRIVE (See 54C/74C Family Characteristics Data Sheet) (Short Circuit Current) |                                                                        |       |      |     |       |  |  |  |  |  |  |  |
| ISOURCE Output Source Current (P-Channel)                                            | V <sub>CC</sub> = 5V, V <sub>OUT</sub> = 0V,<br>T <sub>A</sub> = 25°C  | -1.75 | -3.3 |     | mA    |  |  |  |  |  |  |  |
| SOURCE Output Source Current (P-Channel)                                             | V <sub>CC</sub> = 10V, V <sub>OUT</sub> = 0V,<br>T <sub>A</sub> = 25°C | -8    | -15  |     | mA    |  |  |  |  |  |  |  |
| ISINK Output Sink Current (N-Channel)                                                | $V_{CC} = 5V$ , $V_{OUT} = V_{CC}$ ,<br>$T_A = 25^{\circ}C$            | 1.75  | 3.6  | i   | mA    |  |  |  |  |  |  |  |
| ISINK Output Sink Current (N-Channel)                                                | $V_{CC} = 10V$ , $V_{OUT} = V_{CC}$ ,<br>$T_A = 25^{\circ}C$           | 8     | 16   |     | mA    |  |  |  |  |  |  |  |

## AC Electrical Characteristics T<sub>A</sub> = 25°C, C<sub>L</sub> = 50 pF, unless otherwise noted

|                                    | PARAMETER                                                                              | CONDITIONS                                                                                                                                                                     | MIN | TYP             | MAX               | UNITS          |
|------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------|-------------------|----------------|
| <sup>t</sup> pd0 <sup>,t</sup> pd1 | Propagation Delay Time to<br>Logical "O" or Logical "1"<br>from D.A.                   | C <sub>L</sub> = 50 pF, (Figure 1)  V <sub>CC</sub> = 5V  V <sub>CC</sub> = 10V  V <sub>CC</sub> = 15V                                                                         | ā   | 60<br>35<br>25  | 150<br>80<br>60   | ns<br>ns<br>ns |
| <sup>t</sup> 0H, <sup>t</sup> 1H   | Propagation Delay Time from<br>Logical "O" or Logical "1"<br>into High Impedance State | R <sub>L</sub> = 10k, C <sub>L</sub> = 10pF (Figure 2)<br>V <sub>CC</sub> = 5V R <sub>L</sub> = 10k<br>V <sub>CC</sub> = 10V C <sub>L</sub> = 10 pF<br>V <sub>CC</sub> = 15V   |     | 80<br>65<br>50  | 200<br>150<br>110 | ns<br>ns<br>ns |
| tH0.tH1                            | Propagation Delay Time from<br>High Impedance State to a<br>Logical "0" or Logical "1" | R <sub>L</sub> = 10k, C <sub>L</sub> = 50 pF, (Figure 2)<br>V <sub>CC</sub> = 5V R <sub>L</sub> = 10k<br>V <sub>CC</sub> = 10V C <sub>L</sub> = 50 pF<br>V <sub>CC</sub> = 15V |     | 100<br>55<br>40 | 250<br>125<br>90  | ns<br>ns<br>ns |
| CIN                                | Input Capacitance                                                                      | Any Input, (Note 2)                                                                                                                                                            |     | 5               | 7.5               | pF             |
| COUT                               | TRI-STATE Output Capacitance                                                           | Any Output, (Note 2)                                                                                                                                                           |     | 10              |                   | pF             |

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. Except for "Operating Temperature Range" they are not meant to imply that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation.

Note 2: Capacitance is guaranteed by periodic testing.

# **Switching Time Waveforms**



T1  $\simeq$  T2  $\approx$  RC, T3  $\approx$  0.7 RC where R  $\cong$  10k and C is external capacitor at KBM input.







FIGURE 2

## **Block Diagram**



### **Truth Table**

| SWITCH   | 0     | 1     | 2     | 3     | 4     | 5     | 6     | 7     | 8     | 9     | 10    | 11    | 12    | 13    | 14    | 15    | 16     | 17     | 18     | 19     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|--------|--------|--------|
| POSITION | Y1,X1 | Y1,X2 | Y1,X3 | Y1,X4 | Y2,X1 | Y2,X2 | Y2,X3 | Y2,X4 | Y3,X1 | Y3,X2 | Y3,X3 | Y3,X4 | Y4,X1 | Y4,X2 | Y4,X3 | Y4,X4 | Y5*,X1 | Y5*,X2 | Y5*,X3 | Y5*,X4 |
| D A      | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0      | 1      | 0      | 1      |
| T B      | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 0      | 0      | 1      | 1      |
| A C      | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 0     | 0     | 0     | ٥     | 1     | 1     | 1     | 1     | 0      | 0      | 0      | 0      |
| 0 D      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 0      | 0      | 0      | 0      |
| U E*     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | . 0   | 0     | 0     | 0     | 0     | 0     | 1      | 1      | 1      | 1      |

<sup>\*</sup>Omit for MM54C922/MM74C922

# **Typical Performance Characteristics**





# Typical Performance Characteristics (Cont'd.)





# **Typical Applications**

#### Synchronous Handshake (MM74C922)



#### Synchronous Data Entry Onto Bus (MM74C922)



Outputs are enabled when valid entry is made and go into TRI-STATE when key is released.

#### Asynchronous Data Entry Onto Bus (MM74C922)

# Keyboard Suppliers Mini Key Series KL Digitran Company Pasadena, California

Computronics Engineering 7235 Hollywood Blvd Hollywood, California 90046



Outputs are in TRI-STATE until key is pressed, then data is placed on bus. When key is released, outputs return to TRI-STATE.

Note 3: The keyboard may be synchronously scanned by omitting the capacitor at osc. and driving osc. directly if the system clock rate is lower than 10 kHz.

#### Typical Application (Cont'd.)

#### MM74C922 VCC KRM X1 osc X2 X3 X4 DATA AVAILABLE 2 3 4 5 6 Y2 **Y3** C 10 11 я q TO DATA 12 13 14 15 16 17 18 19 20 21 22 23 27 24 25 26 28 29 30 100 kg

Expansion to 32 Key Encoder (MM74C922)

## **Theory of Operation**

The MM74C922/MM74C923 Keyboard Encoders implement all the logic necessary to interface a 16 or 20 SPST key switch matrix to a digital system. The encoder will convert a key switch closer to a 4(MM74C922) or 5(MM74C923) bit nibble. The designer can control both the keyboard scan rate and the key debounce period by altering the oscillator capacitor, C<sub>OSE</sub>, and the key bounce mask capacitor, C<sub>MSK</sub>. Thus, the MM74C922/MM47C923's performance can be optimized for many keyboards.

The keyboard encoders connect to a switch matrix that is 4 rows by 4 columns (MM74C922) or 5 rows by 4 columns (MM74C923). When no keys are depressed, the row inputs are pulled high by internal pull-ups and the column outputs sequentially output a logic "0". These outputs are open drain and are therefore low for 25% of the time and otherwise off. The column scan rate is controlled by the oscillator input, which consists of a Schmitt trigger oscillator, a 2-bit counter, and a 2-4-bit decoder.

When a key is depressed, key 0, for example, nothing will happen when the X1 input is off, since Y1 will remain high. When the X1 column is scanned, X1 goes low and Y1 will go low. This disables the counter and keeps X1 low. Y1 going low also initiates the key bounce circuit

timing and locks out the other Y inputs. The key code to be outputted is a combination of the frozen counter value and the decoded Y inputs. Once the key bounce circuit times out, the data is latched, and the Data Available (DAV) output goes high.

If, during the key closure the switch bounces, Y1 input will go high again, restarting the scan and resetting the key bounce circuitry. The key may bounce several times, but as soon as the switch stays low for a debounce period, the closure is assumed valid and the data is latched.

A key may also bounce when it is released. To ensure that the encoder does not recognize this bounce as another key closure, the debounce circuit must time out before another closure is recognized.

The two key roll over feature can be illustrated by assuming a key is depressed, and then a second key is depressed. Since all scanning has stopped, and all other Y inputs are disabled, the second key is not recognized until the first key is lifted and the key bounce circuitry has reset.

The output latches feed TRI-STATE®, which are enabled when the Output Enable (OE) input is taken low.