# CA95C68/18/09 # DES DATA CIPHERING PROCESSORS (DCP) - Encrypts/Decrypts data using National Bureau | of Standards Data Encryption Standard (DES) - · High speed, pin and function compatible version of industry standard AMD AM9568, AM9518 and VLSI VM009 - · Supports four standard ciphering modes: Electronic Code Book (ECB), Cipher Block Chaining (CBC), as well as 1 and 8 bit Cipher Feedback (CFB) - Data rates greater than 11 Mbytes per second (25 MHz) in ECB or CBC modes - · Three separate registers for encryption, decryption and master keys improve system security and throughput by eliminating the need to reload keys frequently - Fully static CMOS, TTL I/O compatible device, operates at up to 33MHz - Low power consumption allows battery back-up of internal key registers - · Three separate programmable ports (master, slave and key data) - Available in 44 pin PLCC and 40 pin PDIP and 44 pin TQFP packages The Tundra Semiconductor Corporation CA95C68/18/09 DES Data Ciphering Processors (DCPs) implement the National Bureau of Standards Data Encryption Standard (DES), FIPS PUB 46 (1-15-1977). The DCPs were designed to be used in a variety of environments where computer and communications security is essential. The DCPs provide a high throughput rate (up to 14 Mbytes per second) using ECB or CBC modes of operation. The DCPs provide a unique 1 bit CFB mode as well as the standard 8 bit mode. Separate ports for key input, clear data and enciphered data enhance security for your application. The system communicates with the DCP using commands entered in the Master Port or through auxiliary control lines. Once the DCP is set up, data can flow through at high speeds since input, output and ciphering activities are performed concurrently. External DMA control can easily be used to enhance throughput in many system configurations. The CA95C68 is designed to interface directly to the iAPX86, 88 CPU bus, and with a minimum of external logic, to the 2900 and 8051 families of processors. The CA95C18 is designed to interface directly with Z8000, 68000 type bus interfaces. The CA95C09 may be configured to behave as either the CA95C68 or the CA95C18 (see OPTION pin in Table 3-2), the only difference being the order of the signal names on the device package. Table 3-1: CA95C68/18/09 Data Transfer Rates | Product | | Data Transfer Rates | | | | | | | | | | |--------------|-------------------------------|--------------------------|-------------------------|-------|--|--|--|--|--|--|--| | Code | ECB or CBC Mode<br>(Mbytes/s) | CFB-8 Mode<br>(Mbytes/s) | CFB-1 Mode<br>(Mbits/s) | (MHz) | | | | | | | | | CA95Cxx 5 | 2.22 | 0.27 | 0.27 | 5 | | | | | | | | | CA95Cxx - 10 | 4.44 | 0.55 | 0.55 | 10 | | | | | | | | | CA95Cxx - 16 | 7.10 | 0.88 | 0.88 | 16 | | | | | | | | | CA95Cxx - 20 | 8.88 | 1.11 | 1.11 | 20 | | | | | | | | | CA95Cxx - 25 | 11.11 | 1.38 | 1.38 | 25 | | | | | | | | | CA95Cxx -33 | 14.81 | 1.85 | 1.85 | 33 | | | | | | | | **Tundra Semiconductor Corporation** 3-25 6588101 0005198 3T3 **=** Powered by ICminer.com Electronic-Library Service CopyRight 2003 Figure 3-1: CA95C68/18/09 Block Diagrams 3-26 ■ 6588101 0005199 23T ■ Figure 3-2: CA95C68 40-Pin PDIP Figure 3-5: CA95C68 44-Pin PLCC Figure 3-3: CA95C18 40-Pin PDIP Figure 3-6: CA95C18 44-Pin PLCC Figure 3-4: CA95C09 44-Pin PLCC Figure 3-7: CA95C09 44-Pin TQFP **- 6588101 0005200 881 -** # Table 3-2: Pin Description | Sb. al | 95C | 68/18 | 950 | C09 | TYPE | Name and Function | | | | | | |--------------------------------------|----------------|----------------|----------------|----------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Symbol | PDIP | PLCC | PLCC | TQFP | 11176 | TANIBO WILO I WILOMOTI | | | | | | | CLK | 14 | 15 | 16 | 10 | 1 | Clock: An external timing source is input via this pin. The Master and Slave Port data strobe signals ( $\overline{\text{MWR}}$ , $\overline{\text{MRD}}$ , $\overline{\text{SDS}}$ for CA95C68 and $\overline{\text{MDS}}$ , $\overline{\text{SDS}}$ for CA95C18) must change synchronously with the clock input. In Direct Control Mode the AUX <sub>5</sub> -S/s must also be synchronous. The output flags for the three ports ( $\overline{\text{AFLG}}$ , $\overline{\text{MFLG}}$ , $\overline{\text{SFLG}}$ ) will all change synchronously with the clock. | | | | | | | C/ĸ | 13 | 14 | - | _ | I | Control/Key Mode Control: This input controls the mode of operation of the DCP. The DCP enters into Multiplexed Control Mode when a low input placed on the $C/\overline{k}$ pin, enabling programmed access to internal register through the Master Port and enabling input of keys through the Auxiliar Port. In Direct Control Mode ( $C/\overline{k}$ HIGH), several of the Auxiliary Port pir become direct control/status signals which can be driven/sensed by high speed controller logic, and access to internal registers through the Master Port is limited to the Input and Output Registers. | | | | | | | DCM | - | - | 15 | 9 | 1 | <b>Direct Control Mode</b> : (For CA95C09) This input functions identical to the $C/\overline{K}$ input. (See $C/\overline{K}$ pin description). | | | | | | | MP <sub>7</sub> –<br>MP <sub>0</sub> | 21-24<br>19-16 | 23-26<br>21-18 | 24-27<br>21-18 | 18-21<br>15-12 | I/O | Master Port Bus: These eight bi-directional signals are used to input and output data, as well as specify the internal register addresses in Multiplexed Control Mode. The Master Port provides software access to the Status, Command, Mode, Mask, Input and Output Registers. For the CA95C68, the tri-state Master Port outputs will be enabled only when the Master Port is selected by Master Port Chip Select ( $\overline{\text{MCS}}$ ) LOW, and when Master Port Read ( $\overline{\text{MRD}}$ ) is strobed LOW. For the CA95C18, the Master Port outputs are enabled when selected by $\overline{\text{MCS}}$ , and when MR/W is HIGH and $\overline{\text{MDS}}$ is LOW. MP0 is the low-order bit. Data and key information are entered into this port with the most significant byte first. | | | | | | | MCS | 25 | 27 | 28 | 22 | l | Master Port Chip Select: This active LOW input signal is used to select the Master Port. In Multiplexed Control Mode ( $C/\overline{k}$ LOW), the level on $\overline{\text{MCS}}$ is latched internally on the falling edge of Master Port Address Latch Enable (MALE). This latched level is maintained as long as MALE is LOW; when MALE is HIGH, the latch becomes transparent and the internal signal will follow the $\overline{\text{MCS}}$ input. No latching of $\overline{\text{MCS}}$ occurs in Direct Control Mode ( $C/\overline{k}$ HIGH). The level on $\overline{\text{MCS}}$ is passed directly to the internal select circuitry regardless of the state of Master Port Address Latch Enable (MALE). | | | | | | Table 3-2: Pin Description Cont'd | Symbol | 95C | 68/18 | 950 | C09 | TVDE | | | | | | | |----------|------|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | - Symbol | PDIP | PLCC | PLCC | TQFP | TYPE | Name and Function | | | | | | | MALE | 27 | 30 | _ | _ | I | Master Port Address Latch Enable: (For CA95C68) In Multiplexed Control Mode ( $C/\overline{\kappa}$ LOW), an active HIGH signal on this pin indicates the presence of valid address and chip select information at the Master Port. This information will be latched internally on the falling edge of MALE. When $C/\overline{\kappa}$ is HIGH (Direct Control Mode), MALE has no affect on DCP operation. | | | | | | | MRD | 26 | 29 | - | _ | Master Port Read: (For CA95C68) This active LOW input is used valid MCS to indicate that data is to be output on the Master Port Master Port Read (MRD) and Master Port Write (MWR) are not mutually exclusive; if both become active simultaneously, the DCP is re ECB Mode and all flags go inactive. | | | | | | | | MWR | 28 | 31 | _ | _ | 1 | Master Port Write: (For CA95C68) This active low input signal indicates to the DCP that valid data is present on MP <sub>7</sub> -MP <sub>0</sub> for an input operation. The rising edge of MWR latches the data into the selected internal register. If MWR and MRD both go LOW simultaneously, the DCP is reset. | | | | | | | MAS | 27 | 30 | - | | 1 | Master Port Address Strobe: (For CA95C18) In Multiplexed Control Mode ( $C\bar{lK}$ HIGH), a LOW on $\bar{lM}$ indicates the presence of a valid chip select signal and address information. This information will be latched on the rising edge of $\bar{lM}$ . In Direct Control Mode, $\bar{lM}$ has no affect on the DCP operation. The DCP will be reset if $\bar{lM}$ and $\bar{lM}$ both go low simultaneously. | | | | | | | MDS | 26 | 29 | _ | - | 1 | Master Port Data Strobe: (For CA95C18) This active low input is used it conjunction with a valid Master Port Chip Select ( MCS) to indicate the valid data is present on the MP <sub>7</sub> -MP <sub>0</sub> bus for an input operation or that dat is to be placed on the Master Port Bus during output. MDS and MAS are mutually exclusive; if they both go active simultaneously, the DCP is reset the ECB mode and all flags go inactive. | | | | | | | MR/w | 28 | 31 | - | - | I | Master Port Read/Write: (For CA95C18) This input signal indicates to the DCP whether the current Master Port operation is a read (HIGH) where data is transferred from the device, or a write (LOW) where data is stored to an internal register. MR/W is not latched internally and must be held stable while MDS is LOW. | | | | | | **■ 6588101 0005202 654 ■** Table 3-2: Pin Description Cont'd | | 95C | 68/18 | 95C09 | | TYPE | Name and Function | | | | | | | |----------------------------------|--------------|--------------|--------------|----------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Symbol | PDIP | PLCC | PLCC | TQFP | ITE | regine und i director. | | | | | | | | MRD -<br>MDS | - | - | 29 | 23 | ı | Master Port Read or Master Port Data Strobe: (For CA95C09) When the OPTION pin is HIGH this input functions as $\overline{\text{MRD}}$ . When the OPTION pin is LOW this input functions as $\overline{\text{MDS}}$ . (See appropriate pin description). | | | | | | | | MALE -<br>MAS | - | - | 30 | 24 | I | Master Port Address Latch Enable or Master Port Address Strobe: (For CA95C09) When the OPTION pin is HIGH this input functions as MALE and when OPTION is LOW it functions as MAS. (See the appropriate pin description). | | | | | | | | MWR –<br>MR/W | _ | - | 31 | 25 | I | Master Port Write or Master Port Read/Write: (For CA95C09) When the OPTION pin is HIGH this input functions as MWR and when OPTION is LOW it functions as MR/W. (See the appropriate pin description). | | | | | | | | MFLG | 15 | 16 | 17 | 11 | 0 | Master Port Flag: This active LOW flag indicates the need for a data transfer into or out of the Master Port during normal ciphering operation. The Master Port will be associated with either the Input or Output Register depending upon the setting of the Control bits in the Mode Register (See Register Description). If data is to be transferred through the Master Port to the Input Register, then MFLG reflects the contents of the Input Register. After any Start command is entered, MFLG will go active (LOW) whenever the Input Register is not full. MFLG is forced HIGH by any command other than a Start. Conversely, if the Master Port is associated with the Output Register, MFLG reflects the contents of the Output Register (except in single port configuration; see Functional Description). Whenever the Output Register is not empty MFLG will be active (LOW). In single port mode of operation, the Master Port flag reflects the contents of the Input Register, while the Slave Port Flag ( SFLG , see below) is associated with the Output Register. | | | | | | | | SP <sub>7</sub> -SP <sub>0</sub> | 36-39<br>5-2 | 40-43<br>6-3 | 40-43<br>6-3 | 34-37<br>44-41 | I/O | Slave Port Bus: This 8 bit bi-directional data bus provides a second input/output interface to the DCP, allowing overlapped input, ciphering and output operations. The tri-state Slave Port will be accessed only when the Mode Register is configured for dual port operation, Slave Port Chip Select (SCS) and Slave Port Data Strobe (SDS) are both LOW and SFLG =0. Data entered or retrieved through this port is the most significant byte in/out first (SP <sub>7</sub> is the most significant bit). | | | | | | | Table 3-2: Pin Description Cont'd | Cumbal | 95C | 68/18 | 95C09 | | | | | | | | |------------------------------------|--------------|---------------|---------------|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Symbol | PDIP | PLCC | PLCC | TQFP | TYPE | Name and Function | | | | | | scs | 30 | 33 | 33 | 27 | I | Slave Port Chip Select: This active LOW signal is logically combined with the Slave Port Data Strobe (\$\overline{SDS}\$) to facilitate Slave Port data transfers in a bus environment. \$\overline{SCS}\$ is not latched internally, and may be tied permanently LOW without impairing Slave Port operation. | | | | | | SDS | 29 | 32 | 32 | 26 | I | Slave Port Data Strobe: This active LOW input, in conjunction with Slave Port Chip Select ( $\overline{SCS}$ ) LOW indicates to the DCP that valid data is on the SP <sub>7</sub> -SP <sub>0</sub> lines for an input operation, or that data is to be driven onto SP <sub>7</sub> -SP <sub>0</sub> lines for output. The direction of data flow is determined by Control bits in the Mode Register. (See Register Description). | | | | | | SFLG | 31 | 34 | 35 | 29 | 0 | Slave Port Flag: This active LOW output indicates the state of either the Input Register or the Output Register, depending on the Mode Register configuration. In single port configuration, \$\overline{\text{FLG}}\$ will go active whenever the Output Register is not empty during normal processing. In dual port configuration, \$\overline{\text{FLG}}\$ will reflect the content of whichever register is associated with the Slave Port. If the Input Register is assigned to the Slave Port, \$\overline{\text{FLG}}\$ will go active whenever the Input Register is not full, once any of the Start commands has been entered; \$\overline{\text{FLG}}\$ will be forced inactive if any other command is entered. Conversely, if the Slave Port is assigned to the Output Register, \$\overline{\text{FLG}}\$ will go active whenever the Output Register is not empty. | | | | | | AUX <sub>7</sub> -AUX <sub>0</sub> | 32-35<br>9-6 | 36-39<br>10-7 | 36-39<br>10-7 | 30-33<br>4-1 | I/O | <b>Auxiliary Port Bus:</b> In Multiplexed Control Mode ( $C/\overline{k}$ LOW), these eight lines form a key byte input port which may be used to enter the Master and Session Keys. The Master Key can only be entered through this port but Session Keys may alternatively be entered via the Master Port. AUX $_0$ is the low-order bit, and is considered to be the Parity bit in key bytes. The most significant byte of the key is entered first. When the DCP is operated in Direct Control Mode, ( $C/\overline{k}$ HIGH), the Auxiliary Port's key-entry function is disabled and five of the eight lines become direct control/status lines for interfacing to high-speed microprogrammed controllers. In this case, AUX $_0$ , AUX $_1$ and AUX $_4$ have no function (they may be tied HIGH) and the other pins are defined on the following pages. | | | | | | AUX <sub>5</sub> –S/S | 34 | 38 | 38 | 32 | I | <b>Start/Stop:</b> In Direct Control Mode, when this pin goes LOW (Stop) the DCP will follow the sequence that would normally occur when a Stop Command is entered. Conversely, when this input goes HIGH, a sequence equivalent to a Start Encryption or Start Decryption command will be followed. At the time AUX $_5$ -S/ $\bar{s}$ goes HIGH, the level on AUX $_6$ -E/ $\bar{b}$ selects either the Start Encryption or Start Decryption ciphering operation. | | | | | | AUX <sub>6</sub> –E/̄D | 33 | 37 | 37 | 31 | 1 | <b>Encrypt/Decrypt:</b> In Direct Control Mode, this input specifies whether the ciphering algorithm is to encrypt (E/ $\overline{D}$ HIGH) or decrypt (E/ $\overline{D}$ LOW) when AUX $_5$ -S/ $\overline{S}$ goes HIGH to initiate a normal data ciphering operation. When AUX $_7$ -K/ $\overline{D}$ goes HIGH, initiating entry of key bytes, the level on AUX $_6$ -E/ $\overline{D}$ specifies whether the bytes are to be written into the E Key Register (E/ $\overline{D}$ HIGH) or the D Key Register (E/ $\overline{D}$ LOW). The AUX $_6$ -E/ $\overline{D}$ input is not latched internally, and must be held constant whenever one or more of AUX $_5$ -S/ $\overline{S}$ , AUX $_7$ -K/ $\overline{D}$ , AUX $_2$ -BS $\overline{S}$ , or AUX $_3$ - $\overline{C}$ P are active. Corrupted data in the internal registers will occur if the proper level on AUX $_6$ -E/ $\overline{D}$ is not maintained during loading or ciphering operations. | | | | | ■ 6588101 0005204 427 **■** Table 3-2: Pin Description Cont'd | 0 | 95C | 68/18 | 95C09 | | TYPE | Name and Function | | | |---------------------------|------|-------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Symbol | PDIP | PLCC | PLCC | TQFP | | Hume and Farious | | | | AUX <sub>7</sub> –K/D | 32 | 36 | 36 | 30 | I Key/Data: In Direct Control Mode, when this signal goes HIGH, the initiates a key-data input sequence as if a Clear E (or D) Key throug Master Port command had been entered. The level on AUX <sub>6</sub> -E/determine whether the subsequently entered clear-key bytes are writte the E Key Register (E/D̄ HIGH) or the D Key Register (E/D̄ LOW). AUX <sub>7</sub> -K/D̄ and AUX <sub>5</sub> -S/S̄ are mutually exclusive control lines. When goes active HIGH, the other must be inactive (LOW) and remain in this until the first signal returns to an inactive state. Whenever a transition on C/k̄ (switching between Direct Control Mode and Multiplexed C Mode) both of these signals must be inactive (LOW). | | | | | AUX <sub>2</sub> –<br>BSY | 8 | 9 | 9 | 3 | 0 | Busy: In Direct Control Mode, this active LOW status output gives a hardware indication that the ciphering algorithm is in operation. This status line is driven by the BSY bit in the Status Register, such that when the BSY bit is "1" (active), AUX <sub>2</sub> -BSY is LOW. | | | | AUX <sub>3</sub> – CP | 9 | 10 | 10 | 4 | 0 | Command Pending: In Direct Control Mode, this active LOW status output gives a hardware indication that the DCP is ready to accept input of key bytes following a LOW-to-HIGH transition on $AUX_T$ - $K/\overline{D}$ . This signal line is driven by the $\overline{CP}$ bit in the Status Register, such that when the $\overline{CP}$ bit is "1" (active), $AUX_3$ - $\overline{CP}$ is LOW. | | | | ASTB | 11 | 12 | 13 | 7 | 1 | <b>Auxiliary Port Strobe</b> : The rising edge of $\overline{\text{ASTB}}$ strobes the key-data on pins $\text{AUX}_7\text{-}\text{AUX}_0$ into the appropriate internal key register in Multiplexed Control Mode ( $C/\overline{k}$ LOW). This input is ignored unless $\overline{\text{AFLG}}$ and $C/\overline{k}$ are both LOW. One byte of key-data (most significant byte first) is entered on each $\overline{\text{ASTB}}$ . | | | Table 3-2: Pin Description Cont'd | Symbol | 95C | 68/18 | 95C09 | | | | | | | | |-----------------|-------|-------|--------------------|--------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | PDIP | PLCC | PLCC TQFP | | TYPE | Name and Function | | | | | | AFLG | 10 | 11 | 11 | 5 | 0 | Auxiliary Port Flag: This active LOW output signal indicates that the DCP is expecting key-data to be entered on the Auxiliary Port Bus. This can occur only when $C/\overline{\kappa}$ is LOW (Multiplexed Control Mode) and a Load Key Through AUX Port command has been entered. $\overline{\text{AFLG}}$ will remain active (LOW) during input of all eight bytes, and will go inactive with the falling edge of the eighth $\overline{\text{ASTB}}$ . | | | | | | PAR | 12 | 13 | 14 | 8 | 0 | Parity: The DCP checks all key bytes for correct (odd) parity as they entered through either the Master Port (Multiplexed or Direct Control Moor the Auxiliary Port (Multiplexed Control Mode only). If any key byte conteven parity, the PAR bit in the Status Register is set to a "1" and PAR gactive (LOW). (See Parity Checking of Keys.). The Parity bit is the listing significant bit of the key byte. | | | | | | OPTION | | _ | 1 | 39 | 1 | Option: (For CA95C09) This input allows the user to configure the Master Port Control interface to function as either a CA95C68 or a CA95C18. When the OPTION pin is tied to $V_{\rm DD}$ , the device will function with the interface of a CA95C68. Conversely, tying the OPTION pin to $V_{\rm SS}$ will cause the DCP to function as a CA95C18. This OPTION pin must be tied to either $V_{\rm SS}$ or $V_{\rm DD}$ , or erratic operation of the device will occur. The CA95C09 DCP will perform identically to the CA95C68 or the CA95C18 (depending on the OPTION pin) with the only difference being the order of the signal names on the device package. | | | | | | V <sub>DD</sub> | 40 | 44 | 44,22 | 16,<br>38 | PWR | Power Supply: +5 Volts. | | | | | | V <sub>SS</sub> | 1, 20 | 1, 22 | 2, 12<br>23,<br>34 | 6, 17<br>28,<br>40 | GND | Ground: 0 Volts. | | | | | Table 3-3a : AC Characteristics (T<sub>A</sub> + 0 to 70° C, V<sub>DD</sub> = +5.0V $\pm$ 5%, V<sub>SS</sub> = 0V) | Number | Description | | | | | | | | | | |-----------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | Clock | | | | | | | | | | | | t <sub>1</sub> | CLK Width HIGH (t <sub>WH</sub> ) | | | | | | | | | | | t <sub>2</sub> | CLK Width LOW (t <sub>WL</sub> ) | | | | | | | | | | | t <sub>3</sub> | CLK HIGH to Next Clock HIGH (Clock Cycle, t <sub>C</sub> ) | | | | | | | | | | | Reset | | | | | | | | | | | | t <sub>5</sub> | MRD • MWR LOW to MRD • MWR HIGH (Reset Pulse Width), (Note 11) | | | | | | | | | | | Direct Contr | ol Mode | | | | | | | | | | | tg | S/s LOW to C/K HIGH (Setup), (Note 11) | | | | | | | | | | | t <sub>10</sub> | K/\overline{\text{D}} LOW to C/\overline{K} HIGH (Setup), (Note 11) | | | | | | | | | | | t <sub>11</sub> | C/k HIGH to S/s HIGH (Note 11) | | | | | | | | | | | t <sub>12</sub> | C/k HIGH to K/b HIGH (Note 11) | | | | | | | | | | | t <sub>13</sub> | S/s LOW to E/o INVALID (Hold) | | | | | | | | | | | t <sub>14</sub> | E/\(\bar{D}\) SETUP to K/\(\bar{D}\) HIGH (Setup) (Note 11) | | | | | | | | | | | t <sub>15</sub> | K/\(\overline{D}\) HIGH • CLK \(\psi\) to \(\overline{CP}\) LOW | | | | | | | | | | | t <sub>17</sub> | К/Б LOW to E/Б INVALID (Hold) | | | | | | | | | | | t <sub>18</sub> | К/Б LOW to S/S HIGH | | | | | | | | | | | t <sub>19</sub> | S/s LOW to K/o HIGH | | | | | | | | | | | t <sub>20</sub> | E/\(\bar{D}\) SETUP to S/\(\bar{S}\) HIGH (Setup), (Note 11) | | | | | | | | | | | t <sub>21</sub> | S/s HIGH • CLK ↓ to MFLG ( SFLG ) LOW (Port Input Flag) | | | | | | | | | | | t <sub>23</sub> | S/s LOW to E/D INVALID (Hold) (Note 11) | | | | | | | | | | | t <sub>24</sub> | CLK LOW to BSY LOW | | | | | | | | | | | t <sub>25</sub> | CLK LOW to BSY HIGH | | | | | | | | | | | t <sub>27</sub> | ALGORITHM completed • CLK ↓ to MFLG (SFLG) LOW (Port Output Flag) | | | | | | | | | | | t <sub>28</sub> | S/s LOW • CLK ↓ to MFLG (SFLG) HIGH (Port Input Flag), (Note 3) | | | | | | | | | | | t <sub>29</sub> | CLK ↓ to K/D HIGH (Notes 11, 16) | | | | | | | | | | | t <sub>30</sub> | CLK ↓ to S/s HIGH (Notes 11, 16) | | | | | | | | | | | Multiplexed | Control Mode - Master Port | | | | | | | | | | | t <sub>32</sub> | For CA95C68: MALE Width (HIGH) For CA95C18: MAS Width (LOW) | | | | | | | | | | | t <sub>34</sub> | For CA95C68: MCS LOW to MALE LOW (Setup) For CA95C18: MCS LOW to MAS HIGH (Setup) | | | | | | | | | | | t <sub>35</sub> | For CA95C68: MALE LOW to MCS HIGH (Hold) For CA95C18: MAS HIGH to MCS HIGH (Hold) | | | | | | | | | | | t <sub>36</sub> | For CA95C68: Address INVALID to MALE LOW (Address Setup Time) For CA95C18: Address INVALID to MAS HIGH (Address Setup Time) | | | | | | | | | | | t <sub>37</sub> | For CA95C68: MALE LOW to Address INVALID (Address Hold Time) For CA95C18: MAS HIGH to Address INVALID (Address Hold Time) | | | | | | | | | | 3-34 **■ 6588101 0005207 136 ■** Table 3-3b : AC Characteristics (T\_A = 0 to 70°C, $V_{DD}$ = +5.0V $\pm$ 5%, $V_{SS}$ = 0V | Number | 5 MH2 | z Limits | 10 MH | z Limits | 16 MH | z Limits | 20 MH | z Limits | 25 MH | z Limits | 33 MH | z Limits | | |-----------------|-----------------|--------------------|-----------------|--------------------|-----------------|--------------------|----------------------------------------------|--------------------|-----------------|--------------------|-----------------|--------------------|----------| | | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | Clock | | | 1 | | -1 | | | | l | 1 | | <u> </u> | <u> </u> | | t <sub>1</sub> | 85 | _ | 40 | - | 27 | ]_ | 20 | _ | 17 | - | 13 | <b> </b> - | ns | | t <sub>2</sub> | 85 | _ | 40 | _ | 27 | - | 20 | 1 | 17 | _ | 13 | _ | ns | | t <sub>3</sub> | 200 | - | 100 | | 62.5 | T- | 50 | _ | 40 | _ | 30 | 1- | ns | | Reset | | | | | | · | | | <del></del> | | L | | L | | t <sub>5</sub> | 3t <sub>C</sub> | - | 3t <sub>C</sub> | _ | 3t <sub>C</sub> | - | 3t <sub>C</sub> | _ | 3t <sub>C</sub> | <u> </u> | 3t <sub>C</sub> | - | ns | | Direct Co | ntrol Mo | de | | | | -1 | · | | | | | | L | | t <sub>9</sub> | t <sub>C</sub> | | t <sub>C</sub> | - | t <sub>C</sub> | - | t <sub>C</sub> | _ | t <sub>C</sub> | <b> </b> - | t <sub>C</sub> | T- | ns | | t <sub>10</sub> | t <sub>C</sub> | _ | t <sub>C</sub> | _ | t <sub>C</sub> | - | t <sub>C</sub> | - | t <sub>C</sub> | 1- | t <sub>C</sub> | † <u> </u> | ns | | t <sub>11</sub> | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | 2t <sub>C</sub> | _ | 2t <sub>C</sub> | - | ns | | t <sub>12</sub> | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | 2t <sub>C</sub> | - | ns | | t <sub>13</sub> | 40 | | 20 | - | 15 | - | 10 | _ | 5 | - | 3 | | ns | | t <sub>14</sub> | t <sub>C</sub> | - | tc | - | t <sub>C</sub> | - | t <sub>C</sub> | - | t <sub>C</sub> | - | tc | _ | ns | | t <sub>15</sub> | - | 75 | - | 60 | - | 45 | _ | 40 | _ | 30 | _ | 10 | ns | | t <sub>17</sub> | 40 | Ī | 20 | - | 15 | - | 10 | | 5 | _ | 3 | - | ns | | t <sub>18</sub> | 40 | Ī- | 20 | - | 15 | _ | 10 | _ | 5 | | 3 | | ns | | t <sub>19</sub> | 40 | - | 20 | - | 15 | | 10 | - | 5 | <u> </u> | 3 | - | ns | | t <sub>20</sub> | 40 | - | 20 | - | 15 | <u> </u> | 10 | † | 5 | <u> </u> | 3 | | ns | | t <sub>21</sub> | - | 75 | - | 60 | _ | 45 | | 40 | _ | 30 | _ | 10 | ns | | t <sub>23</sub> | 40 | _ | 20 | _ | 15 | | 10 | - | 5 | - | 3 | - | ns | | t <sub>24</sub> | _ | 75 | _ | 60 | _ | 45 | _ | 40 | - | 30 | _ | 10 | ns | | t <sub>25</sub> | _ | 100 | _ | 75 | _ | 60 | | 50 | | 40 | | 10 | ns | | t <sub>27</sub> | _ | 75 | _ | 60 | | 45 | _ | 40 | _ | 30 | | 10 | ns | | t <sub>28</sub> | _ | 75 | _ | 60 | <b> </b> | 45 | | 40 | | 30 | - | 10 | ns | | t <sub>29</sub> | 3 | t <sub>C</sub> -25 | 3 | t <sub>C</sub> -25 | 3 | t <sub>C</sub> -25 | 1 | t <sub>C</sub> -20 | 1 | t <sub>C</sub> -20 | 1 | t <sub>C</sub> -13 | ns | | t <sub>30</sub> | 3 | t <sub>C</sub> -25 | 3 | t <sub>C</sub> -25 | 3 | t <sub>C</sub> -25 | 1 | t <sub>C</sub> -20 | 1 | t <sub>C</sub> -20 | 1 | | ns | | Multiplexe | d Contr | | Master | | | 1.0 | <u>. </u> | 1.0 20 | L | 10-20 | <u> </u> | t <sub>C</sub> -15 | ris | | t <sub>32</sub> | 75 | _ | 50 | _ | 30 | _ | 20 | 1_ | 12 | 1_ | 6 | T_ | ns | | _ | 75 | _ | 50 | _ | 30 | - | 20 | - | 12 | _ | 6 | _ | ns | | t <sub>34</sub> | 25 | _ | 15 | _ | 5 | _ | 0 | 1- | 0 | _ | 0 | - | ns | | | 25 | - | 15 | | 5 | | 0 | | 0 | | 0 | _ | ns | | t <sub>35</sub> | 35<br>35 | - | 30 | - | 20 | - | 15 | - | 10 | - | 6 | - | ns | | • | 35 | - | 30 | - | 20 | - | 15 | | 10 | - | 6 | - | ns | | t <sub>36</sub> | 35<br>35 | - | 30<br>30 | _ | 20<br>20 | _ | 15<br>15 | _ | 10 | - | 5 | - | ns | | t <sub>37</sub> | 35 | _ | 30 | | 20 | | | | 10 | <del> -</del> | 5 | <del> -</del> | ns | | u, | 35 | _ | 30 | _ | 20 | - | 15<br>15 | _ | 15<br>15 | _ | 8<br>8 | _ | ns<br>ns | ■ 6588101 0005208 072 **■** Table 3-3a (con't): AC Characteristics ( $T_A$ + 0 to 70° C, $V_{DD}$ = +5.0V $\pm$ 5%, $V_{SS}$ = 0V) | Number | Description | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Master/Slave | e Port Read/Write | | <b>t</b> 40 | For CA95C68: MCS LOW to MRD, MWR LOW (Select Setup), (Note 4) For CA95C18: MCS LOW to MDS LOW (Select Setup), (Note 4) For CA95C68/18: SCS LOW to SDS LOW (Select Setup) | | <b>t</b> 41 | For CA95C68: MRD, MWR HIGH to MCS HIGH (Select Hold), (Note 4) For CA95C18: MDS HIGH to MCS HIGH (Select Hold), (Note 4) For CA95C68/18: SDS HIGH to SCS HIGH (Select Hold) | | t <sub>42</sub> | MR/w VALID to MDS LOW (Setup) | | t <sub>43</sub> | MDS HIGH to MR√W INVALID (Hold) | | t <sub>44</sub> | For CA95C68: MRW LOW to MRW HIGH (Width-Write) For CA95C68: MRD, LOW to MRD HIGH (Width-Read) For CA95C18: MDS LOW to MDS HIGH (Width-Write, Read) For CA95C68/18: SDS LOW to SDS HIGH (Read, Write) | | t <sub>45</sub> | For CA95C68: CLK LOW to MWR HIGH (Notes 11,16) For CA95C68: CLK LOW to MRD HIGH (Notes 11, 16) For CA95C18: CLK LOW to MDS HIGH (Notes 11, 16) For CA95C68/18: CLK LOW to SDS HIGH (writes to the slave port) (Notes 11, 16) For CA95C68/18: CLK LOW to SDS HIGH (reads from the slave port) (Notes 11, 16) | | t <sub>46</sub> | For CA95C68: MRD, MWR HIGH to MRD, MWR LOW (Data Strobe Recovery Time) For CA95C18: MDS HIGH to MDS LOW (Data Strobe Recovery Time) For CA95C68/18: SDS HIGH to SDS LOW (Data Strobe Recovery Time) | | t <sub>47</sub> | For CA95C68: Write Data VALID to MWR (SDS) HIGH (Write Setup Time) For CA95C18: Write Data VALID to MDS (SDS) HIGH (Write Setup Time) | | t <sub>48</sub> | For CA95C68: MWR HIGH to Write Data INVALID (Hold Time) For CA95C18: MDS HIGH to Write Data INVALID (Hold Time) For CA95C68/18: SDS HIGH to Write Data INVALID (Hold Time) | | t <sub>49</sub> | For CA95C68: MRD LOW to Read Data VALID (Read Access Time) (Note 15) For CA95C18: MDS LOW to Read Data VALID (Read Access Time) (Note 15) For CA95C68/18: SDS LOW to Read Data VALID (Read Access Time) (Note 15) | | t <sub>50</sub> | For CA95C68: MRD (SDS) HIGH to Read Data INVALID (Hold Time) For CA95C18: MDS (SDS) HIGH to Read Data INVALID (Hold Time) | | t <sub>51</sub> | For CA95C68: MRD , MWR , (SDS) LOW • CLK ↓ to MFLG (SFLG) HIGH (Last Strobe), (Note 5) For CA95C18: MDS , (SDS) LOW • CLK ↓ to MFLG (SFLG) HIGH (Last Strobe), (Note 5) | | t <sub>52</sub> | For CA95C68: MWR HIGH • CLK ↓ to CP HIGH (Note 4,11), (Last Strobe-Key Load) For CA95C18: MDS HIGH • CLK ↓ to CP HIGH (Note 4,11), (Last Strobe-Key Load) | | t <sub>53</sub> | For CA95C68: MRD , MWR (SDS) HIGH to S/S LOW (Hold Time) (Note 11) For CA95C18: MDS (SDS) HIGH to S/S LOW (Hold Time) (Note 11) | | t <sub>54</sub> | For CA95C68: MWR HIGH • CLK ↓ to PAR VALID (Key Write) For CA95C18: MDS HIGH • CLK ↓ to PAR VALID (Key Write) | | t <sub>55</sub> | For CA95C68: S/S HIGH to MRD , MWR , (SDS) LOW (Setup Time) (Note 11) For CA95C18: S/S HIGH to MDS , (SDS) LOW (Setup Time) (Note 11) | | t <sub>57</sub> | MRD , MWR HIGH to MALE HIGH MDS HIGH to MAS LOW | | t <sub>58</sub> | MALE LOW to MRD , MWR LOW MAS HIGH to MDS LOW | en la companya de Table 3-3b (con't): AC Characteristics ( $T_A = 0$ to $70^{\circ}$ C, $V_{DD} = +5.0$ V $\pm 5\%$ , $V_{SS} = 0$ V) | Number | 5 MHz | Limits | 10 MHz | Limits | 16 MH | Limits | 20 MH | z Limits | 25 MH: | z Limits | 33 MH | z Limits | Unit | |-----------------|----------------|--------------------|--------|--------------------|----------------|--------------------|----------------|--------------------|----------------|--------------------|----------------|--------------------|------| | | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | Master/SI | ave Port | Read/Wr | ite | l | 1 | <u> </u> | | | | | <u> </u> | L | L | | t <sub>40</sub> | 30 | _ | 20 | _ | 10 | I - | 5 | | 0 | I | 0 | T_ | ns | | | 30 | _ | 20 | _ | 10 | _ | 5 | _ | 0 | _ | 0 | _ | ns | | | 30 | - | 20 | | 10 | - | 5 | - | 0 | _ | 0 | _ | ns | | t <sub>41</sub> | 35 | - | 30 | _ | 20 | _ | 10 | _ | 5 | _ | 3 | _ | ns | | | 35 | - | 30 | - | 20 | - | 10 | - | 5 | - | 3 | - | ns | | | 35 | - | 30 | - | 20 | - | 10 | _ | 5 | - | 3 | _ | ns | | t <sub>42</sub> | 35 | | 30 | | 20 | - | 15 | | 10 | - | 3 | - | ns | | t <sub>43</sub> | 35 | - | 30 | - | 20 | - | 15 | _ | 15 | _ | 5 | _ | ns | | t <sub>44</sub> | 140 | _ | 70 | _ | 50 | _ | 35 | _ | 30 | _ | 15 | | ns | | | 140 | - | 70 | - | 50 | - | 35 | _ | 30 | _ | 24 | _ | ns | | | 140 | - | 70 | - | 50 | - | 35 | _ | 30 | _ | 24 | _ | ns | | | 140 | - | 70 | _ | 50 | _ | 35 | - | 30 | - | 19 | - | ns | | t <sub>45</sub> | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -25 | 0 | t <sub>C</sub> -20 | ns | | | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -25 | 0 | t <sub>C</sub> -15 | ns | | | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -25 | 0 | t <sub>C</sub> -20 | ns | | | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -20 | 2 | t <sub>C</sub> -20 | 1 | t <sub>C</sub> -16 | ns | | | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 5 | t <sub>C</sub> -25 | 2 | t <sub>C</sub> -20 | 2 | t <sub>C</sub> -20 | 1 | t <sub>C</sub> -8 | ns | | t <sub>46</sub> | 30 | - | 20 | - | 15 | - | 10 | _ | 10 | _ | 10 | _ | ns | | | 30 | - | 20 | - | 15 | - | 10 | _ | 10 | _ | 10 | _ | ns | | | 30 | | 20 | - | 15 | | 10 | _ | 10 | _ | 10 | _ | ns | | t <sub>47</sub> | 60 | - | 30 | - | 20 | - | 15 | - | 10 | _ | 5 | _ | ns | | | 60 | _ | 30 | - | 20 | _ | 15 | _ | 10 | | 5 | - | ns | | t <sub>48</sub> | 20 | - | 20 | - | 15 | - | 15 | - | 10 | _ | 3 | _ | ns | | | 20 | - | 20 | - | 15 | - | 15 | - | 10 | - | 3 | - | ns | | | 20 | | 20 | - | 15 | | 15 | - | 10 | _ | 3 | _ | ns | | t <sub>49</sub> | - | 60 | - | 50 | - | 45 | _ | 35 | _ | 35 | - | 27 | ns | | | - | 60 | - | 50 | - | 45 | - | 35 | - | 35 | _ | 27 | ns | | | - | 60 | - | 50 | - | 45 | _ | 35 | - | 35 | - | 23 | ns | | t <sub>50</sub> | 5 | 20 | 5 | 20 | 5 | 20 | 5 | 20 | 5 | 20 | 5 | 20 | ns | | _ | 5 | 20 | 5 | 20 | 5 | 20 | 5 | 20 | 5 | 20 | 5 | 20 | ns | | t <sub>51</sub> | - | 75 | - | 50 | _ | 40 | _ | 35 | _ | 30 | _ | 15 | ns | | | _ | 75 | - | 50 | - | 40 | - | 35 | - | 30 | - | 15 | ns | | t <sub>52</sub> | _ | 75 | _ | 50 | _ | 40 | _ | 35 | _ | 30 | _ | 15 | ns | | | <u> </u> | 75 | - | 50 | - | 40 | - | 35 | _ | 30 | _ | 15 | ns | | t <sub>53</sub> | t <sub>C</sub> | _ | tc | _ | t <sub>C</sub> | _ | tc | _ | t <sub>C</sub> | _ | t <sub>C</sub> | _ | ns | | | t <sub>C</sub> | - | tc | _ | tc | - | t <sub>C</sub> | - | t <sub>C</sub> | - | tc | _ | ns | | t <sub>54</sub> | - | 75 | _ | 50 | _ | 40 | _ | 35 | _ | 30 | <del> </del> | 20 | ns | | | _ | 75 | _ | 50 | - | 40 | _ | 35 | _ | 30 | _ | 20 | ns | | t <sub>55</sub> | t <sub>C</sub> | _ | tc | _ | tc | _ | t <sub>C</sub> | _ | t <sub>C</sub> | _ | t <sub>C</sub> | - | ns | | t <sub>57</sub> | 140 | <u> </u> | 70 | _ | 30 | | 20 | _ | 10 | | 15 | | | | J. | 140 | | 70 | | 30 | | 20 | | 10 | [ | 15 | - | ns | | t <sub>58</sub> | 80 | 1_ | 40 | | 20 | _ | 20 | - | - | _ | <del></del> | | l | | -30 | 80 | | 40 | | 20 | - | 20 | - | 20<br>20 | - | 10 | - | ns | | | 1,00 | | 1 0 | | 120 | L | 1 Z V | L | 20 | | 10 | <u></u> | | 3-37 **■ 6588101 0005210 720 ■** Table 3-3a (con't): AC Characteristics (T<sub>A</sub> + 0 to 70° C, V<sub>DD</sub> = +5.0V $\pm$ 5%, V<sub>SS</sub> = 0V) | Number | Description | | | | | | | | | | |--------------------------|--------------------------------------------------|--|--|--|--|--|--|--|--|--| | Auxiliary Port Key Entry | | | | | | | | | | | | t <sub>61</sub> | ASTB LOW to ASTB HIGH (Width) | | | | | | | | | | | t <sub>62</sub> | CLK LOW to ASTB HIGH (Notes 11, 16) | | | | | | | | | | | t <sub>63</sub> | ASTB HIGH to Next ASTB LOW (Recovery Time) | | | | | | | | | | | t <sub>64</sub> | Write-Data VALID to ASTB HIGH (Data Setup Time) | | | | | | | | | | | t <sub>65</sub> | ASTB HIGH to Write-Data INVALID (Data Hold Time) | | | | | | | | | | | t <sub>66</sub> | ASTB HIGH • CLK ↓ to PAR VALID | | | | | | | | | | | t <sub>67</sub> | ASTB LOW • CLK ↓ to AFLG HIGH (Last Strobe) | | | | | | | | | | Table 3-3b (con't): AC Characteristics ( $T_A = 0$ to $70^{\circ}$ C, $V_{DD} = +5.0$ V $\pm 5\%$ , $V_{SS} = 0$ V) | Number | 5 MHz Limits | | 10 MHz Limits | | 16 MHz Limits | | 20 MHz Limits | | 25 MHz Limits | | 33 MHz Limits | | | |-----------------|--------------|--------------------|---------------|--------------------|---------------|--------------------|---------------|--------------------|---------------|--------------------|---------------|--------------------|------| | | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | Auxiliary | Port Key | Entry | | | | -1 | | -L | | 1 | | | | | t <sub>61</sub> | 80 | - | 40 | - | 30 | _ | 20 | T- | 20 | - | 15 | - | ns | | t <sub>62</sub> | 5 | t <sub>C</sub> -20 | 5 | t <sub>C</sub> -20 | 5 | t <sub>C</sub> -20 | 5 | t <sub>C</sub> -20 | 5 | t <sub>C</sub> -20 | -12 | t <sub>C</sub> -20 | ns | | t <sub>63</sub> | 30 | - | 20 | - | 15 | _ | 10 | _ | 10 | - | 8 | 1- | ns | | t <sub>64</sub> | 40 | - | 20 | _ | 15 | _ | 10 | _ | 5 | - | 3 | - | ns | | t <sub>65</sub> | 20 | - | 20 | - | 15 | - | 15 | 1- | 5 | - | 3 | - | ns | | t <sub>66</sub> | - | 75 | - | 50 | - | 40 | - | 35 | - | 30 | - | 25 | ns | | t <sub>67</sub> | - | 75 | _ | 50 | _ | 40 | - | 35 | - | 30 | - | 20 | ns | #### Notes: - All input transition times assumed <5ns, except clock which is <3ns (for 25 and 33MHz timing).</li> - The appropriate input flag (MFLG, SFLG, AFLG) goes active LOW after 1 CLK ↓ +30ns from the writing of a "Load" or "Start" command. - 3) When s/s goes inactive (LOW) in Direct Control Mode, the flag associated with the Input Port will turn off. - 4) Direct Control Mode only ( MCS must be LOW for one falling edge during a read/write cycle). - 5) In Cipher Feedback, the Port Flag ( MFLG or SFLG ) will go inactive following the leading edge of the first data strobe ( MRD, MWR, MDS, or SDS), in all other modes and operations, the flags go inactive on the eighth data strobe. - 6) Do not change κ/ō until ⟨¬P⟩ is inactive (HIGH). - 7) Do not change E/o until MFLG (SFLG) is inactive (HIGH). - 8) In Cipher Feedback, BSY must be inactive (HIGH) before s/s goes inactive (LOW). - 9) AFLG must go active (LOW) before ASTB goes active (LOW). - 10) t<sub>WL</sub> is the clock width LOW (number t<sub>2</sub>). - 11) t<sub>C</sub> is the clock cycle time (number t<sub>3</sub>). - All output timing specifications reflect the following: High output >1.5V, Low output <1.5V.</li> - 13) All output timings assume $C_{LOAD} = 50 pF$ . - 14) When operating in Direct Control Mode, you must ensure that the κ̄̄̄̄ input is valid one clock cycle before you begin to load the key, or perform any data operations with the device. - 15) Timing numbers for parameter t<sub>49</sub> with C<sub>LOAD</sub> = 25 pF are shown below for a 33 MHz device: For CA95C68: MRD LOW to Read Data VALID (Read Access Time): 23.5 ns For CA95C18: MDS LOW to Read Data VALID (Read Access Time): 23.5 ns For CA95C68/18: SDS LOW to Read Data VALID (Read Access Time); 19 ns 16) These input signals must be externally synchronized to the CA95C09's clock. As a result, there is less timing margin as the frequency increases (ie: @ 33 MHz). Designers should review these timing parameters early on in the design cycle to ensure that their interface logic to the CA95C09/18/68 will be able to meet these timing requirements. **Tundra Semiconductor Corporation** 3-40 Figure 3-8: CA95C68/18 Clock and Reset Timing Figure 3-9: CA95C68/18 Control and Status Signals Timing (Direct Control Mode) Tundra Semiconductor Corporation 5588101 0005213 437 Figure 3-10: CA95C68 Master Port, Multiplexed Control Mode Read/Write Figure 3-11: CA95C68 Master (Slave) Port Read/Write Timing **588101 0005214 376** Figure 3-12: CA95C68/18 Auxiliary - Port Key Entry Timing Figure 3-13: CA95C18 Master Port, Multiplexed Control Mode, Read/Write Timing 3-42 **■ 6588101 0005215 202 ■** <sup>1.</sup> These Signals are only used for Read/Write timing in Direct Control Mode of operation. Figure 3-14: CA95C18 Master (Slave) Port Read/Write Timing Table 3-4 : DC Characteristics (T<sub>A</sub> = 0 to 70°C, $V_{DD}$ = +5.0V $\pm$ 5%, $V_{SS}$ = 0V) | Comple at | Parameter | Test | L | Units | | |-------------------|----------------------------------------|----------------------------------------------------------------------------------------------|----------|-----------------------|--------| | Symbol | Parameter | Conditions | Min | Max | Units | | I <sub>IL</sub> | Input leakage current | $0 \text{ V} \leq \text{V}_{\text{IN}} \leq \text{V}_{\text{DD}}$ | -1.0 | +1.0 | μА | | loz | Output leakage current | $0 \text{ V} \leq V_{IN} \leq V_{DD}$ | -10.0 | +10.0 | μΑ | | I <sub>DDOP</sub> | Operating supply current | _ | _ | 3.0 | mA/MHz | | I <sub>DDSB</sub> | Standby supply current | V <sub>IN</sub> =V <sub>DD</sub> or V <sub>SS</sub><br>V <sub>DD</sub> = 5.50V, Outputs open | - | 100.0 | μΑ | | V <sub>IL</sub> | Input low voltage | Note 2 | -0.3 | 0.8 | V | | V <sub>IH</sub> | Input high voltage | Note 2 | 2.0 | V <sub>DD</sub> + 0.3 | V | | V <sub>TL</sub> | Schmitt trigger input low voltage | Note 1 | -0.3 | 0.7 | V | | V <sub>TH</sub> | Schmitt trigger input high voltage | Note 1 | 2.1 | V <sub>DD</sub> + 0.3 | V | | V <sub>HY</sub> | Schmitt trigger hysteresis | Note 1 | 0.4 | _ | V | | V <sub>OL</sub> | Output low voltage | I <sub>OL</sub> = 4.0mA | _ | 0.4 | V | | V <sub>OH</sub> | Output high voltage | I <sub>OH</sub> = -4.0mA | 2.4 | - | V | | C <sub>IN</sub> | Maximum input capacitance for any inpu | t or bidirectional pin. | in. – 10 | | | #### Note: 1) Applies to the following inputs: For CA95C68: CLK, $c/\bar{\kappa}$ , $\overline{MCS}$ , $\overline{MRD}$ , $\overline{MWR}$ , MALE, $\overline{SCS}$ , $\overline{SDS}$ , $\overline{ASTB}$ . For CA95C18: CLK, C/K, MCS, MAS, MDS, MR/W, SCS, SDS, ASTB. For CA95C09: CLK, DCM, MCS, MRD \_ MDS, MALE\_MAS, MWR \_MRW, SCS, SDS, ASTB, OPTION. 2) Applies to the following inputs: MP<sub>7-0</sub>, SP<sub>7-0</sub>, AUX<sub>7-0</sub>. Table 3-5: Recommended Operating Conditions | DC Supply Voltage (V <sub>DD</sub> ) | +4.5V to +5.5V | |-----------------------------------------------------------|----------------| | Power Dissipation (P <sub>DD</sub> ), (Note 1) | 0.5 W | | Ambient Operating Temperature (T <sub>A</sub> Commercial) | 0 to 70° C | #### Note: The power dissipation figure is based on typical internal logic dissipation plus the worst case set of outputs simultaneously active with maximum rated loads. **Table 3-6: Absolute Maximum Ratings** | DC Supply Voltage (V <sub>DD</sub> ) | -0.3 to +7.0V | |--------------------------------------------------|----------------| | Input Voltage (V <sub>IN</sub> ) | -0.3 to +7.0V | | DC Input Current (I <sub>IN</sub> ) | -10 to +10 mA | | Storage Temperature, plastic (T <sub>STG</sub> ) | -65° to +150°C | Stresses beyond those listed above may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. 3-44 **Tundra Semiconductor Corporation** 🖿 6588101 0005217 085 🖷 . #### **FUNCTIONAL DESCRIPTION** The design of the DCP, as shown in Figure 3-1 is optimized for high data throughput. The cryptography key bytes can be written through both the Auxiliary and Master Ports. Three 56-bit, write-only key registers are provided for the Master (M) Key, the Encryption (E) Key and the Decryption (D) Key. Parity checking is provided on each incoming key byte. Two 64-bit registers are provided for the initialization Vectors (IVE and IVD) required for chained (feedback) ciphering modes. Clear and cipher data bytes can be transferred through both the Master and Slave Ports to the Input Register; conversely, data can be transferred from the Output Register to either port. Four 8-bit registers (Mode, Command, Status and Mask) are accessible through the Master Port for interfacing to a host microprocessor. ## Algorithm Processing The DCP's Algorithm Processing Unit (see Figure 3-1) is designed to encrypt and decrypt data according to the National Bureau of Standards Data Encryption Standard (DES), as specified in Federal Information Processing Standards Publication FIPS PUB 46 (1-15-1977). The DES specifies a method for encrypting 64-bit blocks of clear data (plain text) into corresponding 64-bit blocks of cipher text. The DCP offers four ciphering methods: Electronic Code Book (ECB), Cipher Block Chaining (CBC), one (CFB-1) and eight bit Cipher Feedback (CFB-8). Electronic Code Block (ECB) is a straightforward implementation of the DES algorithm; 64 bits of clear data in, 64 bits of cipher text out, with no cryptographic dependence between blocks. Cipher Block Chaining (CBC) also operates on blocks of 64 bits, but includes a feedback step which chains consecutive blocks so that repetitive data in the plain text (such as ASCII blanks) does not yield identical cipher text. CBC also provides an error extension characteristic which protects against fraudulent data insertions and deletions. Cipher Feedback is an additive stream cipher method in which the DES generates a pseudo random binary stream which is then exclusive-ORed with the clear text to form the cipher text. The cipher text is then fed back to form a portion of the next DES input block. The DCP implements both 1-bit and 8-bit cipher feedback which is useful for low speed bit and byte oriented serial communications. # **Multiple Key Registers** The DCP provides the necessary registers to implement a multiple-key system. In such an arrangement, a single Master Key, stored in the DCP M Key Register, is used only to encrypt session keys for transmission to remote DES equipment, and to decrypt session keys received from such equipment. The M Key Register may only be loaded with plain text through the Auxiliary Port, using the Load Clear M Key command. In addition to the Master Key Register, the DCP contains two Session Key Registers; the E Key Register, used to encrypt clear text, and the D Key Register, used to decrypt cipher text. All three registers are loaded by writing commands through the Master Port (Multiplexed Control Mode) into the Command Register, and then writing the eight bytes of key data to the port when the Command Pending bit = "1" in the Status Register (see Command Description Section). # Operating Modes: Multiplexed Control vs. Direct Control The DCP can be operated in either of two basic interfacing modes, determined by the logic level on the $C/\bar{\kappa}$ input pin. In Multiplexed Control Mode ( $C/\bar{\kappa}$ LOW), the DCP is internally connected to allow a host CPU to directly address six internal (Mode, Command, Status, Mask, Input, Output) registers and thereby control the device by writing and reading these registers. In Multiplexed Control Mode, the Auxiliary Port is also enabled for entering keys. If the logic level of $C/\overline{\kappa}$ is brought HIGH, the DCP enters Direct Control Mode, and the Auxiliary Port pins are converted into direct hardware control or status signals that are capable of instructing the DCP to perform a functionally complete subset of its cipher processing at very high throughputs. This operating mode is especially well suited for ciphering data for high-speed peripheral devices. #### Initialization ı The DCP can be reset in several ways: - 1) By the "Software Reset" command, - 2) By a hardware reset: (CA95C68) Assertion of MRD and MWR LOW simultaneously for 3 clock cycles, (CA95C18) Assertion of $\overline{\text{MAS}}$ and $\overline{\text{MDS}}$ LOW simultaneously for 1 clock cycle. - 3) By writing to the Mode Register, - 4) By aborting any command. **Tundra Semiconductor Corporation** **=** 6588101 0005218 Tll == All these sequences are identical internally, except that loading the Mode Register doesn't subsequently reset the Mode Register. Once the reset process starts, the DCP is unable to respond to any further commands for approximately five clock cycles. If a power-up reset is used, the rising edge of the reset signal should not occur until approximately 1 ms after $V_{\rm DD}$ has reached the normal operating voltage. This delay time is required for internal nodes to stabilize. #### Master Port Read/Write Timing The DCP's Master Port is designed to operate with multiplexed address-data buses. The Master Port can be optimized to interface with either a Latched Address Enable (CA95C68) or a Strobed (CA95C18) microprocessor. Several features of the CA95C68 interface should be stressed. - The level on Master Port Chip Select (MCS) is latched internally on the falling edge of Master Port Address Latch Enable (MALE) in Multiplexed Control Mode only. This relieves external address decode circuitry of the responsibility for latching chip select at address time. - The levels on MP1, MP2 are also latched internally on the falling edge of MALE and are subsequently decoded to enable reading and writing of the DCP's internal registers (Mode, Command, Status, Mask, Input and Output). Again, this eliminates the need for external address latching and decoding. The Mask Register is only accessible when the DCP is programmed for one-bit CFB mode via the Mode Register's Cipher Type bits. - Data transfers through the Master Port are controlled by the levels and transitions on the Master Port Read (MRD) and Master Port Write (MWR) pins. Master Port data transfers do not disturb either the chip-select or address latches, so that once the DCP and a particular register have been selected, unlimited writing and reading of that register can be done without intervening address cycles. Given the required transfer control external to the DCP, this feature could greatly speed up loading keys and data. The CA95C18 interface is similar with the following exceptions: - The level on MCS is latched internally on the rising edge of MAS in Multiplexed Control Mode only. - The levels on MP1, MP2 are also latched internally on the rising edge of MAS and are then decoded to enable reading and writing of internal registers. - Data transfers through the Master Port are controlled by Master Port Data Strobe ( MDS ) and Master Port Read/Write (MR/w). The chip-select and address latches aren't affected by data transfers. Any number of reads or writes to this selected register can be accomplished without intervening address cycles. ### Loading Key and Initialization Vector (IV) Registers The Key and Initialization Vector Registers are not directly addressable through any of the DCP's ports, therefore keys and vector data must be loaded through "command data sequences" (see Command Description Section). Most of the commands recognized by the DCP are of this type: a load or read command is written to the Command Register through the Master Port; the command processor responds by asserting the Command Pending bit in the Status Register; the user then either writes eight bytes of key or initial vector data through the Master or Auxiliary Port, as selected by the specific command, or reads eight bytes of initial vector data from the Master Port. In Direct Control Mode, only the E Key and D Key Registers can be loaded; the M Key and IV Registers are inaccessible. Loading the E and D Key Registers is accomplished by asserting the proper state on the AUX<sub>6</sub>-E/D input (HIGH for E Key, LOW for D Key) and subsequently raising the AUX<sub>7</sub>-K/ $\overline{D}$ input, indicating that key loading is required. The command processor will assert the AUX3-CP (Command Pending) signal, then the eight key bytes may be written through the Master Port to the appropriate register. In Multiplexed Control Mode, all Key and Initial Vector Registers, except the Master (M) Key, may be loaded with encrypted, as well as clear, data. Before loading an encrypted key or initial vector, the clear Master Key must first be loaded through the Auxiliary Port. If the operation is a Load Encrypted command, the subsequent data is written to either the Master or Auxiliary Port and is routed first to the Input Register and decrypted before being stored in the specified Key or Initial Vector Register. After loading the last byte of an encrypted key or initial vector, no reading or writing of internal registers is allowed for the subsequent 60 clock cycles. ## **Parity Checking of Keys** Key bytes are considered to contain seven bits of key information and one Parity bit. By DES designation, the low-order bit is the Parity bit. The parity checking circuit is enabled whenever a byte is written to one of the three key registers. The output of the parity detection circuit is connected to the PAR pin, as well as the state of this pin being reflected by the Status Register PAR (S3) bit. Status Register bit PAR goes to "1" whenever a byte with even parity (an even number of "1"s) is detected. The Status Register also has a Latched Parity bit (LPAR, S4) which is set to "1" whenever the Status Register PAR bit goes to "1". Once it is set to "1", the LPAR bit is not cleared until a reset occurs or a new Load Key command is issued. Tundra Semiconductor Corporation 3-46 **■■ 6588101 0005219 958 ■** When an encrypted key has been loaded, the parity detect logic operates only after the decrypted key is available. The encrypted data is not checked for parity. The PAR signal will reflect the state of the decrypted bytes on a byte-to-byte basis, as they are clocked through the parity check logic on their way to the appropriate key register. Therefore, the time PAR indicates the status of a byte of decrypted key data may be as short as four clock cycles. The LPAR bit in the Status Register will indicate if any byte contained errors. #### **Data Flow** The Mode Register contains two bits, M2 and M3, which control the flow of data into and out of the DCP through the Master and Slave Ports. Three basic configurations are provided: single port, and two dual port configurations. #### Single Port Configuration The simplest configuration occurs when the Mode Register Data Flow Control bits are set to Master Port only. Data to be encrypted/decrypted (depending on the value loaded into the Encrypt/Decrypt bit (M4) of the Mode Register) is written to the Input Register through the Master Port. To facilitate monitoring of the Input Register status, the MFLG signal goes LOW when the Input Register is not full. Clear or cipher data is ready to be read by the host CPU through the Master Port Output Register address when SFLG goes LOW. Therefore, MFLG is redefined as Master Input Flag and SFLG is redefined as Master Output Flag. # Dual Port, Master Port Clear Configuration In the dual port configurations, entering and removing data is accomplished with both the Master and Slave Ports. In the Master Port Clear configuration, clear text for encryption or clear text resulting from decryption can pass only through the Master Port. Cipher text can be handled only through the Slave Port. The direction of data flow is controlled either by the Encrypt/Decrypt bit (M4) in the Mode Register, or by the Start Encryption or Start Decryption commands. For encryption, clear data is written through the Master Port to the Input Register, and cipher data can be read from the Output Register through the Slave Port at the appropriate time. If decryption is selected, the process is reversed, cipher data being written to the Input Register through the Slave Port, and the clear data being read from the Output Register through the Master Port. ### Dual Port, Slave Port Clear Configuration This configuration is identical to the Dual Port, Master Port Clear configuration described above, except that the direction of ciphering is reversed. That is, all data written, or read at the Master Port is cipher text, and all data at the Slave Port is clear text Figure 3-15: CA95C68 and CA95C18 Data Flow Options **Tundra Semiconductor Corporation** 3-47 **■ 6588101 0005220 67T ■** #### REGISTER DESCRIPTION The registers in the DCP which can be directly addressed through the Master Port are shown with their addresses in Table 3-7. A brief description of these registers and others not directly accessible is given below. Table 3-7: Master Port Register Address | C/K | Cipher<br>Type | MP2 | MP1 | MRD<br>9568 | MWR<br>9568 | MR/W<br>9518 | MCS | Register<br>Addressed | |-----|---------------------------|-----|-----|-------------|-------------|--------------|-----|-------------------------| | 0 | all | 0 | 0 | 1 | 0 | 0 | 0 | Input<br>Register | | 0 | all | 0 | 0 | 0 | 1 | 1 | 0 | Output<br>Register | | 0 | all | 0 | 1 | 1 | 0 | 0 | 0 | Command<br>Register | | 0 | ali | 0 | 1 | 0 | 1 | 1 | 0 | Status<br>Register | | 0 | ECB/<br>CBC/<br>CFB-<br>8 | 1 | 0 | 1 | 0 | 0 | 0 | Input<br>Register | | 0 | ECB/<br>CBC/<br>CFB-<br>8 | 1 | 0 | 0 | 1 | 1 | 0 | Output<br>Register | | 0 | CFB- | 1 | 0 | х | х | х | 0 | Mask<br>Register | | 0 | all | 1 | 1 | х | х | х | 0 | Mode<br>Register | | х | all | х | × | х | x | х | 1 | No Register<br>Accessed | | 1 | all | х | х | 1 | 0 | 0 | 0 | Input<br>Register | | 1 | all | х | × | 0 | 1 | 1 | 0 | Output<br>Register | #### **Mode Register** Figure 3-16 shows the bit assignments in this 7-bit read/write register. The Cipher Type bits (M1, M0) indicate to the DCP which ciphering algorithm is to be used. After a reset, the Cipher Type defaults to the Electronic Code Book. Configuration bits (M3, M2) indicate which data ports are to be associated with the Input and Output Registers and flags. When these bits are set to the Single Port Master Only configuration (M3, M2=10), the Slave Port is disabled and no manipulation of Slave Port Chip Select (\$\overline{SCS}\$) or Slave Port Data Strobe (\$\overline{SCS}\$) can cause data movement through the Slave Port. All data transfers are accomplished through the Master Port, as described more fully in the Functional Description section. In this configuration, $\overline{\text{MFLG}}$ gives the status of the Input Register and $\overline{\text{SFLG}}$ the Output Register. Both the Master and Slave Ports are available for input and output operations when the Configuration bits are set to one of the dual port configurations (M3,M2 = 00 or 01). When M3,M2 = 01 (the default configuration), the Master Port handles clear data while the Slave Port handles ciphered data. Configuration M3,M2 = 00 reverses this assignment. The data direction at any particular moment is controlled by the Encrypt/Decrypt bit (M4). The Encrypt/Decrypt bit instructs the DCP algorithm processor to encrypt or decrypt the data from the Input Register using the ciphering method specified by the Cipher Type bits. The Encrypt/Decrypt bit also controls the data flow direction within the DCP. For example, when the Encrypt/Decrypt bit is "1" (encrypt) and the Configuration bits are "01" (Dual Port, Master Clear, Slave Encrypted), clear data will enter the DCP through the Master Port and encrypted data will be removed from the Slave Port. When the Encrypt/Decrypt bit is set to "0" (decrypt), the direction of data flow reverses. The CFB-1 Mask Direction bit (M5) determines the direction in which the Mask Register's bits and the input data are interpreted. When the CFB-1 Mask Direction bit is set to "0" the DCP will read the Mask Direction and data to be ciphered from most significant bit (MSB) to least significant bit (LSB). When the CFB-1 Mask Direction bit is set to "1" the DCP will read the Mask Register and data from LSB to MSB. The CFB-1 Mask Direction bit is only accessible when the DCP is set to 1-bit Cipher Feedback mode via the Mode Register. The CFB-1 Default Output bit (M6) defines the sense of output bits which are masked off in the Mask Register. If the Default Output bit is set to "1" then output bits, which are masked (not used), will be set to "1". If the Default Output bit is cleared to "0" then output bits, which are masked (not used), will be cleared to "0". #### Mask Register The 8-bit read/write Mask Register determines which Input and Output Register bits are significant during One-bit Cipher Feedback mode (CFB-1). If any Mask Register bit is set to "1" then the corresponding bit of the Input Register will be used as an input to the one-bit cipher feedback encryption/decryption process and its one bit result will likewise be placed in the corresponding bit of the Output Register. If any Mask Register bit is cleared to "0" then the corresponding bit of the Input Register will be ignored. **Tundra Semiconductor Corporation** 3-48 **■** 6588101 0005221 506 1 In one-bit cipher feedback mode, if a single byte is written to the Input Register (when requested by the DCP via the Input Flag) then the ciphering algorithm unit will remain busy until all bits in the Input Register, corresponding to set bits in the Mask Register, are processed. For example, if the Mask Register is set to "01101001" and the Mode Register's CFB-1 Mask Direction bit is set for MSB to LSB Mask interpretation, then the DCP will perform Encryption/Decryption on bit 6 of the Input Register, followed by bits 5, 3, and 1. The corresponding results will be placed in bits 6, 5, 3 and 1 of the Output Register. All other bits in the Input Register will be ignored and all other bits in the Output Register will be set to the state indicated by the Default Output bit (M6) of the Mode Register. The ciphering algorithm unit will remain busy until all four bits are ciphered. Zero to eight bits of the Mask Register may be set to "1". If zero bits are set to "1" then any subsequent writes to the Input Register will be ignored. - \* The CFB-1 Mask Direction and Default Output bits are only accessible when the DCP is in CFB-1 mode, otherwise these bits are high. - 1.) This mode is Newbridge Microsystems specific. Figure 3-16: Mode Register Bit Assignments #### Command Register Data written to the 8-bit, write only Command Register through the Master Port is interpreted as an instruction. A detailed description of each command is given in the Command Description section, and the commands and their binary representations are summarized in Table 3-8 and Table 3-9. Table 3-8: Command Codes in Multiplexed Control Mode | Hex<br>Code | Command | |-------------|---------------------------------------------| | 90 | Load Clear M Key through Auxiliary Port | | 91 | Load Clear E Key through Auxiliary Port | | 92 | Load Clear D Key through Auxiliary Port | | 11 | Load Clear E Key through Master Port | | 12 | Load Clear D Key through Master Port | | B1 | Load Encrypted E Key through Auxiliary Port | | B2 | Load Encrypted D Key through Auxiliary Port | | 31 | Load Encrypted E Key through Master Port | | 32 | Load Encrypted D Key through Master Port | | 85 | Load Clear IVE through Master Port | | 84 | Load Clear IVD through Master Port | | A5 | Load Encrypted IVE through Master Port | | A4 | Load Encrypted IVD through Master Port | | 8D | Read Clear IVE through Master Port | | 8C | Read Clear IVD through Master Port | | A9 | Read Encrypted IVE through Master Port | | A8 | Read Encrypted IVD through Master Port | | 39 | Encrypt with Master Key | | 41 | Start Encryption | | 40 | Start Decryption | | C0 | Start | | E0 | Stop | | 00 | Software Reset | # **Status Register** The bit assignments for the read-only Status Register are shown in Figure 3-17. The PAR, AFLG, SFLG and MFLG bits indicate the status of the similarly named output pins, as do the Busy and Command Pending bits when the DCP is the Direct Control Mode ( $C/\bar{k}$ HIGH). In each case, the output signal will be active LOW when the corresponding Status bit is a "1". The Parity bit indicates the parity of the most recently entered key byte. The LPAR bit, on the other hand, indicates whether any key byte with even parity has been encountered since the last Reset or Load Key command. Table 3-9: Implicit Command Sequences in Direct Control Mode | <b>C</b> /K | Aux <sub>7</sub> -<br>k/ō | AUX <sub>6</sub> - | AUX <sub>5</sub> -<br>s/s | Command Initiated | |-------------|---------------------------|--------------------|---------------------------|-----------------------------------------| | Н | L | L | 1 | Start Decryption | | Н | L | Н | 1 | Start Encryption | | Н | L | х | <b>↓</b> | Stop | | Н | 1 | L | L | Load Clear D Key through<br>Master Port | | Н | 1 | н | L | Load Clear E Key through<br>Master Port | | Н | <b>↓</b> | х | L | End Load Key Command | | Н | Н | x | Н | Not Allowed | | L | Data | Data | Data | AUX Pins become Key byte Inputs | The Busy bit will be a "1" whenever the ciphering algorithm unit is actively encrypting or decrypting data. For example, the Busy bit is set in response to a Load Encrypted Key command (the Command Pending bit will go HIGH as well) or in the ciphering of regular text (indicated by the Start/Stop bit being a "1"). If the ciphered data cannot be transferred to the Output Register (due to the presence of data from a previous ciphering cycle), then the Busy bit will remain a "1". The Busy bit will be "0" at all other times, including if no ciphering is possible because no data has been loaded into the Input Register. The Command Pending bit is set to "1" by any instruction which requires the transfer of data to or from a non-addressable internal register, such as when writing key bytes to the E Key Register or reading bytes from the IVE Register. Therefore, the Command Pending bit will be set following all commands except the three Start Commands, the Stop command and the software Reset command. The Command Pending bit will return to an inactive state ("0") after all eight bytes have been transferred following Load Clear, Read Clear or Read Encrypted commands. In addition the inactive state ("0") only returns after data has been entered, decrypted and placed into the desired register following Load Encrypted commands. The Start/Stop bit is set to "1" when one of the Start commands is entered, and is reset to "0" whenever a reset occurs or when a new command other than a Start is entered. **Tundra Semiconductor Corporation** 3-50 **■ 6588101 0005223 389 ■** Figure 3-17: Status Register Bit Assignments 6588101 0005224.215 #### Input Register The 64-bit, write-only Input Register is organized to appear to the user as eight bytes of push-down storage. The number of bytes stored in the register is monitored by a status circuit. The register is considered full when eight bytes of data have been loaded with the ECB or CBC ciphering algorithm in use, or when one byte of data has been entered in either CFB mode. It is considered empty when the data stored in it has been or is being processed. The data in the register won't be destroyed if the user attempts to write data into the Input Register when it is full. Table 3-10 gives a summary of the port flag associated with this register depending on the mode of operation. #### **Output Register** The 64-bit, read-only Output Register is setup to appear to the user as eight bytes of pop-up storage. A status circuit detects the number of bytes stored in the Output Register. The register is considered empty when all the data stored in it has been read out by the host CPU, and is considered full if it still contains one or more bytes of output data. If an attempt is made to read data from the Output Register when it is empty, the output buffers will remain in a tri-state condition. Table 3-10: Association of Master Port Flag ( MFLG ) and Slave Port Flag (SFLG) with Input and Output Registers | Encrypt/ | Port Con | figuration | Input | Output<br>Register<br>Flag | | |---------------|----------|------------|------------------|----------------------------|--| | Decrypt<br>M4 | M3 | M2 | Register<br>Flag | | | | 0 | 0 | 0 | MFLG | SFLG | | | 0 | 0 | 1 | ŞFLG | MFLG | | | 0 | 1 | 0 | MFLG | SFLG | | | 1 | 0 | 0 | SFLG | MFLG | | | 1 | 0 | 1 | MFLG | SFLG | | | 1 | 1 | 0 | MFLG | SFLG | | ## M,E,D Key Registers There are three 64-bit, write-only key registers in the DCP; the Master (M) Key Register, the Encrypt (E) Key Register, and the Decrypt (D) Key Register. These registers are not directly addressable, but can be loaded or read in response to a command (See Command Descriptions). The Master key can be loaded only with clear data through the Auxiliary Port. The Encrypt and Decrypt Keys can be loaded as either clear or cipher text through the Master or Auxiliary Port. If the key data is encrypted, it is first routed to the Input Register where it is decrypted using the M Key, and then written to the target key register from the Output Register. ### **Initialization Vector Registers** Two 64-bit registers are provided to store feedback from Cipher Feedback and Cipher Block Chaining modes of operation. One Initialization Vector (IVE) Register is used during encryption, the other (IVD) during decryption. Both registers can be loaded with either clear or encrypted data through the Master Port. If encrypted data is loaded, it is first decrypted before being written into the corresponding IV Register. Both registers may be read out through the Master Port as either clear or encrypted text (see Command Description Section). # PROGRAMMING INSTRUCTIONS FOR MULTIPLEXED CONTROL MODE This section describes the registers that need programming prior to using the DCP in ECB, CBC, or CFB ciphering modes in Multiplexed Control Mode (MCM) of operation. The programming flow charts for each mode are implemented for a single 8 bit port interface (see the pipelining section for the dual port programming flow chart). ### **ECB Operation** Figure 3-18 illustrates the programming sequence for ECB. - A hardware or software reset must be implemented to bring the device to a known state. A reset clears all bits in the Status Register and programs the Mode Register to it's default setting. - Program the Mode Register (see Figure 3-16) with the cipher type and the port configuration. For further explanation see the Mode Register description. - 3) The clear Encryption or Decryption Keys can be loaded through either the Master or Auxiliary Ports. The Command Pending bit in the Status Register will go active once a command has been entered in the Command Register. This bit will be active until all eight bytes of the key have been loaded into the Input Register of the DCP. An alternative method to Step 3 is to load a Master Key into the DCP through the Auxiliary Port. When this command is entered the AFLG bit in the Status Register will go active (AFLG output pin will be active low) until all 8 bytes have been entered. One key byte is loaded on each rising edge of the Auxiliary Strobe (ASTB). A Load Encrypted Session Key command is then entered into the DCP. The Session Key is then decrypted by the Master Key before being stored in the corresponding register. This use of the Master Key allows you to enhance security by frequently changing the session keys over a communication link. - One of the three Start commands is then written to the Command Register to begin the ciphering session. - 5) Once a Start command is entered, the DCP will indicate that it is ready for data input by activating the corresponding flag bit in the Status Register, as well as the associated input flag pin. Data can now be input through the assigned Input Port. The two flags, MFLG and SFLG, which are associated with the Data Registers can be sensed by hardware or software to know when data is to be entered or removed from the DCP. - 6) As soon as the Input flag is active, the DCP is ready to accept data (MSB first). This bit is deactivated once eight bytes of data have been entered. - The Output flag goes active whenever the DES algorithm is completed and data is ready to be removed from the Output Register. - 8) Data is removed from the Output Port one byte at a time with the most significant byte first. The Output flag becomes inactive upon the removal of the eighth byte. - Loop through steps 5 through 9 until the ciphering session should be terminated. - 10) The session can now be terminated by issuing the Stop command to the Command Register. Upon termination, all remaining processed data is available in the Output Register until the DCP is reset. This allows you to enter the Stop command immediately upon entering the last input block. When all the data has been removed from the Output Register, all the flags will be inactive. If the DCP is restarted, any data that was not read out from the previous ciphering session will be lost. **Tundra Semiconductor Corporation** ■ 6588101 0005226 098 **■** Figure 3-18: Multiplexed Control Mode ECB Programming Flow Chart ■ 6588101 0005227 T24 **■** ### **CBC** Operation Figure 3-19 illustrates the DCP programming sequence for implementing the CBC method of ciphering. The programming sequence is identical to the ECB programming sequence except for an extra step included between steps 3 and 4. The Initialization Vectors (IVs) must be loaded before beginning to cipher data. These IVs can be loaded in either clear (step 3.1) or ciphered form (steps 3.1.A and 3.1.B). - 3.1 Load in eight bytes (MSB first) of the Initialization Vector through the Master Port. - 3.1.A(B) If the Initialization Vector is entered in encrypted form, it is decrypted using the Decrypt Session Key in ECB mode before being stored in the appropriate register. Load the D Key (if not already done) prior to executing an encrypted IV command. The eight IV bytes are then loaded into the Input Register and decrypted. The bits (Cipher Type and Encrypt/Decrypt bit) in the Mode Register are not affected by the decrypting of the IVs. # **CFB Operation** The flow chart for the instruction sequence in CFB mode is very similar to CBC mode. The DCP can be programmed to execute in either 1-bit or 8-bit CFB mode. The Input and Output Registers hold between one and 8 bits depending on the cipher type and the setting of bits in the Mask Register. In both modes, the IV is first ciphered by the algorithm unit and the result is then XORed with the input byte or bit (see explanation of Mask Register for CFB-1 mode). The XOR result is then loaded into the Output Register to be read out by the CPU. This result is also shifted into the current IV Register to be used in the next cipher session. When operating in CFB mode, the Output Register must first be emptied before issuing a Stop command to the DCP. If you must stop in the middle of inputting a block of data while using ECB or CBC ciphering in Multiplexed Control Mode, follow this instruction sequence to avoid erroneous data: - 1) Issue a Stop command. - 2) Read all available data from the Output Register. - 3) Reload the Mode Register. - 4) Issue a Start command. - Wait for the input flag to go active and resume data input. Figure 3-19: Multiplexed Control Mode CBC Programming Flow Chart # PROGRAMMING INSTRUCTIONS FOR DIRECT CONTROL MODE This section describes how the DCP functions in Direct Control Mode (DCM), (C/k pin is high). Only a subset of the commands that are available in Multiplexed Control Mode can be executed by controlling and monitoring the status of the Auxiliary Port pins. While in DCM, you are unable to access the Mode or Mask Register. The state of the E/\overline{D} and K/\overline{D} pins should be held constant throughout the entire key or data loading process. The state of the S/\overline{S} pin must also be held constant during the entire data ciphering process. #### **ECB Operation** A flow chart of ECB operation in Direct Control Mode is illustrated in Figure 3-20. A detailed explanation of each step is described below: In most DCM applications it is desirable to switch back and forth between MCM and DCM; therefore, $C/\bar{\kappa}$ must be programmable. Before using the device, either a hardware or software reset should be performed to set the device to it's default state. If the default mode of operation and the Direct Control Mode instruction set is sufficient for your requirements, then $C/\bar{\kappa}$ may be permanently tied high. If your application does not work in the default mode of operation, the Mode Register must be programmed while in Multiplexed Control Mode (which requires $C/\bar{\kappa}$ to be low). - 1) While in Multiplexed Control Mode, any key load commands can be executed before switching back to Direct Control Mode (DCM). Alternatively, the session keys may be loaded while in DCM. When operating in DCM, the DCP does not automatically latch the Input/Output Register's address. Before beginning to load any data into the Input Register, you must latch this address using the address latch enable strobe. Driving the K/\overline{D} pin of the Auxiliary Port high sets up the DCP for key entry (the S/s pin must stay low for the entire key loading process). The level of the E/D pin determines whether the Encryption or Decryption Session Key will be loaded. As soon as the CP output pin goes low you may begin to strobe in the eight key bytes using the Master Port Write Strobe (MCS must be held low throughout the entire byte loading process). - 2) Once the key loading process is complete, you may now enter a Start command by driving the S/s line high. The level on the E/o pin at this time will determine whether the data is encrypted or decrypted. The levels on the K/o and S/s) pins must be low throughout the data ciphering process. The DCP responds to this command by lowering the Input Port flag (see Table 3-10). - 3) Whenever the Input flag is active, data can be entered through the Master or the Slave Port, depending on the selected mode of operation. To achieve the highest throughput, the DCP must be configured to work in the pipeline mode of operation. When the DCP has processed the data, the Output flag will become active and the data may be removed from the Output Port. - 4) Once all the data has been ciphered and read from the output port, the DCP should be returned to the inactive state by driving the S/s pin low. **Note:** You must remove all the data from the output port before stopping the DCP or the data will be lost. Similarly, the key reloading process can not begin until all the data from the previous ciphering session has been removed from the output port. 3-56 **Tundra Semiconductor Corporation** ■ 6588101 0005229 8T? **■** Figure 3-20: Direct Control Mode ECB Programming Flow Chart **■ 6588101 0005230 519 ■** #### **CBC and CFB Operation** The instruction sequence to perform CBC or CFB operation in Direct Control Mode (DCM) is similar to ECB mode of operation. When operating in these modes, the $C/\bar{k}$ pin must be programmable because the IV needed for CBC and CFB can only be loaded while in Multiplexed Control Mode. If you are using CFB-1 ciphering, the Mask Register must also be loaded before entering DCM. When operating in this mode you must ensure that a Stop command is not issued while the Command Pending or Busy pins are active, or when there is data still remaining in the Output Register. (see Figure 3-21 for a programming flow chart). Figure 3-21: Direct Control Mode CBC/CFB Programming Flow Chart Tundra Semiconductor Corporation 3-58 ■ 65881C1 0005231 455 ■ ### **Maximum Throughput** The pipelined architecture of the DES DCPs allows simultaneous input, ciphering, and output operations. Maximum throughput is obtained when the device is configured for one of the dual port configurations. Figure 3-22 shows the timing for ciphering one block of 64 bits in either ECB or CBC modes of encryption. The inputting of the 64 bits of data takes 8 clock cycles to complete with one data strobe being issued per clock cycle. This data must then be transferred from the Input Register to the algorithm processing unit and the flags updated, which requires 5 additional clock cycles. The algorithm unit begins ciphering concurrently with the transfer and once the flags have been updated another 64 bit block may be entered. The ciphering of the first block is completed after 18 clock cycles have elapsed from the last byte having been written to the Input Register. Another 5 clock cycles are required to transfer the ciphered data to the Output Register and update flags. Transferring of data from the algorithm processing unit to the Output Register can be performed concurrently with loading new data into the DES algorithm unit. Removing the data from the Output Register involves 8 clock cycles with one data strobe per clock cycle. The whole procedure of ciphering one block takes 39 cycles but because the different operations can be overlapped, the DCP can process one block every 18 clock cycles once fully loaded. Note: CA95C68 minimum clock period = 40 nanoseconds Figure 3-22: Detailed Timing of One Block # **Pipelining** Once the device has been initialized for dual port configuration, two data blocks are loaded into the device to fill the Output Register and the DES algorithm processing unit. Now blocks of data can be strobed in and out concurrently. When the ciphering session is completed the DCP must be emptied by reading out the last two bytes. Figure 3-23 illustrates a programming flow chart for programming the DCP for pipelined mode of operation. Figure 3-24 shows the minimum timing configuration for maximum throughput for this device. The total time to transfer "n" blocks is (n+1)x18+3 clock cycles. The DCP can also be operated in pipelined mode when configured for signal port operation. Once initialized, one block of data is loaded into the device. Then, in a loop, one block of data is strobed in and one block is read out. The first block of data loaded before entering the loop is ciphered while the input of the second block is occurring. \* DATA INPUT AND OUTPUT CONCURRENTLY Figure 3-23: Pipelining Operational Flow Chart 3-60 ■ 65881C1 0005233 228 ■ For n blocks, total number of clock pulses = (n+1)x18+3 Figure 3-24: Pipelined Minimum Timing Operation **Tundra Semiconductor Corporation** **--** 6588101 0005234 164 **--** #### COMMAND DESCRIPTION All operations of the DCP result from command inputs, which are entered in Multiplexed Control Mode by writing a command byte to the Command Register. Command inputs are entered in Direct Control Mode by raising and lowering the logic levels on the AUX<sub>7</sub>- K/\(\bar{o}\), AUX<sub>6</sub>-E/\(\bar{o}\) and AUX<sub>5</sub>-S/\(\bar{s}\) pins. Table 3-8 shows all commands that may be given in Multiplexed Control Mode and Table 3-9 shows the subset executable in Direct Control Mode. # Load Clear M Key Through Auxiliary Port (90H) ## Load Clear E Key Through Auxiliary Port (91<sub>H</sub>) #### Load Clear D Key Through Auxiliary Port (92H) These commands override data flow specifications set in the Mode Register and cause the Master (M), Encrypt (E), or Decrypt (D) Key Register to be loaded with eight bytes written to the Auxiliary Port. Once the load command is written to the Command Register, the Auxiliary Port flag (AFLG) pin will go active (LOW), as well as the Auxiliary Port Flag bit (S2) in the Status Register being set to "1", indicating that the device is able to accept key bytes at the Auxiliary Port bus. In addition, the Command Pending bit (S6) will go to "1" during the entire loading process. When data has been setup on the Auxiliary Port pins, each byte is written by placing an active LOW signal on the Auxiliary Port Strobe (ASTB). The actual write occurs on the rising edge of ASTB. The Auxiliary Port Flag (AFLG) will go inactive immediately after the eighth strobe goes active (LOW). However, the Command Pending bit (S6) will remain "1" for several more clock cycles, until the key loading process is completed. All key bytes are checked for correct (odd) parity as they are entered. ### Load Clear E Key Through Master Port (11H) # Load Clear D Key Through Master Port (12H) These commands are available in both Multiplexed Control and Direct Control Modes. They override the data flow specifications set in the Mode Register (bits M2 and M3) and allow eight bytes of data to be written to the appropriate key register through the Master Port. The input register must be addressed before beginning to load the eight key bytes. In Multiplexed Control Mode, the command is initiated by writing the instruction to the Command Register. In Direct Control Mode, the command is initiated by raising the $AUX_7$ -K/ $\bar{o}$ control input while the $AUX_5$ -S/ $\bar{s}$ input is LOW and the level on $AUX_6$ -E/ $\bar{o}$ determines which key register is loaded. When the command has been recognized, the Command Pending bit (S6 in the Status Register) will go to "1" and in Direct Control Mode AUX<sub>3</sub>- $\overline{\text{CP}}$ will go active (LOW), indicating that key loading may proceed. The host system then writes exactly eight bytes to the Input Register through the Master Port. When the Key Register has been loaded, the Command Pending bit will return to "0", and in Direct Control Mode the AUX<sub>3</sub>- $\overline{\text{CP}}$ output will go inactive, indicating that the DCP can accept the next command. # Load Encrypted E Key Through Auxiliary Port (B1H) #### Load Encrypted D Key Through Auxiliary Port (B2H) These commands are only available in Multiplexed Control Mode. They are similar to the Load Clear E (or D) Key through Auxiliary Port commands, except that key bytes are initially decrypted using the Electronic Code Book algorithm and the Master (M) Key. The key bytes then pass through the parity checking logic and into the appropriate key register. The Command Pending bit (S6) will be "1" during the entire decrypt-and-load operation. The Busy bit (S5) will be "1" during the actual decrypting of the key. #### Load Encrypted E Key Through Master Port (31H) #### Load Encrypted D Key Through Master Port (32<sub>H</sub>) These commands (available in Multiplexed Control Mode only) are similar in effect to Load Clear E (or D) Key Through Master Port, except that key bytes are first decrypted using the Electronic Code Book algorithm and the Master (M) Key. The bytes are then loaded into the target key register, after having passed through the parity checking logic. The Command Pending bit (S6) will be "1" during the entire decrypt-and-load operation. As well, the Busy bit (S5) will be "1" during the actual decryption process. **Tundra Semiconductor Corporation** 3-62 ■ 6588101 0005235 OTO **■** # Load Clear IVE Register Through Master Port (85<sub>H</sub>) # Load Clear IVD Register Through Master Port (84H) These commands (available in Multiplexed Control Mode only) are virtually identical to Load Clear E (or D) Key Through Master Port, except that the data written to the Input Register address is transferred to either the Initialization Vector for Encryption (IVE) or Decryption (IVD) Register instead of a Key Register and no parity checking takes place. The Command Pending bit (S6) is a "1" during the entire loading process. # Load Encrypted IVE Register Through Master Port (A5<sub>H</sub>) # Load Encrypted IVD Register Through Master Port (A4<sub>H</sub>) These commands are similar to the Load Encrypted E (or D) Key Through Master Port commands. The data flow specification set in the Mode Register is overridden and the eight initial vector bytes are decrypted using the Decryption (D) Key and the Electronic Code Book algorithm. The resulting clear initial vector bytes are routed into the appropriate Initialization Vector Register, and no parity checking occurs. The Busy bit (S5) does not go to "1" during the decryption process, but Command Pending bit (S6) will be "1" during the entire decryption-and-load operation. # Read Clear IVE Register Through Master Port (8DH) #### Read Clear IVD Register Through Master Port (8CH) The effect of these commands (available in Multiplexed Control Mode only) is to override the data flow specifications set in the Mode Register and to allow the appropriate Initialization Vector Register to be read from the Output Register through the Master Port. When executing this instruction, each IV Register appears as eight bytes of FIFO storage. The first byte of data will be available six clocks after the loading of the Command Register. The Command Pending bit will be set to "1" and will remain a "1" until sometime after the eighth byte is read out. The host system has the responsibility to read out exactly eight bytes. # Read Encrypted IVE Register Through Master Port (A9 $_{\rm H}$ ) # Read Encrypted IVD Register Through Master Port (A8<sub>H</sub>) The effect of these commands (in Multiplexed Control Mode only) is to override the specifications set in the Mode Register and to encrypt the contents of the specified Initialization Vector Register using the Electronic Code Book algorithm and the Encrypt (E) Key. The resulting eight bytes of cipher text can be read from the Output Register through the Master Port. The Busy bit (S5) will be "1" during the encryption process, when it goes to "0, "the encrypted initial vector bytes are ready to be read out. The Command Pending bit (S6) will be "1" during the entire encryption-and-output process, and will go to "0" when the eighth byte is read out. The host system is responsible for reading out exactly eight bytes. # Encrypt with Master (M) Key (39H) This command (available in Multiplexed Control Mode only) overrides the data flow specifications set in the Mode Register and causes the DCP to write eight bytes of data to the Input Register via the Master Port. After the eighth byte has been received, the data is encrypted using the Master (M) Key and then routed to the Output Register, where it may be read out through the Master Port. The Command Pending (S6) and Busy (S5) bits are used to sense the three phases of this operation. Command Pending goes to "1" as soon as the Input Register can accept data. When exactly eight bytes have been entered, the Busy bit will got to "1" until the encrypted data is available to be read out. Command Pending will return to "0" when the eighth byte has been read. **Tundra Semiconductor Corporation** 🖿 6588101 0005236 T37 🖿 #### Start Encryption (41H) # Start Decryption (40H) ### Start (C0<sub>H</sub>) The three "Start" commands begin normal data ciphering by setting the Start/Stop bit (S7) in the Status Register to "1." The Start Encryption and Start Decryption commands specify the ciphering direction by forcing the Encrypt/Decrypt bit (M4) in the Mode Register to "1" or "0", respectively. Whereas Start uses the current state of the Mode Register Encrypt/Decrypt bit, as specified in a previous Mode Register load. When any Start command has been entered, the port status flag (MFLG or SFLG) associated with the Input Register will become active (LOW), indicating that data may be written to the Input Register to begin ciphering. In Direct Control Mode, the Start command is issued by raising the level of the $AUX_5$ -S/ $\bar{s}$ input. If $AUX_6$ -E/ $\bar{o}$ is high when $AUX_5$ -S/ $\bar{s}$ goes HIGH, the command is Start Encryption; if $AUX_6$ -E/ $\bar{o}$ is low, it is Start Decryption. # Stop (E0<sub>H</sub>) The Stop command sets the Start/Stop bit (S7) in the Status Register to "0." This causes the input flag (MFLG or SFLG) to become inactive and inhibits the loading of any further data. Any ciphering in progress (Busy bit (S5) is "1" or AUX<sub>2</sub>-BSY is active) will be completed and any data in the Output Register will remain accessible (except in CFB Mode). In either CFB Mode, the last byte of data must be read out before issuing the Stop command. In Direct Control Mode, the Stop command is implied when the signal level on the AUX<sub>5</sub>-S/ $\overline{s}$ input goes from HIGH to LOW. # Software Reset (00H) This command is similar to a hardware reset (CA95C68: MRD and MWR low, CA95C18: MAS and MDS low) in that it forces the DCP back to its default configuration, and all the processing flags go inactive. The default configuration for the Mode Register is: Electronic Code Book cipher type and dual port configuration with Master Port clear, Slave Port encrypted. #### CA95C68/18/09 NOTES This listing describes known operating variants between the CA95C68/18/09 devices and both the AMD AM9568/18 and VLSI VM009 devices. Also contained here are some CA95C68/18/09 operating idiosyncrasies. - CA95C68/18/09 Reset: The CA95C68/18/09 device does not operate in the default mode of operation until one of the reset operations are performed on it. Either a hardware reset, a software reset, or a write to the Mode Register must be performed before beginning to program the CA95C68/18/09 to ensure that the device is operating in the default mode. - 2) CA95C68/18/09 Direct Control Mode: When the CA95C68/18/09 is programmed for Direct Control Mode (DCM) operation, the Input and Output Register address and ™CS must be manually latched immediately before or immediately after DCM is entered. The device does not automatically address the Input and Output Registers (Address 0) when DCM is entered. This should be done before any operations are performed. - 3) CA95C68/18/09 Busy Bit in CFB-8 Cipher Mode: When the CA95C68/18/09 is programmed for eight bit cipher feedback (CFB-8), ciphering in either Multiplexed Control or Direct Control Mode of operation, the Busy bit (bit 5 in the Status Register) and the BSY pin (AUX<sub>2</sub>-BSY in DCM) go active before the Input Register is addressed. The Busy bit and the BSY pin go active immediately after the Mode Register is programmed for the CFB-8 cipher type. This bit (and pin in DCM) is not of great importance and should be ignored in this mode of operation. - 4) Synchronization for CA95C68/18/09 and VM009 Read/Write: Compared to the VLSI VM009 device, the CA95C68/18/09 has a narrower window in which the read and write strobes must synchronize to the clock input. The CA95C68/18/09 AC parameter in question is t<sub>45</sub> which is specified as a minimum of 2ns and a maximum of t<sub>c</sub>-25ns. Therefore, the CA95C68/18/09 read and write strobes must be driven HIGH between 2 and 15ns after the falling edge of the clock if you are using the DCP at 25MHz. With the VLSI device, the read and write synchronization occurs on the rising edge of the clock and there is only a 4ns region in which the strobes can not go HIGH for any clock frequency. - Clock Frequency: The clock input frequency for the various devices are: AM9568 1.0 MHz to 4.0 MHz AM9518 1.0 MHz to 3.1 MHz CA95C68/18/09 0 MHz to 33 MHz VM009 0 MHz to 33 MHz One-Bit Cipher Feedback Mode: This is a mode of encryption supported by the CA95C68/18/09 that the AMD and VLSI devices do not provide. - 7) Flag Output Assertion Timing Variant: The AM9568/18 devices set and clear the flag output lines immediately after the corresponding event has occurred. The CA95C68/18/09 devices synchronize all internal events with respect to the falling edge of the clock input. Therefore, the flag output lines are set or cleared on the next falling clock edge after the corresponding event has occurred. - 8) IVE in Pipelined CBC Mode of Encryption: The AM9568/18 presents the previous IVE instead of the current IVE during a read IVE operation after a series of CBC encryptions in which more than one round of data was in the encryption pipeline. In the CA95C68/18/09 devices, the correct IVE is presented for the pipelined CBC mode encryption scheme. - 9) Direct Control Mode, Mode Register Encrypt/Decrypt Bit Variant: In Direct Control Mode (DCM), the AM9568/18 adjusts the sense of the Mode Register's Encrypt/Decrypt bit (M4) inconsistently; based on whether encryption or decryption is performed. The CA95C68/18/09 always sets the Encrypt/Decrypt bit to be the same sense as the AUX<sub>6</sub>-E/\(\overline{D}\) input line in this case. - 10) Key Parity in Direct Control Mode: The AM9568/18 erroneously indicates a parity error during the loading of keys of correct parity in Direct Control Mode. The CA95C68/18/09 devices do not indicate a parity error in this scenario. - 11) Encrypted Key Load Parity Variant: The AM9568/18 will clear a parity error regardless of whether the last byte of an encrypted key load has a parity error. The CA95C68/18/09 devices will indicate the parity of the last byte of an encrypted key load correctly, and if required, the parity error must be cleared by one of the specified methods. - 12) Mode Register's Encrypt/Decrypt Bit Status on a Command Abort Reset: The AM9568/18 will not set the Encrypt/Decrypt bit high if that bit is low and a command is aborted. The CA95C68/18/09 devices will reset this bit high when the Mode Register is reset during a command abort sequence. 3-66 **■ 6588101 0005239 746** ■