### **DATA SHEET** L 67024 ## 4 K × 16 CMOS DUAL PORT RAM 3.3 Volt #### **FEATURES** - SINGLE 3.3V ± 0.3 Volt POWER SUPPLY - FAST ACCESS TIME: 55 NS TO 70 NS - 45 NS PRELIMINARY FOR COMMERCIAL ONLY - WIDE TEMPERATURE RANGE: - 55 °C TO + 125 °C - 67024 L LOW POWER 67024 V VERY LOW POWER - SEPARATE UPPER BYTE AND LOWER BYTE CONTROL FOR MULTIPLEXED BUS COMPATIBILITY - EXPANDABLE DATA BUS TO 32 BITS OR MORE USING MASTER/SLAVE CHIP SELECT WHEN USING MORE THAN ONE DEVICE - ON CHIP ARBITRATION LOGIC - VERSATILE PIN SELECT FOR MASTER OR SLAVE: - M/S = H FOR BUSY OUTPUT FLAG ON MASTER - M/S = L FOR BUSY INPUT FLAG ON SLAVE - INT FLAG FOR PORT TO PORT COMMUNICATION - FULL HARDWARE SUPPORT OF SEMAPHORE SIGNALING BETWEEN PORTS - FULLY ASYNCHRONOUS OPERATION FROM EITHER PORT - BATTERY BACK-UP OPERATION: 2 V DATA RETENTION #### INTRODUCTION The L 67024 is a very low power CMOS dual port static RAM organised as $4096\times16$ . The L 67024 is designed to be used as a stand-alone 16 bit dual port RAM or as a combination MASTER/SLAVE dual port for 32 bit or more width systems. The MHS MASTER/SLAVE dual port approach in memory system applications results in full speed, error free operation without the need for additional discrete logic. Master and slave devices provide two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads and writes to any location in the memory. An automatic power down feature controlled by $\overline{\text{CS}}$ permits the onchip circuitry of each port in order to enter a very low stand by power mode. Using an array of eigh transistors (8T) memory cell and fabricated with the state of the art 1.0 $\mu m$ lithography named SCMOS, the L 67024 combines an extremely low standby supply current (typ = 1.0 $\mu A$ ) with a fast access time at 45 ns over the full temperature range. All versions offer battery backup data retention capability with a typical power consumption at less than 5 $\mu W$ . For military/space applications that demand superior levels of performance and reliability the L 67024 is processed according to the methods of the latest revision of the MIL STD 883 (class B or S) and/or ESA SCC 9000. The information contained herein is subject to change without notice. No responsibility is assumed by MATRA MHS SA for using this publication and/or circuits described herein: nor for any possible infringements of patents or other rights of third parties which may result from its use. ## 1 ## **INTERFACE** #### PIN CONFIGURATION | r | | | | | | | | | | | | | | |----|--------------------------|--------------------------|-------------------------|-------------------------|-------------------------|-----------------------|------------------------|------------------------|-------------------------|------------------------|-------------------------|--|--| | 11 | 63<br>I/O <sub>7L</sub> | 61<br>I/O <sub>5L</sub> | 60<br>I/O <sub>4L</sub> | 58<br>1/0 <sub>2L</sub> | 55<br>1/O <sub>OL</sub> | OE <sub>L</sub> | 51<br>SEML | LB <sub>L</sub> | 46<br>A <sub>11</sub> L | 45<br>A <sub>10L</sub> | 42<br>A <sub>7L</sub> | | | | 10 | 66<br>I/O <sub>10L</sub> | 64<br>I/O <sub>8L</sub> | 62<br>I/O <sub>6L</sub> | 59<br>1/O <sub>3L</sub> | 56<br>VO <sub>1L</sub> | UB <sub>L</sub> | 25<br>CS <sub>L</sub> | 47<br>NC | 44<br>A <sub>9L</sub> | 43<br>A <sub>8L</sub> | 40<br>A <sub>5L</sub> | | | | 09 | 67<br>I/O <sub>11L</sub> | 65<br>1/O <sub>9L</sub> | | | 57<br>GND | V <sub>CC</sub> | 52<br>R/W <sub>L</sub> | | | 41<br>A <sub>6L</sub> | 39<br>A <sub>4L</sub> | | | | 08 | 1/O <sub>13L</sub> | 1/O <sub>12L</sub> | | ' | | | | | | 38<br>A <sub>3L</sub> | 37<br>A <sub>2L</sub> | | | | 07 | 72<br>VO <sub>15L</sub> | 71<br>I/O <sub>14L</sub> | 73<br>V <sub>CC</sub> | | 04 | DIN DA | <b>.</b> . | | 33<br>BUSYL | 35<br>A <sub>0L</sub> | 34<br>INT <sub>L</sub> | | | | 06 | 75<br>I/O <sub>OR</sub> | 70<br>GND | 74<br>GND | | - | PIN P | | | 32<br>GND | 31<br>M/S | 36<br>A <sub>1</sub> L | | | | 05 | 76<br>VO <sub>1R</sub> | 77<br>I/O <sub>2R</sub> | 78<br>V <sub>CC</sub> | | (10 | p Vie | w) | | 28<br>A <sub>OR</sub> | 29<br>INT <sub>R</sub> | 30<br>BUSY <sub>F</sub> | | | | ŀ | 79<br>I/O <sub>3R</sub> | 80 | | | | | | | | 26<br>A <sub>2</sub> R | 27<br>A <sub>1R</sub> | | | | 03 | 81 | 83<br>I/O <sub>7R</sub> | | | GND 7 | 11<br>GND | SEM <sub>R</sub> | | | 23<br>A <sub>5</sub> R | 25<br>A <sub>3R</sub> | | | | 02 | 82<br>I/O <sub>6R</sub> | 1 | 2 | 5<br>VO <sub>13R</sub> | 8<br>I/O <sub>15R</sub> | | 14<br>UB <sub>R</sub> | 17<br>A <sub>11R</sub> | | 22<br>A <sub>6R</sub> | 24<br>A4R | | | | 01 | 84<br>I/O <sub>8R</sub> | 3 | 4<br>I/O <sub>12R</sub> | 6 | 9 | 15<br>LB <sub>R</sub> | CS <sub>R</sub> | | | 19 | 21<br>A <sub>7R</sub> | | | | · | Α | В | С | D | E | F | G I | + 1 | J | К | | | | | | | | | | | | | | | | | | | ## **FUNCTIONAL DESCRIPTION** #### **BLOCK DIAGRAM** Notes: 1. (MASTER): BUSY is output. (SLAVE): BUSY is input. 2. LB = Lower Byte UB = Upper Byte. #### **PIN NAMES** | LEFT PORT | RIGHT PORT | NAMES | |------------------------------------|------------------------------------|-------------------| | CSL | CSR | Chip select | | R/W <sub>L</sub> | R/W <sub>R</sub> | Read/Write Enable | | ŌĒL | ŌĒ <sub>R</sub> | Output Enable | | A <sub>OL</sub> -11 <sub>L</sub> | A <sub>OR</sub> -11 <sub>R</sub> | Address | | I/O <sub>OL</sub> -15 <sub>L</sub> | I/O <sub>OR</sub> -15 <sub>R</sub> | Data Input/Output | | SEML | SEMR | Semaphore Enable | | <del>UB</del> L | <del>UB</del> R | Upper Byte Select | | ĽB∟ | LBR | Lower Byte Select | | INTL | INTR | Interrupt Flag | | BUSYL | BUSYR | Busy Flag | | м | /S | Master or Slave | | | | Select | | V | cc | Power | | GI | ND | Ground | # 4 ### **FUNCTIONAL DESCRIPTION** The L 67024 has two ports with separate control, address and I/O pins that permit independent read/write access to any memory location. These devices have an automatic power-down feature controlled by $\overline{CS}.\overline{CS}$ controls on-chip power-down circuitry which causes the port concerned to go into stand-by mode when not selected ( $\overline{CS}$ high). When a port is selected access to the full memory array is permitted. Each port has its own Output Enable control ( $\overline{OE}$ ). In read mode, the port's $\overline{OE}$ truns the Output drivers on when set LOW. Nonconflicting READ/WRITE conditions are illustrated in table 1. The interrupt flag ( $\overline{\text{INT}}$ ) allows communication between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag ( $\overline{\text{INT}}_L$ ) is set when the right port writes to memory location FFE (HEX). The left port clears the interrupt by reading address location FFE. Similarly, the right port interrupt flag ( $\overline{\text{INT}}_R$ ) is set when the left port writes to memory location FFF (hex), and the right port must read memory location FFF in order to clear the interrupt flag ( $\overline{\text{INT}}_R$ ). The 16 bit message at FFE or FFF is user-defined. If the interrupt function is not used, address locations FFE and FFF are not reserved for mail boxes but become part of the RAM. See table 3 for the interrupt function. #### ARBITRATION LOGIC The arbitration logic will resolve an address match or a chip select match down to a minimum of 5 ns determine which port has access. In all cases, an active BUSY flag will be set for the inhibited port. The BUSY flags are required when both ports attempt to access the same location simultaneously. Should this conflict arise, on-chip arbitration logic will determine which port has access and set the $\overline{\text{BUSY}}$ flag for the inhibited port. $\overline{\text{BUSY}}$ is set at speeds that allow the processor to hold the operation with its associated address and data. It should be noted that the operation is invalid for the port for which $\overline{\text{BUSY}}$ is set LOW. The inhibited port will be given access when $\overline{\text{BUSY}}$ goes inactive. A conflict will occur when both left and right ports are active and the two addresses coincide. The on-chip arbitration determines access in these circumstances. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{CS}$ on-chip control logic arbitrates between $\overline{CS}_L$ and $\overline{CS}_R$ for access; or (2) if the $\overline{CS}_R$ are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to table 4). The inhibited pont's $\overline{BUSY}$ flag is set and will reset when the port granted access completes its operation in both arbitration modes. #### **DATA BUS WIDTH EXPANSION** #### MASTER/SLAVE DESCRIPTION Expanding the data bus width to 32 or more bits in a dual-port RAM system means that several chips may be active simultaneously. If every chips has a hardware arbitrator, and the addresses for each arrive at the same time one chip may activate in L BUSY signal while another activates its R BUSY signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free. To overcome this "Busy Lock-Out" problem, MHS has developped a MASTER/SLAVE system which uses a single hardware arbitrator located on the MASTER. The SLAVE has BUSY inputs which allow direct interface to the MASTER with no external components, giving a speed advantage over other systems. Figure 1:32 Bit Master/slave Dual-port Memory Systems. Note: 1. No arbitration in L 67024 (SLAVE). BUSY-IN inhibits write in L 67024 SLAVE. When dual-port RAMs are expanded in width, the SLAVE RAMs must be prevented from writing until after the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a conflict situation. Conversely, the write pulse must extend a hold time beyond BUSY to ensure that a write cycle occurs once the conflict is resolved. This timing is inherent in all dual-port memory systems where more than one chip is active at the same time. The write pulse to the SLAVE must be inhibited by the MASTER's maximum arbitration time. If a conflict then occurs, the write to the SLAVE will be inhibited because of the MASTER's BUSY signal. #### SEMAPHORE LOGIC The L 67024 is an extremely fast dual-port $4k \times 16$ CMOS static RAM with an additional locations dedicated to binary semaphore flags. These flags allow either of the processors on the left or right side of the dual-port RAM to claim priority over the other for functions defined by the system software. For example, the semaphore flag can be used by oner processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource. The dual-port RAM has a fast access time, and the two ports are completely independent of one another. This means that the activity on the left port cannot slow the access time of the right port. The ports are identical in function to standard CMOS static RAMs and can be read from, or written to, at the same time with the only possible conflict arising from simultaneous writing to, or a simultaneous READ/WRITE operation on, a nonsemaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to prevent conflicts in the nonsemaphore segment of the dual-port RAM. The devices have an automatic power-down feature controlled by CS, the dual-port RAM select and SEM, the semaphore enable. The CS and SEM pins control on-chip-powerdown circuitry that permits the port concerned to go into stand-by mode when not selected. This conditions is shown in table 1 where $\overline{CS}$ and $\overline{SEM}$ are both high. Systems best able to exploit the L 67024 are based around multiple processors or controllers and are typically very high-speed, software controlled or software-intensive systems. These systems can benefit from the performance enhancement offered by the L 67024 hardware semaphores, which provide a lock-out mechanism without the need for complex programming. Software handshaking between processors offers the maximum level of system flexibility by permitting shared resources to be allocated in varying configurations. The L 67024 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture. An advantage of using semaphores rather than the more usual methods of hardware arbitration is that neither processor ever incurs wait states. This can prove a considerable advantage in very high speed systems. #### **HOW THE SEMAPHORE FLAGS WORK** The semaphore logic is a set of eight latches independent of the dual-port RAM. These latches can be used to pass a flag or token, from one port to the other to indicate that a shared resource is in use. The semaphore provide the hardware context for the "Token" Passing Allocation" method of use assignment. This method uses the state of a semaphore latch as a token indicating that a shared resource is in use. If the left processor needs to use a resource, it requests the token by setting the latch. The processor then verifies that the latch has been set by reading it. If the latch has been set the processor assumes control over the shared resource. If the latch has not been set, the left processor has established that the right processor had set the latch first, has the token and is using the shared resource. The left processor may then either repeatedly query the status of the semaphore, or abandon its request for the token and perform another operation whilst occasionally attempting to gain control of the token through a set and test operation. Once the right side has relinquished the token the left side will be able to take control of the shared resource. The semaphore flags are active low. A token is requested by writing a zero to a semaphore latch, and is relinquished again when the same side writes a one to the latch. The eight semaphore flags are located in a separate memory space from the dual-port RAM in the L 67024. The address space is accessed by placing a low input on the SEM pin (which acts as a chip select for the semaphore flags) and using the other control pins (address, OE and R/W) as normally used in accessing a standard static RAM. Each of the flags has a unique address accessed by either side through address pins A0-A2. None of the other address pins has any effect when accessing the semaphores. Only data pin Do is used when writing to a semaphore. If a low level is written to an unused semaphore location, the flag will be set to zero on that side and to one on the other side. (see table 5). The semaphore can now only be modified by the side showing the zero. Once a one is writen to this location from the same side, the flag will be set to one for both sides (unless a request is pending from the other side) and the semaphore can then be written to by either side. The effect the side writing a zero to a semaphore location has of locking out the other side is the reason for the use of semaphore logic in interprocessor communication. (A thorough discussion of the use of this feature follows below). A zero written to the semaphore location from the locked-out side will be stored in the semaphore request latch for that side until the semaphore is relinquished by the side having control. When a semaphore flag is read its value is distributed to all data bits so that a flag set at one reads as one in all data bits and a flag set at zero reads as all zeroes. The read value is latched into the output register of one side when its semaphore select ( $\overline{\text{SEM}}$ ) and output enable ( $\overline{\text{OE}}$ ) signals go active. This prevents the semaphore changing state in the middle of a read cycle as a result of a write issued by the other side. Because of this latch, a repeated read of a semaphore flag in a test loop must cause either signal ( $\overline{\text{SEM}}$ or $\overline{\text{OE}}$ ) to go inactive, otherwise the output will never change. The semaphore must use a WRITE/READ sequence in order to ensure that no system level conflict will occur. A processor requests access to shared resources by attempting to write a zero to a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as a one, and the processor will detect this status in the subsequent read (see table 5). For example, assume a processor writes a zero to the left port at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume control over the resource concerned. If a processor on the right side then attempts to write a zero to the same semaphore flag it will fail, as will be verified by a subsequent read returning a one from the semaphore location on the right side has a READ/WRITE sequence been used instead, system conflict problems could have occurred during the interval between the read and write cycles. It must be noted that a failed semaphore request needs to be followed by either repeated reads or by writing a one to the same location. The simple logic diagram for the semaphore flag in figure 2 illusrates the reason for this quite clearly. Two semaphore request latches feed into a semaphore flag. The first latch to send a zero to the semaphore flag will force its side of the semaphore flag low and other side high. This status will be maintained until a one is written to the same semaphore request latch. Sould a zero be written to the other side's semaphore flag will flip over to this second side as soon as a one is written to the first side's request latch. The second side's flag will now stay low until its semaphore request latch is changed to a one. Thus, clearly, if a semaphore flag is requested and the processor requesting it no longer requires access to the resource, the entire system can hang up until a one is written to the semaphore request latch concerned. Semaphore timing becomes critical when both sides request the same token by attempting to write a zero to it at the same time. Semaphore logic is specially conceived to resolve this problem. The logic ensures that only one side will receive the token if simultaneous requests are made. The first side to make a request will receive the token where request do not arrive at the same time. Where they do arrive at the same time, the logic will assign the token arbitrarily to one of the ports. It should be noted, however, that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, errors can be introduced if semaphores are misused or misinterpreted. Code integrity is of the utmost performance when semaphores are being used instead of slower, more restrictive hardware-intensive systems. Semaphore initialization is not automatic and must therefore be incorporated in the power up initialization procedures. Since any semaphore flag containing a zero must be reset to one, initialization should write a one to all request flags from both sides to ensure that they will be available when required. #### **USING SEMAPHORES (some examples)** Perhaps the simplest application of semaphores is their use as resource markers for the L 67024's dual-port RAM. If it is necessary to split the 4 k × 16 RAM into two 2 K × 16 blocks which are to be dedicated to serving either the left or right port at any one time. Semaphore 0 can be used to indicate which side is controlling the lower segment of memory and semaphore 1 can be defined as indicating the upper segment of memory. To take control of a resource, in this case the lower 2k of a dual-port RAM, the left port processor would then write a zero into semaphore flag 0 and then read it back. If successful in taking the token (reading back a zero rather than a one), the left processor could then take control of the lower 2 k of RAM. If the right processor attempts to perform the same function to take control of the resource after the left processor has already done so, it will read back a one in response to the attempted write of a zero into semaphore 0. At this point the software may choose to attempt to gain control of the second 2 k segment of RAM by writing and then reading a zero in semaphore 1. If successful, it will lock out the left processor. Once the left side has completed its task it will write a one to semaphore 0 and may then attempt to access semaphore 1. If semaphore 1 is still occupied by the right side, the left side may abandon its semaphore request and perform other operations until it is able to write and then read a zero in semaphore 1. If the right processor performs the same operation with semaphore 0, this protocol would then allow the two processes to swap 2 k blocks of dual-port RAM between one another. The blocks do not have to be any particular size, and may even be of variable size depending on the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphores can even be assigned different meanings on each side, rather than having a common meaning as is described in the above example. Semaphores are a useful form of arbitration in systems such as disk interfaces where the CPU must be locked out of a segment of memory during a data transfer operation, and the I/O device cannot tolerate any wait states. If semaphores are used, both the CPU and the I/O device can access assigned memory segments, without the need for wait states, once the two devices have determined which memory area is barred to the CPU Semaphores are also useful in applications where no memory WAIT state is available on one or both sides. On a semaphore handshake has been performed, both processors can access their assigned RAM segments at full speed. Another application is in complex data structures. Block arbitration is very important in this case, since one processor may be responsible for building and updating a data structure whilst the other processor reads and interprests it. A major error condition may be created if the interpreting processor reads an incomplete data structure. Some sort of arbitration between the two different processors is therefore necessary. The building processor requests access to the rblock, locks it and is then able to enter the block to update the data structure. Once the update is completed the data structure may be released. This allows the interpreting processor, to return to read the complete data structure, thus ensuring a consistent data structure. Figure 2: L 67024 - Semaphore Logic. #### **TRUTH TABLE** Table 1: Non Contention Read/Write Control. | | | INPU | TS (1) | | | OUTI | PUTS | MODE | |----|-----|------|--------|----|-----|-----------------------------------|----------------------------------|----------------------------------------| | CS | R/W | ŌĒ | ŪB | LB | SEM | IO <sub>8</sub> /IO <sub>15</sub> | VO <sub>Ø</sub> -VO <sub>7</sub> | INODE | | Н | Х | Х | Х | Х | Н | Hi-Z | Hi-Z | Deselected: Power Down | | Х | Х | Х | Н | Н | Н | Hi-Z | Hi-Z | Deselected: Power Down | | L | L | Х | L | Н | Н | DATAIN | Hi-Z | Write to Upper Byte Only | | L | L | Х | Н | L | Н | Hi-Z | DATAIN | Write to Lower Byte Only | | L | L | Х | L | L | Н | DATAIN | DATAIN | Write to Both Bytes | | L | Н | L | L | Н | Н | DATA <sub>OUT</sub> | Hi-Z | Read Upper Byte Only | | L | Н | L | Н | L | н | Hi-Z | DATA <sub>OUT</sub> | Read Lower Byte Only | | L | Н | L | L | L | Н | DATA <sub>OUT</sub> | DATA <sub>OUT</sub> | Read Both Bytes | | Х | Х | Н | Х | Х | Х | Hi-Z | Hi-Z | Outputs Disabled | | Н | Н | L | Х | Х | L | DATAOUT | DATA <sub>OUT</sub> | Read Data in Sema. Flag | | Х | Н | L | Н | Н | L | DATA <sub>OUT</sub> | DATA <sub>OUT</sub> | Read Data in Sema. Flag | | Н | | Х | Х | Х | L | DATAIN | DATAIN | Write D <sub>INØ</sub> into Sema. Flag | | Х | | × | Н | Н | L | DATAIN | DATAIN | Write D <sub>INØ</sub> into Sema. Flag | | L | Х | Χ | L | Х | L | _ | _ | Not Allowed | | L | Х | X | X | L | L | _ | - | Not Allowed | Note: 1. AØL - A11L ≠ AØR - A11R Table 2: Arbitration Options. | OPTIONS | | | INPUTS | | | OUT | PUTS | |-------------------|----|----|--------|-----|-----|--------|--------| | OFTIONS | CS | ŪB | LB | M/S | SEM | BUSY | ĪNT | | Busy Logic Master | L | Х | L | Н | Н | Output | _ | | | L | L | Х | Н | Н | Signal | | | Busy Logic Slave | L | Х | L | L | Н | Input | _ | | | L | L | Х | L | Н | Signal | | | Interrupt Logic | L | Х | L | Х | Н | _ | Output | | | L | L | Х | X | Н | | Signal | | Semaphore Logic* | Н | Х | Х | Н | L | Н | _ | | | Н | X | Х | L | L | Hi-Z | | <sup>\*</sup> Inputs Signals are for Semaphore Flags set and test (Write and Read) operations. Table 3 : Interrupt Flag<sup>(1, 4)</sup>. | | LEFT PORT | | | | RIGHT PORT | | | | | FUNCTION | | |------------------|-----------|-----|-----------------------------------|------------------|------------------|-----|------------------------|----------------------|------------------|-----------------------------------|--| | R/W <sub>L</sub> | CSL | ŌĒL | A <sub>OL</sub> -A <sub>11L</sub> | ĪNTL | R/W <sub>R</sub> | CSR | <b>OE</b> <sub>R</sub> | Aor-A <sub>11R</sub> | INTR | TONOTION | | | L | L | Х | FFF | Х | Х | Х | Х | Х | L <sup>(2)</sup> | Set Right INT <sub>R</sub> Flag | | | Х | Х | Х | Х | Х | Х | L | L | FFF | H <sup>(3)</sup> | Reset Right INT <sub>R</sub> Flag | | | Χ | Х | Х | Х | L(3) | L | L | Х | FFE | Х | Set Left INT <sub>L</sub> Flag | | | Х | L | L | FFE | H <sup>(2)</sup> | Х | Χ | Х | Х | Х | Reset Left INTL Flag | | Notes: 1. Assumes BUSY<sub>L</sub> = BUSY<sub>R</sub> = H. 2. If BUSY<sub>L</sub> = L, then NC. 3. If $\overline{BUSY}_R = L$ , then NC. <sup>4.</sup> H = HIGH, L = LOW, X = DON'T CARE, NC = NO CHANGE Table 4 : Arbitration. (2) | LEF | LEFT PORT | | T PORT | FLA | GS <sup>(1)</sup> | FUNCTION | | |-----|------------------------|------------------------|----------------------|-------|-------------------|---------------|--| | CSL | Aol-A <sub>11L</sub> | <b>CS</b> <sub>R</sub> | AoL-A <sub>11R</sub> | BUSYL | BUSYR | FUNCTION | | | Н | X | Н | Х | Н | Н | No Contention | | | L | Any | Н | Х | Н | Н | No Contention | | | Н | X | L | Any | Н | Н | No Contention | | | L | ≠ Aor-A <sub>11R</sub> | L | ≠ AoL-A11L | Н | Н | No Contention | | #### ADDRESS ARBITRATION WITH CS LOW BEFORE ADDRESS MATCH | L | LV5R | L | LV5R | Н | L | L-Port Wins | |---|------|---|------|---|---|----------------------| | L | RV5L | L | RV5L | L | Н | R-Port Wins | | L | Same | L | Same | Н | L | Arbitration Resolved | | L | Same | L | Same | L | Н | Arbitration Resolved | #### CE ARBITRATION WITH ADDRESS MATCH BEFORE CS | LL5R | = A <sub>OR</sub> - A <sub>11R</sub> | LL5R | = A <sub>OL</sub> - A <sub>11L</sub> | Н | L | L-Port Wins | |------|--------------------------------------|------|--------------------------------------|---|---|----------------------| | RL5L | = AOR - A11R | RL5L | = A <sub>OL</sub> - A <sub>11L</sub> | L | Н | R-Port Wins | | LW5R | = AOR - A11R | LW5R | = A <sub>OL</sub> - A <sub>11L</sub> | Н | L | Arbitration Resolved | | LW5R | = AOR - A11R | LW5R | = A <sub>OL</sub> - A <sub>11L</sub> | L | Н | Arbitration Resolved | Notes: 1. INT Flags Don't Care 2. X = DON'T CARE, L = LOW, H = HIGH LV5R = Left Address Valid ≥ 5 ns before right address RV5L = Right Address Valid ≥ 5 ns before left address Same = Left and Right Addresses match within 5 ns of each other LL5R = Left OS = LOW ≥ 5 ns before Right CS RL5L = Right CS = LOW ≥ 5 ns before Left CS LW5R = Left and Right CS = LOW within 5 ns of each other Table 5: Example Semaphore Procurement Sequence. | FUNCTION | Do - D <sub>15</sub> LEFT | D <sub>0</sub> - D <sub>15</sub> RIGHT | STATUS | |------------------------------------|---------------------------|----------------------------------------|--------------------------------------------------------| | No Action | 1 | 1 | Semaphore free | | Left Port Writes "0" to Semaphore | 0 | 1 | Left Port has semaphore token | | Right Port Writes "0" to Semaphore | 0 | 1 | No change. Right side has no write access to semaphore | | Left Port Writes "1" to Semaphore | 1 | 0 | Right port obtains semaphore token | | Left Port Writes "0" to Semaphore | 1 | 0 | No change. Left port has no write access to semaphore | | Right Port Writes "1" to Semaphore | 0 | 1 | Left port obtains semaphore token | | Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore free | | Right Port Writes "0" to Semaphore | 1 | 0 | Right port has semaphore token | | Right Port Writes "1" to Semaphore | 1 | 1 | Semaphore free | | Left Port Writes "0" to Semaphore | 0 | 1 | Left port has semaphore token | | Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore free | Note: 1. This table denotes a sequence of events for only one of the 8 semaphores on the L 67024 #### ELECTRICAL CHARACTERISTICS #### ABSOLUTE MAXIMUM RATINGS Supply voltage (VCC-GND) : - 0.3 V to 7.0 V Input or output voltage applied : (GND - 0.3 V) to (VCC + 0.3 V) : - 65 °C to + 150 °C Storage temperature Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. | OPERATING RANGE | OPERATING SUPPLY VOLTAGE | OPERATING TEMPERATURE | |-----------------|--------------------------|-----------------------| | Military | Vcc = 3.3 V ± 0.3 % | 55 °C to + 125 °C | | Industrial | Vcc = 3.3 V ± 0.3 % | – 40 °C to + 85 °C | | Commercial | Vcc = 3.3 V ± 0.3 % | 0 °C to + 70 °C | | Automotive | Vcc = 3.3 V ± 0.3 % | - 40 °C to + 125 °C | #### DC PARAMETERS | | | | L 67024-45 | L 670 | 24-55 | L 670 | 24-70 | | | | |------------|---------------------------------------------------------------------|---------|--------------------|------------|--------------------|------------|--------------------|--------------------------|------------|--| | PARAMETER | DESCRIPTION | VERSION | Preliminary<br>COM | COM | IND<br>MIL<br>AUTO | сом | IND<br>MIL<br>AUTO | UNIT | VALUE | | | IccsB (1) | Standby supply current<br>(Both ports TTL<br>level inputs) | V<br>L | 1<br>5 | 1<br>5 | 1<br>10 | 1<br>5 | 1<br>10 | mA<br>mA | Max<br>Max | | | IccsB1 (2) | Standby supply current<br>(Both ports CMOS<br>level inputs) | V<br>L | 20<br>100 | 20<br>100 | 50<br>100 | 20<br>100 | 50<br>200 | μ <b>Α</b><br>μ <b>Α</b> | Max<br>Max | | | ICCOP (3) | Operating supply current (Both ports active) | V<br>L | 150<br>180 | 130<br>160 | 140<br>170 | 125<br>155 | 135<br>165 | mA<br>mA | Max<br>Max | | | ICCOP1 (4) | Operating supply current<br>(One port active –<br>One port standby) | V<br>L | 90<br>120 | 80<br>110 | 85<br>120 | 70<br>100 | 75<br>110 | mA<br>mA | Max<br>Max | | Notes: 1. CS<sub>L</sub> = CS<sub>R</sub> ≥ 2.2 V - SEM<sub>R</sub> = SEM<sub>L</sub> ≥ 2.2 V 2. CS<sub>L</sub> = CS<sub>R</sub> ≥ VCC - 0.2 V - SEM<sub>R</sub> = SEM<sub>L</sub> ≥ 2.2 V 3. Both ports active – Maximum frequency – Outputs open – OE = VIH – CS ≤ VIL – SEM ≥ 2.2 V One port active (f = fMAX) - Output open - One port stand-by TTL or CMOS Level Inputs - CS<sub>L</sub> = CS<sub>R</sub> ≥ 2.2 V - SEM<sub>R</sub> = SEM<sub>L</sub> ≥ Vcc - 0.2 V | PARAMETER | DESCRIPTION | L 67024-45/55/70 | UNIT | VALUE | |---------------------|-----------------------------------------------------------|------------------|------|-------| | II/O <sub>(5)</sub> | Input/Output leakage current | ± 10 | μА | Max | | VIL <sub>(6)</sub> | Input low voltage | 0.7 | ٧ | Max | | VIH <sup>(6)</sup> | Input high voltage | 1.8 | ٧ | Min | | VOL <sub>(7)</sub> | Output low voltage (I/o <sub>0</sub> -I/o <sub>15</sub> ) | 0.5 | ٧ | Max | | VOH <sub>(7)</sub> | Output high voltage | 1.5 | ٧ | Min | | C IN | Input capacitance | 5 | pF | Max | | COUT | Output capacitance | 7 | pF | Max | Notes: 5. Vcc = 5.5 V, Vin = Gnd to Vcc, CS = VIH, Vout = 0 to Vcc 6. VIH max = Vcc + 0.3 V, VIL min = -0.3 V or -1 V pulse width 50 ns 7. Vcc min, IOL = 4 mA, IOH = -4 mA #### **DATA-RETENTION MODE** MHS CMOS RAMs are designed with battery backup in mind. Data retention voltage and supply current are guaranteed over temperature. The following rules insure data retention: 1 – Chip select (CS) must be held high during data retention; within $V_{CC}$ to $V_{CC}$ – 0.2 V $2-\overline{CS}$ must be kept between VCC - 0.2 V and 70 % of VCC during the power up and power down transitions. 3 - The RAM can begin operation > tRC after $V_{\text{CC}}$ reaches the minimum operating voltage (4,5 volts). #### TIMING | | | | M | | | |--------------------|--------------------------|--------|-----------|--------------------|------| | PARAMETER | TEST CONDITION | NS (9) | СОМ | MIL<br>IND<br>AUTO | UNIT | | ICC <sub>DR1</sub> | @VCC <sub>DR</sub> = 2 V | V<br>L | 20<br>100 | 50<br>200 | μА | **Notes:** 9. $\overline{CS} = Vcc$ , Vin = Gnd to Vcc Input Timing Reference Levels 10. t<sub>RC</sub> = Read cycle time #### **AC TEST CONDITIONS** Input Pulse Levels Input Rise/Fall Times : GND to 3.0 V Eno : 5 ns : 1.5 V Output Reference Levels Output Load : 1.5 V : see figures 1, 2 #### **AC PARAMETERS** | READ | CYCLE | PARAMETER | L 67024-45 (*) | | L 67024-55 | | L 67024-70 | | | |------------|-----------------|--------------------------------------|----------------|------|------------|------|------------|------|------| | SYMBOL (4) | SYMBOL (5) | | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | UNIT | | TAVAVR | tac | Read cycle time | 45 | | 55 | - | 70 | _ | ns | | TAVQV | taa | Address access time | | 45 | - | 55 | - | 70 | ns | | TELQV | tacs | Chip Select access time (3) | - | 45 | - | 55 | - | 70 | ns | | TBLQV | tabe | Byte enable access time (3) | - , | 45 | - | 55 | - | 70 | ns | | TGLQV | tace | Output enable access time | _ ( | 25 | - | 30 | - | 35 | ns | | TAVQX | tон | Output hold from address change | 5 | _ | 5 | - | 5 | - | ns | | TELQZ | tιz | Output low Z time (1, 2) | 5 L | ļ _ | 5 | _ | 5 | _ | ns | | TEHQZ | t <sub>HZ</sub> | Output high Z time (1, 2) | _ 2 | 20 | _ | 25 | _ | 30 | ns | | TPU | tpu | Chip Select to power up time (2) | 0 | _ | 0 | - | 0 | _ | ns | | TPD | t <sub>PD</sub> | Chip disable to power down time (2) | _ | 50 | - | 50 | _ | 50 | ns | | TSOP | tsop | SEM flag update pulse<br>(OE or SEM) | 15 | _ | 15 | - | 15 | - | ns | Notes: 1. Transition is measured ± 500 mV from low or high impedance voltage with load (figures 1 and 2) 2. This parameters is guaranteed but not tested 3. To access RAM CS = V<sub>IL</sub>, UB or LB = V<sub>IL</sub>, SEM = V<sub>IH</sub>, To access semaphore CS = V<sub>IH</sub>, SEM = V<sub>IL</sub>. Refer to table 1 4. STD symbol 5. ALT Symbol (\*). Commercial only ## TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE(1, 2, 4) ### TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE(1, 3, 5) ## TIMING WAVEFORM OF READ CYCLE NO. 3, EITHER SIDE (1, 3, 4, 5) Notes: 1. R/W is high for read cycles. 2. Device is continuously enabled, $\overline{CS} = V_L$ , $\overline{UB}$ or $\overline{LB} = V_L$ . This waveform cannot be used for semaphore reads. 3. Addresses valid prior to or coincident with $\overline{CE}$ transition low. 5. To access RAM, $\overline{CS} = V_{IL}$ , $\overline{UB}$ or $\overline{LB} = V_{IL}$ , $\overline{SEM} = V_{IH}$ . To access semaphore, $\overline{CS} = V_{IH}$ , $\overline{SEM} = V_{IL}$ . Refer to table 1. #### **AC PARAMETERS** | WRITE | CYCLE | PARAMETER | L 67024-45 (*) | | L 67024-55 | | L 67024-70 | | LINUT | |------------|------------|-------------------------------------------|----------------|------|------------|------|------------|------|-------| | SYMBOL (5) | SYMBOL (6) | | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | UNIT | | TAVAVW | twc | Write cycle time | 45 | _ | 55 | | 70 | _ | ns | | TELWH | tsw | Chip select to end of write (3) | 40 | _ | 45 | | 50 | - | ns | | TAVWH | taw | Address valid to end of write | 40 | _ | 45 | _ | 50 | _ | ns | | TAVWL | tas | Address Set-up Time | 0 > | _ | 0 | _ | 0 | - | ns | | TWLWH | twp | Write Pulse Width | 35 1 | - | 40 | _ | 45 | - | ns | | TWHAX | twa | Write Recovery Time | 0 ₹ | - | 0 | _ | 0 | _ | ns | | TDVWH | tow | Data Valid to end of write | 30 🗔 | - | 35 | _ | 40 | _ | ns | | TGHQZ | tHZ | Output high Z time (1, 2) | 30 🗒 | 20 | - | 25 | _ | 30 | ns | | TWHDX | ton | Data hold time (4) | 0 | _ | 0 | _ | 0 | - | ns | | TWLQZ | twz | Write enable to output in high Z (1, 2) | _ | 20 | - | 25 | - | 30 | ns | | TWHQX | tow | Output active from end of write (1, 2, 4) | 0 | - | 0 | _ | 0 | - | ns | | TSWRD | tswrp | SEM flag write to read time | 10 | - | 10 | - | 10 | - | ns | | TSPS | tsps | SEM flag contention window | 10 | _ | 10 | _ | 10 | - | ns | Notes: 1. Transition is measured ± 500 mV from low or high impedance voltage with load (figures 1 and 2). This parameters is guaranteed but not tested. To access RAM CS = V<sub>IL</sub>, UB or LB = V<sub>IL</sub>, SEM = V<sub>IH</sub>. To access semaphore CS = V<sub>IH</sub>, SEM = V<sub>IL</sub>. This condition must be valid for entire t<sub>SW</sub> time. time. 4. The specification for to must be met by the device supplying write data to the RAM under all operating conditions. Although to walues will vary over voltage and temperature, the actual to will always be smaller than the actual tow. 5. STD Symbol. ALT symbol. (\*). Commercial only. ## TIMING WAVEFORM OF WRITE CYCLE NO. 1, $R/\overline{W}$ CONTROLLED TIMING<sup>(1, 2, 3, 7)</sup> ## TIMING WAVEFORM OF WRITE CYCLE NO. 2, $\overline{\text{CS}}$ CONTROLLED TIMING<sup>(1, 2, 3, 5)</sup> - Notes: 1. R/W must be high during all adress transitions. - 2. A write occurs during the overlap (tsw or twe) of a low CS or SEM and a low R/W. - 3. twn is measured from the earlier of CS or R/W (or SEM or R/W) going high to the end of write cycle. - 4. During this period, the I/O pins are in the output state, and input signals must not be applied. - 5. If the CS or SEM low transition occurs simultaneously with or after the R/W low transition, the outputs remain in the high impedance state. - 6. Transition is measured ±500 mV from steady state with a 5 pF load (including scope and jig). This parameter is sampled and not 100 % tested. 7. If OE is low during a RW controlled write cycle, the write pulse width must be the larger of two or (twz + tow) to allow the I/O drivers to turn off - and data to be placed on the bus for the required tow. If OE is high during an FWW controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twe. - 8. To access RAM, $\overline{CS} = V_{IL}$ , $\overline{SEM} = V_{IH}$ . 9. To access upper byte $\overline{CS} = V_{IL}$ , $\overline{UB} = V_{IL}$ , $\overline{SEM} = V_{IH}$ . To access lower byte CS = VIL, LB = VIL, SEM = VIH. #### **AC PARAMETERS** | WRITE CYCLE | PARAMETER | L 67024-45 (*) | | L 67024-55 | | L 67024-70 | | UNIT | |------------------|-----------------------------------------|----------------|--------|------------|--------|------------|--------|------| | WHILL CICLE | PARAMETER | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | ONI | | BUSY TIMING (F | or Master 67024 only) | , | | | | | | | | t <sub>BAA</sub> | BUSY Access time to address | _ | 35 | - | 45 | - | 55 | ns | | t <sub>BDA</sub> | BUSY Disable time to address | - | 30 | _ | 40 | _ | 50 | ns | | t <sub>BAC</sub> | BUSY Access time to Chip Select | - | 30 | _ | 40 | _ | 50 | ns | | t <sub>BDC</sub> | BUSY Disable time to Chip Select | - ≿ | 25 | - | 35 | _ | 45 | ns | | t <sub>WDD</sub> | Write Pulse to data Delay (1) | MINAR | 70 | _ | 80 | - | 95 | ns | | topo | Write data valid to read data delay (1) | - € | 55 | _ | 65 | _ | 80 | ns | | taps | Arbitration priority set-up time (2) | 5 급 | - | 5 | - | 5 | - | ns | | t <sub>BDD</sub> | BUSY disable to valid data | - 4 | Note 3 | - | Note 3 | - | Note 3 | ns | | BUSY TIMING (F | or Slave 67024 only) | | | | | | | | | t <sub>WB</sub> | Write to BUSY input (4) | 0 | _ | 0 | - | 0 | - | ns | | twH | Write hold after BUSY (5) | 30 | _ | 35 | - | 35 | _ | ns | | two | Write pulse to data delay (6) | - | 70 | _ | 80 | _ | 95 | ns | | topo | Write data valid to read data delay (6) | - | 55 | - | 65 | - | 80 | ns | Notes: 1. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read with BUSY" (For Master 67024 only)\*. 2. To ensure that the earlier of the two port wins. 3. $t_{BDD}$ is a calculated parameter and is the greater of 0, $t_{WDD}$ - $t_{WP}$ (actual) or $t_{DDD}$ - $t_{DW}$ (actual). 4. To ensure that the write cycle is inhibited during contention. 5. To ensure that a write cycle is completed after contention. 6. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveforms of Read with Port-to-port delay (For Slave, 67024 only)" (\*). Commercial only ## TIMING WAVEFORM OF READ WITH BUSY (2, 3, 4) (FOR MASTER 67024) Notes: 1. To ensure that the earlier of the two port wins 2. Write cycle parameters should be adhered to, to ensure proper writing 3. Device is continuously enabled for both ports 4. OE = L for the reading port ## TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT(1, 2, 3) (FOR SLAVE 67024 ONLY) 1. Assume $\overline{BUSY}$ input = H for the writing port, and $\overline{OE}$ = L for the reading port 2. Write cycle parameters should be adhered to, to ensure proper writing 3. Device is continuously enabled for both ports ### TIMING WAVEFORM OF WRITE WITH BUSY (FOR SLAVE 67024) ## TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{\text{CS}}$ ARBITRATION (FOR MASTER 67024 ONLY) 4 ## TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION (FOR MASTER 67024 ONLY) $^{(1)}$ #### **LEFT ADDRESS VALID FIRST:** #### **RIGHT ADDRESS VALID FIRST:** ## AC PARAMETERS | | т | | | | | | | | |----------------------------|----------------------|----------------|------|------------|------|------------|------|------| | INTERRUPT TIMING<br>SYMBOL | PARAMETER | L 67024-45 (*) | | L 67024-55 | | L 67024-70 | | UNIT | | | | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | ONII | | tas | Address set-up time | 0 ≿ | _ | 0 | _ | 0 | _ | ns | | twn | Write recovery time | 0 2 | - | 0 | _ | 0 | _ | ns | | tins | Interrupt set time | - = | 35 | - | 40 | _ | 55 | ns | | tinr | Interrupt reset time | - & | 35 | _ | 40 | - | 55 | ns | <sup>(\*).</sup> Commercial only. ### WAVEFORM OF INTERRUPT TIMING(1) 1. All timing is the same for left and right ports. Port "A" may be either the left or right port. Port "B" is the port opposite from "A"... - 2. See Interrupt truth table. 3. Timing depends on which enable signal is asserted last. 4. Timing depends on which enable signal is de-asserted first. ## TIMING WAVEFORM OF SEMAPHORE READ AFTER WRITE TIMING, EITHER SIDE(1) **Note:** 1. $\overline{CS} = V_{IH}$ for the duration of the above timing (both write and read cycle). ## TIMING WAVEFORM OF SEMAPHORE CONTENTION(1, 3, 4) Notes: 1. Don = Dot = VIL, $\overrightarrow{CS}_R = \overrightarrow{CS}_L = V_H$ , semaphore Flag is released from both sides (reads as ones from both sides) at cycle start. 2. Either side "A" – left and side "B" – injet, or side "A" – injet and side "B" – left. 3. This parameter is measured from the point where RWA or SEMA goes high until RWs or SEMs goes high. 4. If tass is violated, the semaphore will fall positively to one side or the other, but there is no guaranteed which side will obtain the flag. #### ORDERING INFORMATION