## HIGH-SPEED 64K x 16 BANK-SWITCHABLE DUAL-PORTED SRAM WITH EXTERNAL BANK SELECTS ADVANCED IDT707288S/L ## **FEATURES:** - 64K x 16 Bank-Switchable Dual-Ported SRAM Architecture - Four independent 16K x 16 banks - 1 Megabit of memory on chip - Fast asynchronous address-to-data access time: 20ns - User-controlled input pins included for bank selects - Independent port controls with asynchronous address & data busses - Four 16-bit mailboxes available to each port for interprocessor communications; interrupt option - Interrupt flags with programmable masking - Dual Chip Enables allow for depth expansion without external logic - UB and LB are available for bus matching to x8 or x16 busses; also support very fast banking - TTL-compatible, single 5V (±10%) power supply - Available in a 100-pin Thin Quad Plastic Flatpack (TQFP) and a 108-pin ceramic Pin Grid Array (PGA) ## **DESCRIPTION:** The IDT707288 is a high-speed 64K x 16 (1M bit) Bank-Switchable Dual-Ported SRAM organized into four independent 16K x 16 banks. The device has two independent ports with separate controls, addresses, and I/O pins for each port, allowing each port to asynchronously access any 16K x 16 memory block not already accessed by the other port. Accesses by the ports into specific banks are controlled via bank select pin inputs under the user's control. Mailboxes are provided to allow inter-processor communications. Interrupts are provided to indicate mailbox writes have occurred. An automatic power down feature controlled by the chip enables $(\overline{\text{CE}}\text{o}$ and CE1) permits the on-chip circuitry of each port to enter a very low standby power mode and allows fast depth expansion. The IDT707288 offers a maximum address-to-data access time as fast as 20ns, while typically operating on only 900mW of power, and is available in a 100-pin Thin Quad Plastic Flatpack (TQFP) and a 108-pin ceramic Pin Grid Array (PGA). #### NOTES - 1. The first six address pins for each port serve dual functions. When MBSEL = VIH, the pins serve as memory address inputs. When MBSEL = VIL, the pins serve as mailbox address inputs. - 2. Each bank has an input pin assigned that allows the user to toggle the assignment of that bank between the two ports. Refer to Table I for more details. The IDT logo is a registered trademark of Integrated Device Technology OCTOBER 1996 #### **FUNCTIONALITY:** The IDT707288 is a high-speed asynchronous 64K x 16 Bank-Switchable Dual-Ported SRAM, organized in four 16K x 16 banks. The two ports are permitted independent, simultaneous access into separate banks within the shared array. There are four user-controlled Bank Select input pins , and each of these pins is associated with a specific bank within the memory array. Access to a specific bank is gained by placing the associated Bank Select pin in the appropriate state: VIH assigns the bank to the left port, and VIL assigns the bank to the right port (See Truth Table I). Once a bank is assigned to a particular port, the port has full access to read and write within that bank. Each port can be assigned as many banks within the array as needed, up to and including all four banks. The IDT707288 provides mailboxes to allow inter-processor communications. Each port has four 16-bit mailbox registers available to which it can write and read and which the opposite port can read only. These mailboxes are external to the common SRAM array, and are accessed by setting $\overline{\text{MBSEL}} = \text{VIL}$ while setting $\overline{\text{CE}} = \text{VIH}$ . Each mailbox has an associated interrupt: a port can generate an interrupt to the opposite port by writing to the upper byte of any one of its four 16-bit mailboxes. The interrupted port can clear the interrupt by reading the upper byte. This read will not alter the contents of the mailbox. If desired, any source of interrupt can be independently masked via software. Two registers are provided to permit interpretation of interrupts: the Interrupt Cause Register and the Interrupt Status Register. The Interrupt Cause Register gives the user a snapshot of what has caused the interrupt to be generated - the specific mailbox written to. The information in this register provides post-mask signals: Interrupt sources that have been masked will not be updated. The Interrupt Status Register gives the user the status of all bits that could potentially cause an interrupt regardless of whether they have been masked. Truth Table II gives a detailed explanation of the use of these registers. #### PIN NAMES | A0 - A13 <sup>(1,6)</sup> | Address Inputs | |-----------------------------|---------------------------------| | BA0 - BA1 (1) | Bank Address Inputs | | MBSEL (1) | Mailbox Access Control Gate | | BKSEL <sup>(2)</sup> | Bank Select Inputs | | R/W (1) | Read/Write Enable | | <del>OE</del> (1) | Output Enable | | CE0, CE1 (1) | Chip Enables | | UB, LB (1) | I/O Byte Enables | | I/O0 - I/O15 <sup>(1)</sup> | Bidirectional Data Input/Output | | ĪNT (1) | Interrupt Flag (Output)(3) | | VCC (4) | +5V Power | | GND (5) | Ground | NOTES: 3592 tbl 01 - 1. Duplicated per port. - Each bank has an input pin assigned that allows the user to toggle the assignment of that bank between the two ports. Refer to Table I for more details - 3. Generated upon mailbox access. - 4. All Vcc pins must be connected to power supply. - 5. All GND pins must be connected to ground supply. - 6. The first six address pins for each port serve dual functions. When MBSEL = VIH, the pins serve as bank address or memory address inputs. When MBSEL = VIL, the pins serve as mailbox address inputs. ## PIN CONFIGURATIONS (1,2) ## NOTES: - 1. All Vcc pins must be connected to power supply. - 2. All GND pins must be connected to ground supply. - 3. This text does not indicate orientation of the actual part-marking. ## PIN CONFIGURATIONS (CON'T.) (1,2) | 12 | 81<br>A7R | 80<br>A8R | 77<br>A11R | 74<br>BK<br>SEL3 | 72<br><u>UB</u> R | 69<br>MB<br>SELR | 68<br>GND | 65<br>GND | 63<br>NC | 60<br>I/O13R | 57<br>I/O10R | 54<br>NC | | | | | | | |------|--------------------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------|------------|-----------|--------------|--------------|--------------|-------------------------|--|--|--|--|--|--| | 11 | 84<br>A4R | 83<br>A5R | 78<br>A10R | 76<br>A13R | 73<br>LBR | 70<br>CE1R | 67<br>R/WR | 64<br>GND | 61<br>I/O14R | 59<br>I/O12R | 56<br>I/O9R | 53<br>NC | | | | | | | | 10 | 87<br>A1R | 86<br>A2R | 82<br>A6R | 79<br><b>A</b> 9R | 51<br>I/O8R | 50<br>I/O7R | | | | | | | | | | | | | | 09 | 90<br>BAOR | 88<br>A0R | 85<br>A3R | | | 1 | 52<br>NC | 49<br>Vcc | 47<br>I/O5R | | | | | | | | | | | 08 | 92<br>BK<br>SEL2 | 91<br>A12R | 89<br>BA1R | 48 46 45 I/O4R I/O3R 44 43 42 I/O2R I/O1R I/O0R I/O1R I/O0R I/O1R I/O1 | | | | | | | | | | | | | | | | 07 | 95<br>GND | 94<br>GND | 93<br>INTR | | | | | | | | | | | | | | | | | 06 | 96<br>INTL | 97<br>BK<br>SEL1 | 98<br>NC | 39 40 41 I/O1L I/O0L GND 108-Pin PGA <sup>(3)</sup> Top View 35 37 38 I/O4L I/O2L GND | | | | | | | | | | | | | | | | 05 | 99<br>A12L | 100<br>BA0L | 102<br>A0L | | | | | | | | | | | | | | | | | 04 | 101<br>BA1L | 103<br>A1L | 106<br>A4L | | | | | | | 31<br>Vcc | 34<br>I/O5L | 36<br>I/O3L | | | | | | | | 03 | 104<br>A2L | 105<br>A3L | 1<br>A7L | 4 8 12 17 21 25 28 32<br>A10L BK CE1L GND I/O14L I/O10L NC I/O7L | | | | | | | | | | | | | | | | 02 | 107<br><b>A</b> 5L | 2<br>A8L | 5<br>A11L | 7 10 13 16 19 22 24 29 3 NC UBL MB SELL OEL GND I/O13L I/O11L NC | | | | | | | | | | | | | | | | 01 | 108<br>A6L | 3<br>A9L | 6<br>A13L | 9 | | | | | | | | | | | | | | | | 1 | A | В | С | D | E | F | G | Н | J | K | L | <b>M</b><br>3592 drw 03 | | | | | | | | I ND | ΞX | | | | | | | | | | | | | | | | | | ## NOTES: - All Vcc pins must be connected to power supply. All GND pins must be connected to ground supply. - 3. This text does not indicate orientation of the actual part-marking. ## ASSIGNING THE BANKS VIA THE EXTERNAL BANK SELECTS There are four bank select pins available on the IDT707288, and each of these pins is associated with a specific bank within the memory array. The pins are user-controlled inputs: access to a specific bank is assigned to a particular port by setting the input to the appropriate level. The process of assigning the banks is detailed in Truth Table I. Once a bank is assigned to a port, the owning port has full access to read and write within that bank. The opposite port is unable to access that bank until the user reassigns the port. Access by # TRUTH TABLE I – MEMORY BANK ASSIGNMENT (CE AND/OR R/W = VIH)(2,3) | | | | | BANK AND | |--------|--------|--------|--------|--------------------------| | BKSEL0 | BKSEL1 | BKSEL2 | BKSEL3 | DIRECTION <sup>(1)</sup> | | Н | Х | Х | Х | BANK 0 LEFT | | Х | Н | Х | Х | BANK 1 LEFT | | Х | Х | Н | Х | BANK 2 LEFT | | Х | Х | Х | Н | BANK 3 LEFT | | L | Х | Х | Х | BANK 0 RIGHT | | Х | L | Х | Х | BANK 1 RIGHT | | Х | Х | L | Х | BANK 2 RIGHT | | Х | Х | Х | L | BANK 3 RIGHT | NOTES: 3592 tbl 02 - 1. Bank 0 refers to the first 16Kx16 memory spaces, Bank 1 to the second 16Kx16 memory spaces, Bank 2 to the third 16Kx16 memory spaces, and Bank 3 to the fourth 16Kx16 memory spaces. 'LEFT' indicates the bank is assigned to the left port; 'RIGHT' indicates the bank is assigned to the right port. - 2. The bank select pin inputs must be set at either VIH or VIL these inputs are not tri-statable. When changing the bank select inputs (changing the bank assignments), the device must be write-disabled (CE and/or R/W set to VIH). - 3. 'H' = VIH, 'L' = VIL, 'X' = Don't Care. # MAILBOX INTERRUPTS AND INTERRUPT CONTROL REGISTERS If the user chooses to use the mailbox interrupt function, four mailbox locations are assigned to each port. These mailbox locations are external to the memory array. The mailboxes are accessed by taking MBSEL Low while holding $\overline{\text{CE}}$ High. The mailboxes are 16 bits wide: the message is user-defined since these are addressable SRAM locations. An interrupt is generated to the opposite port upon writing to the upper byte of any mailbox location. A port can read the message it has just written in order to verify it: this read will not alter the status of the interrupt sent to the opposite port. The interrupted port can clear the interrupt by reading the upper byte of the applicable mailbox. This read will not alter the contents of the mailbox. The use of mailboxes to generate interrupts to the opposite port and the reading of mailboxes to clear interrupts is detailed in Truth Table II. If desired, any of the mailbox interrupts can be independently masked via software. Masking of the interrupt sources a port to a bank which it does not control will have no effect if written, and if read unknown values on Do-D15 will be returned. Each port can be assigned as many banks within the array as needed, up to and including all four banks. The bank select pin inputs must be set at either VIH or VIL - these inputs are not tri-statable. When changing the bank select inputs (changing the bank assignments), the device must be write-disabled ( $\overline{CE}$ and/or R/ $\overline{W}$ set to VIH). is done in the Mask Register. The masks are individual and independent: a port can mask any combination of interrupt sources with no effect on the other sources. Each port can modify only its own Mask Register. The use of this register is detailed in Truth Table II. Two registers are provided to permit interpretation of interrupts: these are the Interrupt Cause Register and the Interrupt Status Register. The Interrupt Cause Register gives the user a snapshot of what has caused the interrupt to be generated - a specific semaphore granted to that port or a specific mailbox written to by the opposite port. The information in this register provides post-mask signals: interrupt sources that have been masked will not be updated. The Interrupt Status Register gives the user the status of all bits that could potentially cause an interrupt regardless of whether they have been masked. The use of the Interrupt Cause Register and the Interrupt Status Register is detailed in Truth Table II. ## TRUTH TABLE II - MAILBOX INTERRUPTS (CE = VIH)(8,9) | MB | | | | | | | | | | | | | | | | | | | | | | | | | | | |-----|-----|-----------------|-----------------|-----|-----------|----|-----------|------------|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------------------------------------------| | SEL | R/W | $\overline{UB}$ | $\overline{LB}$ | A5 | <b>A4</b> | А3 | <b>A2</b> | <b>A</b> 1 | Α0 | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | D10 | D11 | D12 | D13 | D14 | D15 | DESCRIPTION | | L | Х | Х | Х | L | L | L | L | L | L | RE | SER | VED | (7) | | | | | | | | | | | | | RESERVED (7) | | L | Х | Х | Х | : | : | : | : | : | : | RE | SER | VED | (7) | | | | | | | | | | | | | RESERVED (7) | | L | (1) | (1) | (1) | Н | L | L | L | L | L | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | MAILBOX 0 - SET INTERRUPT ON OPPOSITE PORT | | L | (1) | (1) | (1) | Н | L | L | L | L | Н | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | MAILBOX 1 - SET INTERRUPT ON OPPOSITE PORT | | L | (1) | (1) | (1) | Н | L | L | L | Н | L | Х | Х | Х | Х | Х | Х | Χ | Х | Х | Х | Х | Х | Χ | Х | Х | Х | MAILBOX 2 - SET INTERRUPT ON OPPOSITE PORT | | L | (1) | (1) | (1) | Н | L | L | L | Н | Н | Х | Х | Χ | Х | Χ | Х | Χ | Х | Х | Χ | Χ | Х | Х | Χ | Х | Х | MAILBOX 3 - SET INTERRUPT ON OPPOSITE PORT | | Æ | Н | (2) | (2) | Н | L | L | Н | L | L | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | MAILBOX 0 - CLEAR OPPOSITE PORT INTERRUPT | | Æ | Н | (2) | (2) | Н | L | L | Н | L | Н | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | MAILBOX 1 - CLEAR OPPOSITE PORT INTERRUPT | | Æ | Н | (2) | (2) | Н | L | L | Н | Н | L | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | MAILBOX 2 - CLEAR OPPOSITE PORT INTERRUPT | | Æ | Н | (2) | (2) | Н | L | L | Н | Н | Н | Х | Х | Х | Х | Х | Х | Х | Χ | Х | Х | Х | Х | Х | Х | Х | Х | MAILBOX 3 - CLEAR OPPOSITE PORT INTERRUPT | | L | (3) | (3) | (3) | Н | L | Н | L | L | L | (4) | (4) | (4) | (4) | (5) | (5) | (5) | (5) | (6) | (6) | (6) | (6) | Х | Х | Х | Х | MAILBOX INTERRUPT CONTROLS | | L | Х | Χ | Х | ••• | : | : | : | : | : | RE | SER | VED | (7) | | | | | | | | | | | | | RESERVED (7) | | L | Χ | Х | Х | Н | Н | Н | Н | Н | Н | RE | SER | VED | (7) | | | | | | | | | | | | | RESERVED (7) | NOTES: 3592 tbl 03 - 1. There are four independent mailbox locations available to each side, external to the standard memory array. The mailboxes can be written to in either 8-bit or 16-bit widths. The upper byte of each mailbox has an associated interrupt to the opposite port. The mailbox interrupts can be individually masked if desired, and the status of the interrupt determined by polling the Interrupt Status Register (see Note 6 for this table). A port can read its own mailboxes to verify the data written, without affecting the interrupt which is sent to the opposite port. - 2. These registers allow a port to read the data written to a specific mailbox location by the opposite port. Reading the upper byte of the data in a particular mailbox clears the interrupt associated with that mailbox without modifying the data written. Once the address and R/W are stable, the actual clearing of the interrupt is triggered by the transition of MBSEL from VIH to VIL. - 3. This register contains the Mask Register (bits D<sub>0</sub>-D<sub>3</sub>), the Interrupt Cause Register (bits D<sub>4</sub>-D<sub>7</sub>), and the Interrupt Status Register (bits D<sub>8</sub>-D<sub>11</sub>). The controls for R/W, UB, and LB are manipulated in accordance with the appropriate function. See Notes 4, 5, and 6 for this table. Bits D<sub>12</sub>-D<sub>15</sub> are "Don't Care". - 4. This register, the Mask Register, allows the user to independently mask the various interrupt sources. Writing V<sub>I</sub>H to the appropriate bit (D<sub>0</sub> = Mailbox 0, D<sub>1</sub> = Mailbox 1, D<sub>2</sub> = Mailbox 2, and D<sub>3</sub> = Mailbox 3) disables the interrupt, while writing V<sub>I</sub>L enables the interrupt. All four bits in this register must be written at the same time. This register can be read at any time to verify the mask settings. The masks are individual and independent: any single interrupt source can be masked with no effect on the other sources. Each port can modify only its own mask settings. - 5. This register, the Interrupt Cause Register, gives the user a snapshot of what has caused the interrupt to be generated. Reading Vol for a specific bit (D4 = Mailbox 0, D5 = Mailbox 1, D6 = Mailbox 2, and D7 = Mailbox 3) indicates that the associated interrupt source has generated an interrupt. Acknowledging the interrupt clears the bit in this register (see Note 2 for this table). This register provides post-mask information: if the interrupt source has been masked, the associated bit in this register will not update. - 6. This register, the Interrupt Status Register, gives the user the status of all interrupt sources that could potentially cause an interrupt regardless of whether they have been masked. Reading Vol for a specific bit (D8 = Mailbox 0, D9 = Mailbox 1, D10 = Mailbox 2, and D11 = Mailbox 3) indicates that the associated interrupt source has generated an interrupt. Acknowledging the interrupt clears the associated bit in this register (see Note 2 for this table). This register provides pre-mask information: regardless of whether an interrupt source has been masked, the associated bit in this register will update. - 7. Access to registers defined as "RESERVED" will have no effect, if written, and if read unknown values on Do-D15 will be returned. - 8. These registers are not guaranteed to initialize in any known state. At power-up, the initialization sequence should include the set-up of these registers. - 9. 'L' = VIL or VOL, 'H' = VIH or VOH, 'X' = Don't Care. ## **ORDERING INFORMATION**