# LANCAM® 1<sup>ST</sup> Family ## **FEATURES AND BENEFITS** - ► Full compatibility among all LANCAM 1<sup>ST</sup> devices, allowing CAM density variations within any application - Full CAM technology for simplicity and speed: one single cycle to find, learn, or delete an entry - > 3.3 volt operation for low power dissipation - Powerful LANCAM instruction set for application flexibility - Partionable CAM/RAM array for associated data storage - Low cost per entry for cost sensitive applications #### DISTINCTIVE CHARACTERISTICS - High density content-addressable memory (CAM) family - > 2K (2481L), 4K (4481L), and 8K (8481L) words - > 64-bit per word memory organization - Fast 100 ns compare speed - > MUSIC's patented CAM/RAM partitioning - Powerful LANCAM instruction set - > 16-bit I/O - > 3.3 volt operation - 44 pin PLCC **Block Diagram** ## **GENERAL DESCRIPTION** The LANCAM 1<sup>ST</sup> family consists of high density contentaddressable memories (CAMs) in a variety of depths. Like the other LANCAM series from MUSIC Semiconductors, the LANCAM 1<sup>ST</sup> is ideal for time critical applications requiring intensive list processing. Content-addressable memories, also known as associative memories, operate in the converse way to random access memories (RAM). In RAM, the input to the device is an address and the output is the data stored at that address. In CAM, the input is a data sample and the output is a flag to indicate a match and the address of the matching data. As a result, CAM searches large databases for matching data in a short, constant time period, no matter how many entries are in the database. The ability to search data words up to 64 bits wide allows large address spaces to be searched rapidly and efficiently. A patented architecture links each CAM entry to associated data and makes this data available for use after a successful compare operation. The MUSIC LANCAM 1<sup>ST</sup> is ideal for address filtering and translation applications in LAN switches and routers. The LANCAM 1<sup>ST</sup> is also well suited to encryption, data caches, and branch tables. #### **OPERATIONAL OVERVIEW** To use the LANCAM 1<sup>ST</sup>, the user loads the data into the Comparand register, which is automatically compared to all valid CAM locations. The device then indicates whether or not one or more of the valid CAM locations contains data that match the target data. The status of each CAM location is determined by two validity bits at each memory location. The two bits are encoded to render four validity conditions: Valid, Skip, Empty, and Random Access, as shown in Table 1. The memory can be partitioned into CAM and associated RAM segments on 16-bit boundaries, but by using one of the two available mask registers, the CAM/RAM partitioning can be set at any arbitrary size between zero and 64 bits. The LANCAM 1<sup>ST</sup>'s internal data path is 64 bits wide for rapid internal comparison and data movement. Loading data to the Control, Comparand, and mask registers automatically triggers a compare. Compares may also be initiated by a command to the device. Associated RAM data is available immediately after a successful compare operation. The Status register reports the results of compares including all flags and addresses. Two Mask registers are available and can be used in two different ways: to mask comparisons or to mask data writes. The random access validity type allows additional masks to be stored in the CAM array where they may be retrieved rapidly. A simple three-wire control interface and commands loaded into the Instruction decoder control the device. A powerful instruction set increases the control flexibility and minimizes software overhead. These and other features make the LANCAM 1<sup>ST</sup> a powerful associative memory that drastically reduces search delays. | Skip Bit | Empty Bit | Entry Type | |----------|-----------|------------| | 0 | 0 | Valid | | 0 | 1 | Empty | | 1 | 0 | Skip | | 1 | 1 | RAM | Table 1: Entry Types vs. Validity Bits | /W | /CM | Cycle Type | |------|------|---------------------| | LOW | LOW | Command Write Cycle | | LOW | HIGH | Data Write Cycle | | HIGH | LOW | Command Read Cycle | | HIGH | HIGH | Data Read Cycle | Table 2: I/O Cycles **Pinout Diagram** #### PIN DESCRIPTIONS All signals are implemented in CMOS technology with TTL levels. Signal names that start with a slash ("/") are active LOW. Inputs should never be left floating. The CAM architecture draws large currents during compare operations, mandating the use of good layout and bypassing techniques. Refer to the Electrical Characteristics section for more information. ## /E (Chip Enable, Input, TTL) The /E input enables the device while LOW. The falling edge registers the control signals /W and /CM. The rising edge turns off the DQ pins and clocks the Destination and Source Segment counters. The four cycle types enabled by /E are shown in Table 2 on page 2. ## /W (Write Enable, Input, TTL) The /W input selects the direction of data flow during a device cycle. /W LOW selects a Write cycle and /W HIGH selects a Read cycle. # /CM (Data/Command Select, Input, TTL) The /CM input selects whether the input signals on DQ15–0 are data or commands. /CM LOW selects Command cycles and /CM HIGH selects Data cycles. ### DQ15-0 (Data Bus, I/O, TTL) The DQ15–0 lines convey data, commands, and status to and from the LANCAM 1<sup>ST</sup>. /W and /CM control the direction and nature of the information that flows to or from the device. When /E is HIGH, DQ15–0 go to Hi-Z. ## /MF (Match Flag, Output, TTL) The /MF output goes LOW when one or more valid matches occur during a compare cycle. /MF is HIGH if there is no match. /MF will be reset when the active configuration register set is changed. ## /FF (Full Flag, Output, TTL) The /FF output goes LOW when no empty memory locations exist within the device. ## /RESET (Reset, Input, TTL) /RESET must be driven LOW to place the device in a known state before operation, which will reset the device to the conditions shown in Table 4 on page 8. The /RESET pin should be driven by TTL levels, not directly by an RC timeout. /E must be kept HIGH during /RESET. #### TEST1, TEST2 (Test, Input, TTL) These pins enable MUSIC production test modes that are not usable in an application. They should be connected to ground, either directly or through a pull-down resistor, or they may be left unconnected. These pins may not be implemented on all versions of these products. ### VCC, GND (Positive Power Supply, Ground) These pins are the power supply connections to the LANCAM 1<sup>ST</sup>. VCC must meet the voltage supply requirements in the Operating Conditions section relative to the GND pins, which are at 0 Volts (system reference potential), for correct operation of the device. All the ground and power pins must be connected to their respective planes with adequate bulk and high frequency bypassing capacitors in close proximity to the device. #### **FUNCTIONAL DESCRIPTION** The LANCAM 1<sup>ST</sup> is a content-addressable memory (CAM) with 16-bit I/O for network address filtering and translation, virtual memory, data compression, caching, and table lookup applications. The memory consists of static CAM, organized in 64-bit data fields. Each data field can be partitioned into a CAM and a RAM subfield on 16-bit boundaries. The contents of the memory can be randomly accessed or associatively accessed by the use of a compare. During automatic comparison cycles, data in the Comparand register is automatically compared with the "Valid" entries in the memory array. The Device ID can be read using a TCO PS instruction (see Table 11 on page 16). The data inputs and outputs of the LANCAM 1ST are multiplexed for data and instructions over a 16-bit I/O bus. Internally, data is handled on a 64-bit basis, since the Comparand register, the mask registers, and each memory entry are 64 bits wide. Memory entries are globally configurable into CAM and RAM segments on 16-bit boundaries, as described in US Patent 5,383,146 assigned to MUSIC Semiconductors. Seven different CAM/RAM splits are possible, with the CAM width going from one to four segments, and the remaining RAM width going from three to zero segments. Finer resolution on compare width is possible by invoking a mask register during a compare, which does global masking on a bit basis. The CAM subfield contains the associative data, which enters into compares, while the RAM subfield contains the associated data, which is not compared. In LAN bridges, the RAM subfield could hold, for example, port-address and aging information related to the destination or source address information held in the CAM subfield of a given location. In a translation application, the CAM field could hold the dictionary entries, while the RAM field holds the translations, with almost instantaneous response. Each entry has two validity bits (known as Skip bit and Empty bit) associated with it to define its particular type: empty, valid, skip, or RAM. When data is written to the active Comparand register, and the active Segment Control register reaches its terminal count, the contents of the Comparand register are automatically compared with the CAM portion of all the valid entries in the memory array. For added versatility, the Comparand register can be barrel-shifted right or left one bit at a time. A Compare instruction can then be used to force another compare between the Comparand register and the CAM portion of memory entries of any one of the four validity types. After a Read or Move from Memory operation, the validity bits of the location read or moved will be copied into the Status register, where they can be read using Command Read cycles. Data can be moved from one of the data registers (CR, MR1, or MR2) to a memory location that is based on the results of the last comparison (Highest-Priority Match or Next Free), or to an absolute address, or to the location pointed to by the active Address register. Data can also be written directly to the memory from the DQ bus using any of the above addressing modes. The Address register may be directly loaded and may be set to increment or decrement, allowing DMA-type reading or writing from memory. Two sets of configuration registers (Control, Segment Control, Address, Mask Register 1, and Persistent Source and Destination) are provided to permit rapid context switching between foreground and background activities. The currently active set of configuration registers control writes, reads, moves, and compares. The foreground set would typically be pre-loaded with values useful for comparing input data, often called filtering, while the background set would be pre-loaded with values useful for housekeeping activities such as purging old entries. Moving from the foreground task of filtering to the background task of purging can be done by issuing a single instruction to change the current set of configuration registers. The match condition of the device is reset whenever the active register set is changed. The active Control register determines the operating conditions within the device. Conditions set by this register's contents are reset, CAM/RAM partitioning, disable or select masking conditions, and disable or select auto-incrementing or -decrementing the Address register. The active Segment Control register contains separate counters to control the writing of 16-bit data segments to the selected persistent destination, and to control the reading of 16-bit data segments from the selected persistent source. There are two active mask registers at any one time, which can be selected to mask comparisons or data writes. Mask Register 1 has both a foreground and background mode to support rapid context switching. Mask Register 2 does not have this mode, but can be shifted left or right one bit at a time. For masking comparisons, data stored in the active selected mask register determines which bits of the comparand are ## **FUNCTIONAL DESCRIPTION Continued** compared against the valid contents of the memory. If a bit is set HIGH in the mask register, the same bit position in the Comparand register becomes a "don't care" for the purpose of the comparison with all the memory locations. During a Data Write cycle or a MOV instruction, data in the specified active mask register can also determine which bits in the destination will be updated. If a bit is HIGH in the mask register, the corresponding bit of the destination is unchanged. The match line associated with each memory address is fed into a priority encoder where multiple responses are resolved, and the address of the highest-priority responder (the lowest numerical match address) is generated. In LAN applications, a multiple response might indicate an error. In other applications the existence of multiple responders may be valid. Three input control signals and commands loaded into an instruction decoder control the LANCAM 1<sup>ST</sup>. Two of the three input control signals determine the cycle type. The control signals tell the device whether the data on the I/O bus represents data or a command, and is input or output. Commands are decoded by instruction logic and control moves, forced compares, validity bit manipulations, and the data path within the device. Registers (Control, Segment Control, Address, Next Free Address, etc.) are accessed using Temporary Command Override instructions. The data path from the DQ bus to/from data resources (comparand, masks, and memory) within the device are set until changed by Select Persistent Source and Destination instructions. After a Compare cycle (caused by either a data write to the Comparand or mask registers, a write to the Control register, or a forced compare), the status register contains the address of the Highest-Priority Matching location, along with flags indicating match, multiple match, and full. The /MF and /FF flags are also available directly on output pins. #### OPERATIONAL CHARACTERISTICS Throughout the following, "aaaH" represents a three-digit hexadecimal number "aaa," while "bbB" represents a two-digit binary number "bb." All memory locations are written to or read from in 16-bit segments. Segment 0 corresponds to the lowest order bits (bits 15–0) and Segment 3 corresponds to the highest order bits (bits 63–48). ## THE CONTROL BUS Refer to the Block Diagram on page 1 for the following discussion. The inputs Chip Enable (/E), Write Enable (/W), and Command Enable (/CM) are the primary control mechanism for the LANCAM 1<sup>ST</sup>. Instructions are the secondary control mechanism. Logical combinations of the Control Bus inputs, coupled with the execution of Select Persistent Source (SPS), Select Persistent Destination (SPD), and Temporary Command Override (TCO) instructions allow the I/O operations to and from the DQ15–0 lines to the internal resources, as shown in Table 3 on page 7. The Comparand register is the default source and destination for Data Read and Write cycles. This default state can be overridden independently by executing a Select Persistent Source or Select Persistent Destination instruction, selecting a different source or destination for data. Subsequent Data Read or Data Write cycles will access that source or destination until another SPS or SPD instruction is executed. The currently selected persistent source or destination can be read back through a TCO PS or PD instruction. The sources and destinations available for persistent access are those resources on the 64-bit bus: Comparand register, Mask Register 1, Mask Register 2, and the Memory array. The default destination for Command Write cycles is the Instruction decoder, while the default source for Command Read cycles is the Status register. Temporary Command Override (TCO) instructions provide access to the Control register, the Segment Control register, the Address register, and the Next Free Address register. TCO instructions are only active for one Command Read or Write cycle after being loaded into the Instruction decoder. The data and control interfaces to the LANCAM 1<sup>ST</sup> are synchronous. During a Write cycle, the Control and Data inputs are registered by the falling edge of /E. When writing to the persistently selected data destination, the Destination Segment counter is clocked by the rising edge of /E. During a Read cycle, the Control inputs are registered by the falling edge of /E, and the Data outputs are enabled while /E is LOW. When reading from the persistently selected data source, the Source Segment counter is clocked by the rising edge of /E. #### THE REGISTER SET The Control, Segment Control, Address, Mask Register 1, and the Persistent Source and Destination registers are duplicated, with one set termed the Foreground set, and the other the Background set. The active set is chosen by issuing Select Foreground Registers or Select Background Registers instructions. By default, the Foreground set is active after a reset. Having two alternate sets of registers that determine the device configuration allows for a rapid return to a foreground network filtering task from a background housekeeping task. Writing a value to the Control register or writing data to the last segment of the Comparand or either mask register will cause an automatic comparison to occur between the contents of the Comparand register and the words in the CAM segments of the memory marked valid, masked by MR1 or MR2 if selected in the Control register. #### Instruction Decoder The Instruction decoder is the write-only decode logic for instructions and is the default destination for Command Write cycles. If an instruction's Address Field flag (bit 11) is set to a 1, it is a two-cycle instruction that is not executed immediately. For the next cycle only, the data from a Command Write cycle is loaded into the Address register and the instruction then completes at that address. The Address register will then increment, decrement, or stay at the same value depending on the setting of Control Register bits CT3 and CT2. If the Address Field flag is not set, the memory access occurs at the address currently contained in the Address register. ## **Control Register (CT)** The Control register is composed of a number of switches that configure the LANCAM 1<sup>ST</sup>, as shown in Table 7 on page 15. It is written or read using a TCO CT instruction. If bit 15 of the value written during a TCO CT is a 0, the device is reset (and all other bits are ignored). See Table 4 for the Reset states. Bit 15 always reads back as a 0. A write to the Control register causes an automatic compare to occur (except in the case of a reset). Either the Foreground or Background Control register will be active, depending on which register set has been selected, and only the active Control register will be written to or read from. Control Register bits 8–6 control the CAM/RAM partitioning. The CAM portion of each word may be sized from a full 64 bits down to 16 bits in 16-bit increments. The RAM portion can be at either end of the 64-bit word. Compare masks may be selected by bits 5 and 4. Mask Register 1, Mask Register 2, or neither may be selected to mask compare operations. The address register behavior is controlled by bits 3 and 2, and may be set to increment, decrement, or neither after a memory access. ## Segment Control Register (SC) The Segment Control register, as shown in Table 8 on page 16, is accessed using a TCO SC instruction. On read cycles, D15, D10, D5, and D2 will always read back as 0s. Either the Foreground or Background Segment Control register will be active, depending on which register set has been selected, and only the active Segment Control register will be written to or read from. The Segment Control register contains dual independent incrementing counters with limits, one for data reads and one for data writes. These counters control which 16-bit segment of the 64-bit internal resource is accessed during a particular data cycle on the 16-bit data bus. The actual destination for data writes and source for data reads (called the persistent destination and source) are set independently with SPD and SPS instructions, respectively. Each of the two counters consists of a start limit, an end limit, and the current count value that points to the segment to be accessed on the next data cycle. The current count value can be set to any segment, even if it is outside the range set by the start and end limits. The counters count up from the current count value to the end limit and then jump back to the start limit. If the current count is greater than the end limit, the current count value will increment to 3, then roll over to 0 and continue incrementing until the end limit is reached; it then jumps back to the start limit. If a sequence of data writes or reads is interrupted, the Segment Control register can be reset to its initial start limit values by using an RSC instruction. After the LANCAM 1<sup>ST</sup> is reset, both Source and Destination counters are set to count from Segment 0 to Segment 3 with an initial value of 0. #### Address Register (AR) The Address register points to the CAM memory location to be operated upon when M@[AR] or M@aaaH is part of the instruction. It can be loaded directly by using a TCO AR instruction or indirectly by using an instruction requiring an absolute address, such as MOV aaaH, CR, V. After being loaded, the Address register value will then be used for the next memory access referencing the Address register. A reset sets the Address register to zero. | Cycle Type | Æ | /CM | /W | I/O Status | SPS | SPD | тсо | Operation | Notes | |------------|---|-----|----|------------|-----|-----|----------|-----------------------------------------------|-------| | Cmd Write | L | L | L | IN | | | | Load Instruction decoder | 1 | | | | | | IN | | | ✓ | Load Address register | 2,3 | | | | | | IN | | | ✓ | Load Control register | 3 | | | | | | IN | | | ✓ | Load Segment Control register | 3 | | Cmd Read | Г | L | Н | OUT | | | <b>✓</b> | Read Next Free Address register | 3 | | | | | | OUT | | | ✓ | Read Address register | 3 | | | | | | OUT | | | | Read Status Register bits 15-0 | 4 | | | | | | OUT | | | | Read Status Register bits 31-16 | 5 | | | | | | OUT | | | ✓ | Read Control register | 3 | | | | | | OUT | | | ✓ | Read Segment Control register | 3 | | | | | | OUT | | | ✓ | Read Current Persistent Source or Destination | 3,10 | | Data Write | L | Н | L | IN | | ✓ | | Load Comparand register | 6,9 | | | | | | IN | | ✓ | | Load Mask Register 1 | 7,9 | | | | | | IN | | ✓ | | Load Mask Register 2 | 7,9 | | | | | | IN | | ✓ | | Write Memory Array at address | 7,9 | | | | | | IN | | ✓ | | Write Memory Array at Next Free address | 7,9 | | | | | | IN | | ✓ | | Write Memory Array at Highest-Priority match | 7,9 | | Data Read | L | Н | Н | OUT | ✓ | | | Read Comparand register | 6, 9 | | | | | | OUT | ✓ | | | Read Mask Register 1 | 8, 9 | | | | | | OUT | ✓ | | | Read Mask Register 2 | 8, 9 | | | | | | OUT | ✓ | | | Read Memory Array at address | 8, 9 | | | | | | OUT | ✓ | | | Read Memory Array at Highest-Priority match | 7, 8 | | | Ι | Х | Χ | HIGH-Z | | | | Deselected | | #### Notes: - 1. Default Command Write cycle destination (does not require a TCO instruction). - 2. Default Command Write cycle destination (no TCO instruction required) if Address Field flag was set in bit 11 of the instruction loaded in the previous cycle. - 3. Loaded or read on the Command Write or Read cycle immediately following a TCO instruction. Active for one Command Write or Read cycle only. NFA register cannot be loaded this way. - 4. Default Command Read cycle source (does not require a TCO instruction). - Default Command Read cycle source (does not require a TCO instruction) if the previous cycle was a Command Read of Status Register bits 15–0. If next cycle is not a Command Read cycle, any subsequent Command Read cycle will access the Status Register bits 15–0. - Default persistent source and destination on power-up and after Reset. If other resources were sources or destinations, SPD CR or SPS CR restores the Comparand register as the destination or source. - 7. Selected by executing a Select Persistent Destination instruction. - 8. Selected by executing a Select Persistent Source instruction. - Access may require multiple 16-bit Read or Write cycles. The Segment Control register is used to control the selection of the desired 16-bit segment(s) by establishing the Segment counters' start and end limits and count values. - 10. A Command Read cycle after a TCO PS or TCO PD reads back the Instruction decoder bits that were last set to select a persistant source or destination. The TCO PS instruction will also read back the Device ID. ## **Table 3: Input/Output Operations** Control Register bits CT3 and CT2 set the Address register to automatically increment or decrement (or not change) during sequences of Command or Data cycles. The Address register will change after executing an instruction that includes M@[AR] or M@aaaH, or after a data access to the end limit segment (as set in the Segment Control register) when the persistent source or destination is M@[AR] or M@aaaH. Either the Foreground or Background Address register will be active, depending on which register set has been selected, and only the active Address register will be written to or read from. #### **Next Free Address Register (NF)** The LANCAM 1<sup>ST</sup> automatically stores the address of the first empty memory location in the Next Free Address register, which is then used as a memory address pointer for M@NF operations. The Next Free Address register, shown in Table 9 on page 16, can be read using a TCO NF instruction. After a reset, the Next Free Address register is set to zero. | CAM Status | After /RESET Is Asserted or Software Reset | |-------------------------------------------------------------|--------------------------------------------| | Validity bits at all memory locations | Skip = 0, Empty = 1 (empty) | | CAM/RAM Partitioning | 64 bits CAM, 0 bits RAM | | Comparison Masking | Disabled | | Address register auto-increment or -decrement | Disabled | | Source and Destination Segment counters count ranges | 00B to 11B; loaded with 00B | | Address register and Next Free Address register | Contains all 0s | | Control register after reset (including CT15) | Contains 0008H | | Persistent Destination for Command writes | Instruction decoder | | Persistent Source for Command reads | Status register | | Persistent Source and Destination for Data reads and writes | Comparand register | | Configuration Register set | Foreground | **Table 4: Device Control State after Reset** ## **Status Register** The 32-bit Status register, as shown in Table 10 on page 16, is the default source for Command Read cycles. Bit 31 is the internal Full flag, which will go LOW if there are no empty memory locations. Bit 30 is the internal Multiple Match flag, which will go LOW if a Multiple match was detected. Bits 29 and 28 are the Skip and Empty Validity bits, which reflect the validity of the last memory location read. After a reset, the Skip and Empty bits will read 11 until a read or move from memory has occurred. The rest of the Status register down to bit 1 contains the address of the Highest-Priority match. After a reset or a no-match condition, the match address bits will be all 1s. Bit 0 is the internal Match flag, which will go LOW if a match was found. ## **Comparand Register (CR)** The 64-bit Comparand register is the default destination for data writes and reads, using the Segment Control register to select which 16-bit segment of the Comparand register is to be loaded or read out. The persistent source and destination for data writes and reads can be changed to the mask registers or memory by SPS and SPD instructions. During an automatic or forced compare, the Comparand register is simultaneously compared against the CAM portion of all memory locations with the correct validity condition. Automatic compares always compare against valid memory locations, while forced compares, using CMP instructions, can compare against memory locations tagged with any specific validity condition. The Comparand register may be shifted one bit at a time to the right or left by issuing a Shift Right or Shift Left instruction, with the right and left limits for the wrap-around determined by the CAM/RAM partitioning set in the Control register. During shift rights, bits shifted off the LSB of the CAM partition will reappear at the MSB of the CAM partition. Likewise, bits shifted off the MSB of the CAM partition will reappear at the LSB during shift lefts. ## Mask Registers (MR1, MR2) The Mask registers can be used in two different ways, either to mask compares or to mask data writes and moves. Either mask register can be selected in the Control register to mask every compare, or selected by instructions to participate in data writes or moves to and from memory. If a bit in the selected mask register is set to a 0, the corresponding bit in the Comparand register will enter into a masked compare operation. If a Mask bit is a 1, the corresponding bit in the Comparand register will not enter into a masked compare operation. Bits set to 0 in the mask register cause corresponding bits in the destination register or memory location to be updated when masking data writes or moves, while a bit set to 1 will prevent that bit in the destination from being changed. Either the Foreground or Background MR1 can be set active, but after a reset, the Foreground MR1 is active by default. MR2 incorporates a sliding mask, where the data can be replicated one bit at a time to the right or left with no wrap-around by issuing a Shift Right or Shift Left instruction. The right and left limits are determined by the CAM/RAM partitioning set in the Control register. For a Shift Right the upper limit bit is replicated to the next lower bit, while for a Shift Left the lower limit bit is replicated to the next higher bit. ## THE MEMORY ARRAY #### **Memory Organization** The Memory array is organized into 64-bit words with each word having an additional two validity bits (Skip and Empty). By default, all words are configured to be 64 CAM cells. However, bits 8–6 of the Control register can divide each word into a CAM field and a RAM field. The RAM field can be assigned to the least-significant or most-significant portion of each entry. The CAM/RAM partitioning is allowed on 16-bit boundaries, permitting selection of the configuration shown in Table 7 on page 15, bits 8–6 (e.g., 001 sets the 48 MSBs to CAM and the 16 LSBs to RAM). Memory Array bits designated as RAM can be used to store and retrieve data associated with the CAM content at the same memory location. ## **Memory Access** There are two general ways to get data into and out of the memory array: directly or by moving the data via the Comparand or mask registers. The first way, through direct reads or writes, is set up by issuing a Set Persistent Destination (SPD) or Set Persistent Source (SPS) command. The addresses for the direct access can be directly supplied; supplied from the Address register, supplied from the Next Free Address register, or supplied as the Highest-Priority Match address. Additionally, all the direct writes can be masked by either mask register. The second way is to move data via the Comparand or mask registers. This is accomplished by issuing Data Move commands (MOV). Moves using the Comparand register can also be masked by either of the mask registers. ## I/O CYCLES The LANCAM $1^{\rm ST}$ supports four basic I/O cycles: Data Read, Data Write, Command Read, and Command Write. The type of cycle is determined by the states of the /W and /CM control inputs. These signals are registered at the beginning of a cycle by the falling edge of /E. Table 2 on page 2 shows how the /W and /CM lines select the cycle type. During Read cycles, the DQ15–0 outputs are enabled after /E goes LOW. During Write cycles, the data or command to be written is captured from DQ15–0 at the beginning of the cycle by the falling edge of /E. Figures 1 and 2 show Read and Write cycles respectively. Figure 3 shows typical cycle-to-cycle timing with the Match flag valid at the end of the Comparand Write cycle. Data writes and reads to the comparand, mask registers, or memory occur in one to four 16-bit cycles, depending on the settings in the Segment Control register. The Compare operation automatically occurs during Data writes to the Comparand or mask registers when the destination segment counter reaches the end count set in the Segment Control register. If there was a match, the second cycle reads status or associated data, depending on the state of /CM. The minimum timings for the /E control signal are given in the Switching Characteristics section on page 18. Note that at minimum timings the /E signal is non-symmetrical, and that different cycle types have different timing requirements, as given in Table 6 on page 15. ## **COMPARE OPERATIONS** During a Compare operation, the data in the Comparand register is compared to all locations in the Memory array simultaneously. Any mask register used during compares must be selected beforehand in the Control register. There are two ways compares are initiated: Automatic and Forced compares. Automatic compares perform a compare of the contents of the Comparand register against Memory locations that are tagged as "Valid," and occur whenever the following happens: - ➤ The Destination Segment counter in the Segment Control register reaches its end limit during writes to the Comparand or mask registers. - After a command write of a TCO CT is executed (except for a software reset), so that a compare is executed with the new settings of the Control register. Forced compares are initiated by CMP instructions using one of the four validity conditions, V, R, S, and E. The forced compare against "Empty" locations automatically masks all 64 bits of data to find all locations with the validity bits set to "Empty," while the other forced compares are only masked as selected in the Control register. #### INITIALIZING THE LANCAM 1ST Initialization of the LANCAM 1<sup>ST</sup> is required to configure the various registers on the device. Since a Control register reset establishes the operating conditions shown in Table 4 on page 8, restoration of operating conditions better suited for the application may be required after a reset, whether using the Control Register reset or the /RESET pin. When the device powers up, the memory and registers are in an unknown state, so the /RESET pin must be asserted to place the device in a known state. Figure 1: Read Cycle Figure 2: Write Cycle Figure 3: Cycle to Cycle Timing Example | Cycle Type | Opcode | Co | ntrol I | Bus | Comments | Notes | |---------------|-----------|----|---------|-----|--------------------------------------------------------------------------------|-------| | | on DQ Bus | /E | /CM | /W | | | | Command read | | L | L | Н | Clears power-up anomalies | | | Command write | TCOCT | L | L | L | Target Control register for reset | | | Command write | 0000H | L | L | L | Causes reset | 1 | | Command write | TCOCT | L | L | L | Target Control register for initial values | | | Command write | 8040H | L | L | L | Control Register value | 2 | | Command write | TCOSC | L | L | L | Target Segment Counter Control register | | | Command write | 3808H | L | L | L | Set Segment counters to write to Segment 1, 2, and 3, and read from Segment 0. | | | Command write | SPS M@HM | L | L | L | Set Data Reads from Segment 0 of the Highest-priority match | | | | | | | | | | #### Notes: - 1. A software reset using a TCO CT followed by 0000H puts the device in a known state. Good programming practice dictates a software reset for initialization to account for all possible conditions. - 2. A typical LANCAM 1<sup>ST</sup> control environment: 48 CAM bits, 16 RAM bits; Disable comparison masking; and Enable address increment. See Table 7 on page 15 for Control Register Bit assignments. **Table 5: Example Initialization Routine** #### **INSTRUCTION SET DESCRIPTIONS\*** Instruction: Select Persistent Source (SPS) Binary Op-Code: 0000 f000 0000 0sss f Address Field flag† sss Selected source This instruction selects a persistent source for data reads, until another SPS instruction changes it or a reset occurs. The default source after reset for Data Read cycles is the Comparand register. Setting the persistent source to M@aaaH loads the Address register with "aaaH" and the first access to that persistent source will be at aaaH, after which the AR value increments or decrements as set in the Control register. The SPS M@[AR] instruction does the same except the current Address Register value is used. Instruction: Select Persistent Destination (SPD) Binary Op-Code: 0000 f001 mmdd dvvv f Address Field flag† mm Mask Register select ddd Selected destination vvv Validity setting for Memory Location destinations This instruction selects a persistent destination for data writes, which remains until another SPD instruction changes it or a reset occurs. The default destination for Data Write cycles is the Comparand register after a reset. When the destination is the Comparand register or the memory array, the data written may be masked by either Mask Register 1 or Mask Register 2, so that only destination bits corresponding to bits in the mask register set to 0 will be modified. An automatic compare will occur after writing the last segment of the Comparand or mask registers, but not after writing to memory. Setting the persistent destination to M@aaaH loads the Address register with aaaH, and the first access to that persistent destination will be at aaaH, after which the AR value increments or decrements as set in the Control register. The SPD M@[AR] instruction does the same except the current Address Register value is used. Instruction: Temporary Command Override (TCO) Binary Op-Code: 0000 0010 00dd d000 ddd Register selected as source or destination for only the next Command Read or Write cycle The TCO instruction selects a register as the source or destination for only the next Command Read or Write cycle, so a value can be loaded or read out of the register. Subsequent Command Read or Write Cycles revert to reading the Status register and writing to the Instruction decoder. All registers but the NF, PS, and PD can be written to, and all can be read from. The Status register is only available via non-TCO Command Read cycles. Reading the PS register also outputs the Device ID on bits 15–4 as shown in Table 11 on page 16. #### INSTRUCTION SET DESCRIPTIONS\* Continued Instruction: Data Move (MOV) Binary Op-Code: 0000 f011 mmdd dsss or 0000 f011 mmdd dvss f Address Field flag† mm Mask Register select ddd Destination of data sss Source of data v Validity setting if destination is a **Memory location** The MOV instruction performs a 64-bit move of the data in the selected source to the selected destination. If the source or destination is aaaH, the Address register is set to aaaH. For MOV instructions to or from aaaH or [AR], the Address register will increment or decrement from that value after the move completes, as set in the Control register. Data transfers between the Memory array and the Comparand register may be masked by either Mask Register 1 or Mask Register 2, in which case, only those bits in the destination which correspond to bits in the selected mask register set to 0 will be changed. A Memory location used as a destination for a MOV instruction may be set to Valid or left unchanged. If the source and destination are the same register, no net change occurs (a NOP). Instruction: Validity Bit Control (VBC) Binary Op-Code: 0000 f100 00dd dvvv f Address Field flag† ddd Destination of data vvv Validity setting for Memory location The VBC instruction sets the Validity bits at the selected memory locations to the selected state. This feature can be used to find all valid entries by using a repetitive sequence of CMP V through a mask of all 1s followed by a VBC HM, S. If the VBC target is aaaH, the Address register is set to aaaH. For VBC instructions to or from aaaH or [AR], the Address register will increment or decrement from that value after the operation completes, as set in the Control register. Instruction: Compare (CMP) Binary Op-Code: 0000 0101 0000 0vvv vvv Validity condition A CMP V, S, or R instruction forces a Comparison of Valid, Skipped, or Random entries against the Comparand register through a mask register, if one is selected. During a CMP E instruction, the compare is only done on the Validity bits and all data bits are automatically masked. Instruction: Special Instructions Binary Op-Code: 0000 0110 00dd drrr ddd Target resource rrr Operation Two alternate sets of configuration registers can be selected by using the Select Foreground and Select Background Registers instructions. These registers are the Control, Segment Control, Address, Mask Register 1, and the PS and PD registers. An RSC instruction resets the Segment Control register count values for both the Destination and Source counters to the original Start limits. The Shift instructions shift the designated register one bit right or left. The right and left limits for shifting are determined by the CAM/RAM partitioning set in the Control register. The Comparand register is a barrel-shifter, and for the example of a device set to 64 bits of CAM executing a Shift Comparand Right instruction, bit 0 is moved to bit 63, bit 1 is moved to bit 0, and bit 63 is moved to bit 62. For a Shift Comparand Left instruction, bit 63 is moved to bit 0, bit 0 is moved to bit 1, and bit 62 is moved to bit 63. MR2 acts as a sliding mask, where for a Shift Right instruction bit 1 is moved to bit 0, while bit 0 "falls off the end," and bit 63 is replicated to bit 62. For a Shift Mask Left instruction, bit 0 is replicated to bit 1, bit 62 is moved to bit 63, and bit 63 "falls off the end." With shorter width CAM fields, the bit limits on the right or left move to match the width of CAM field. ### Notes: \* Instruction cycle lengths given in Table 6 on page 15. † If f = 1, the instruction requires an absolute address to be supplied on the following cycle as a Command write. The value supplied on the second cycle will update the address register. After operations involving M@[AR] or M@aaaH, the Address register will be incremented or decremented depending on the setting in the Control register. # **INSTRUCTION SET SUMMARY** | | INSTRU | JCTION | SET SUMMARY | | | |-------------------------------------------------------|----------------------------------------|-----------------|-------------------------------------------------|------------------------------------|---------------------------| | _ | IC FORMAT<br>rc[msk],val | | Instruction: Select Pers | | n <i>Cont.</i><br>Op-Code | | into dot,o | o[mok],var | | Operation | Mnemonic | 012DH | | INS: Instruction mnemonic | | | Mem. at Highest-Prio. Match, Emp. Masked by MR1 | SPDM@HM[MR1],E | 012DH<br>016DH | | dst: Destination of the data | | | Masked by MR2 | SPD M@HM[MR2],E | 01ADH | | src: Source of the data | <b>a</b> | | Wasked by Wikz | Or Divier invitor (2),2 | OIABIT | | | | | Mem. at Highest-Prio. Match, Skip | SPDM@HM,S | 012EH | | msk: Mask register used | | | Masked by MR1 | SPD M@HM[MR1],S | 016EH | | val: Validity condition set a | it the location written | | Masked by MR2 | SPD M@HM[MR2],S | 01AEH | | | | | Mem. at HighPrio. Match, Randon | SDD M@HM P | 012FH | | Instruction: Select Pers | | | Masked by MR1 | SPD M@HM[MR1],R | 016FH | | Operation | | )p-Code | Masked by MR2 | SPDM@HM[MR2],R | 01AFH | | Comparand Register | SPS CR | 0000H | | | | | Mask Register 1 | SPS MR1 | 0001H | Mem. at Next Free Addr., Valid | • | 0134H | | Mask Register 2 | SPS MR2 | 0002H | Masked by MR1 | SPD M@NF[MR1],V | 0174H | | Memory Array at Addr. Reg.<br>Memory Array at Address | SPS M@[AR]<br>SPS M@aaaH | 0004H<br>0804H | Masked by MR2 | SPD M@NF[MR2],V | 01B4H | | Mem. at Highest-Prio. Match | SPS M@HM | 0004H | Mars at Nort Fron Addr. Frank. | CDDM@NEE | 040511 | | Welli. at Highest The Water | OI OIVI©I IIVI | 000311 | Mem. at Next Free Addr., Empty | | 0135H | | | | | Masked by MR1 Masked by MR2 | SPD M@NF[MR1],E<br>SPD M@NF[MR2],E | 0175H<br>01B5H | | Instruction: Select Pers | istent Destination | | Wasked by Witz | Of Division [ivit 2],E | 010011 | | Operation | Mnemonic C | p-Code | Mem. at Next Free Addr., Skip | SPD M@NF,S | 0136H | | Comparand Register | SPDCR | 0100H | Masked by MR1 | SPD M@NF[MR1],S | 0176H | | Masked by MR1 | SPD CR[MR1] | 0140H | Masked by MR2 | SPD M@NF[MR2],S | 01B6H | | Masked by MR2 | SPD CR[MR2] | 0180H | | | | | L | 000 140 4 | 040011 | Mem. at Next Free Addr., Random | | 0137H | | Mask Register 1 | SPD MR1 | 0108H | Masked by MR1 | SPD M@NF[MR1],R | 0177H | | Mask Register 2 Mem. at Addr. Reg. set Valid | SPD MR2<br>SPD M@[AR],V | 0110H<br>0124H | Masked by MR2 | SPD M@NF[MR2],R | 01B7H | | Masked by MR1 | SPDM@[AR][MR1],V | 012411<br>0164H | Instruction, Tomperory | Command Over | ida | | Masked by MR2 | SPD M@[AR][MR2],V | 01A4H | Instruction: Temporary | | | | Wasked by Witz | Of Divisiphing[wintz],v | O I A | Operation | Mnemonic | Op-Code | | Mem. at Addr. Reg. set Empty | SPD M@[AR],E | 0125H | Control Register | TCO CT | 0200H | | Masked by MR1 | SPD M@[AR][MR1],E | 0165H | Segment Control Register | TCO SC | 0210H | | Masked by MR2 | SPD M@[AR][MR2],E | 01A5H | Read Next Free Address Address Register | TCO NF<br>TCO AR | 0218H<br>0220H | | | 000 140/4010 | 040011 | Read Persistent Source | TCOPS | 0230H | | Mem. at Addr. Reg. set Skip | SPD M@[AR],S | 0126H | Read Persistent Destination | TCOPD | 0238H | | Masked by MR1<br>Masked by MR2 | SPD M@[AR][MR1],S<br>SPD M@[AR][MR2],S | 0166H<br>01A6H | Trodu i Grototom Dodinianom | .00.2 | 0200 | | Wasked by WINZ | 3FD WW[AN][WNZ],3 | UTAGIT | Instruction: Data Move | | | | Mem. at Addr. Reg. set Random | SPD M@[AR].R | 0127H | Operation | Mnemonic | Op-Code | | Masked by MR1 | SPD M@[AR][MR1],R | 0167H | Comparand Register from: | | | | Masked by MR2 | SPD M@[AR][MR2],R | 01A7H | No Operation | NOP | 0300H | | • | | | Mask Register 1 | MOV CR,MR1 | 0301H | | Memory at Address set Valid | SPD M@aaaH,V | 0924H | Mask Register 2 | MOV CR,MR2 | 0302H | | Masked by MR1 | SPD M@aaaH[MR1],V | 0964H | Memory at Address Reg. | MOV CR,[AR] | 0304H | | Masked by MR2 | SPD M@aaaH[MR2],V | 09A4H | Masked by MR1 | MOV CR,[AR][MR1] | 0344H | | Memory at Addr. set Empty | SPDM@aaaH,E | 0925H | Masked by MR2 | MOV CR,[AR][MR2] | 0384H | | Masked by MR1 | SPD M@aaaH[MR1],E | 0965H | | | | | Masked by MR2 | SPD M@aaaH[MR2],E | 09A5H | Memory at Address | MOV CR,aaaH | 0B04H | | | | | Masked by MR1 | MOV CR,aaaH[MR1] | | | Memory at Address set Skip | SPD M@aaaH,S | 0926H | Masked by MR2 | MOV CR,aaaH[MR2] | 0B84H | | Masked by MR1 | SPD M@aaaH[MR1],S | 0966H | | 1401/051::: | | | Masked by MR2 | SPD M@aaaH[MR2],S | 09A6H | Mem. at Highest-Prio. Match | MOV CR LIMINDA | 0305H | | Mem. at Address set Random | SPD M@aaaH,R | 0927H | Masked by MR1<br>Masked by MR2 | MOV CR,HM[MR1]<br>MOV CR,HM[MR2] | 0345H<br>0385H | | Masked by MR1 | SPDM@aaaH[MR1],R | 092711<br>0967H | IVIASNEU DY IVINZ | IVIOV OIX,I IIVI[IVIIXZ] | USOSIT | | Masked by MR2 | SPDM@aaaH[MR2],R | 09A7H | | | | | • | | | | | | | Mem. at Highest-Prio. Match, Valid | | 012CH | | | | | Masked by MR1 | SPD M@HM[MR1],V | 016CH | | | | | Masked by MR2 | SPD M@HM[MR2],V | 01ACH | I | | | | | | | | | | # **INSTRUCTION SET SUMMARY Continued** | Instruction: Data Move | Cont | | <br>I | | | |---------------------------------|---------------------------|----------------|----------------------------------------|-----------------------|----------------| | | | OnCodo | Memory at Next Free Address, | No Change to Validit | v bits. from: | | Operation | Mnemonic | OpCode | Comparand Register | MOV NF,CR | 0330H | | Mask Register 1 from: | | | Masked by MR1 | MOV NF,CR[MR1] | 0370H | | Comparand Register | MOV MR1,CR | 0308H | Masked by MR2 | MOV NF,CR[MR2] | 03B0H | | No Operation | NOP | 0309H | Mask Register 1 | MOV NF,MR1 | 0331H | | Mask Register 2 | MOV MR1,MR2 | 030AH | Mask Register 2 | MOV NF,MR2 | 0332H | | Memory at Address Reg. | MOV MR1,[AR] | 030CH | Wask Register 2 | IVIO V IVI ,IVII VZ | 000211 | | Memory at Address | MOV MR1,aaaH | 0B0CH | Memory at Next Free Address, | Location set Valid fr | om: | | Mem. at Highest-Prio. Match | n MOV MR1,HM | 030DH | Comparand Register | MOV NF,CR,V | 0334H | | | | | Masked by MR1 | MOV NF, CR[MR1], V | 0374H | | Mask Register 2 from: | | | Masked by MR2 | MOV NF, CR[MR2], V | 0374H | | Comparand Register | MOV MR2,CR | 0310H | Mask Register 1 | MOV NF,MR1,V | 0335H | | Mask Register 1 | MOV MR2,MR1 | 0311H | Mask Register 2 | MOV NF,MR2,V | 0336H | | No Operation | NOP | 0312H | Wask Register 2 | IVIO V INF,IVINZ, V | 033011 | | Memory at Address Reg. | MOV MR2,[AR] | 0314H | l | | | | Memory at Address | MOV MR2,aaaH | 0B14H | Instruction: Validity Bit ( | Control | | | Mem. at Highest-Prio. Match | | 0315H | Operation | Mnemonic | <b>Op-Code</b> | | Worm at riightoot riio. Matori | 1010 V 1011 (2,1 1101 | 001011 | Set Validity bits at Address Re | | - | | Memory at Address Register, N | In Change to Validity h | nite from: | Set Valid | VBC [AR],V | 0424H | | Comparand Register | MOV [AR],CR | 0320H | Set Empty | VBC [AR],E | 0425H | | ' | • • | 0360H | | | 0425H | | Masked by MR1 | MOV [AR],CR[MR1] | | Set Skip | VBC [AR],S | | | Masked by MR2 | MOV [AR],CR[MR2] | 03A0H | Set Random Access | VBC [AR],R | 0427H | | Mask Register 1 | MOV [AR],MR1 | 0321H | Cat Validity bits at Address | | | | Mask Register 2 | MOV [AR],MR2 | 0322H | Set Validity bits at Address | \/DC!!\/ | 000411 | | l | | | Set Valid | VBC aaaH,V | 0C24H | | Memory at Address Register, I | - | | Set Empty | VBC aaaH,E | 0C25H | | Comparand Register | MOV [AR],CR,V | 0324H | Set Skip | VBC aaaH,S | 0C26H | | Masked by MR1 | MOV [AR],CR[MR1],\ | | Set Random Access | VBC aaaH,R | 0C27H | | Masked by MR2 | MOV [AR],CR[MR2],\ | / 03A4H | | | | | Mask Register 1 | MOV [AR],MR1,V | 0325H | Set Validity bits at Highest-Prio | • | 0.4001.1 | | Mask Register 2 | MOV [AR],MR2,V | 0326H | Set Valid | VBC HM,V | 042CH | | | | | Set Empty | VBC HM,E | 042DH | | Memory at Address, No Chang | ge to Validity bits, from | : | Set Skip | VBC HM,S | 042EH | | Comparand Register | MOV aaaH,CR | 0B20H | Set Random Access | VBC HM,R | 042FH | | Masked by MR1 | MOV aaaH,CR[MR1] | 0B60H | | | | | Masked by MR2 | MOV aaaH,CR[MR2] | 0BA0H | Set Validity bits at All Matching | Locations | | | Mask Register 1 | MOV aaaH,MR1 | 0B21H | Set Valid | VBC ALM,V | 043CH | | Mask Register 2 | MOV aaaH,MR2 | 0B22H | Set Empty | VBC ALM,E | 043DH | | I maen regions = | | 0222 | Set Skip | VBC ALM,S | 043EH | | Memory at Address, Location | set Valid from: | | Set Random Access | VBC ALM,R | 043FH | | Comparand Register | MOV aaaH,CR,V | 0B24H | | | | | Masked by MR1 | MOV aaaH,CR[MR1], | | Instruction: Compare | | | | Masked by MR2 | MOV aaaH,CR[MR2], | | Operation | Mnemonic | <b>Op-Code</b> | | Mask Register 1 | | 0B25H | Compare Valid Locations | CMPV | 0504H | | | MOV aaaH,MR1,V | 0B25H<br>0B26H | | CMPE | 0504H | | Mask Register 2 | MOV aaaH,MR2,V | UDZUH | Compare Empty Locations | | | | Manager at High ant Driamit Man | tala Na Obanana ta Vali | dia la ia.a | Compare Skipped Locations | CMPS | 0506H | | Memory at Highest-Priority Ma | ich, No Change to Valid | alty bits, | Comp. Random Access Locations | CIVIPR | 0507H | | from: | MOVILIMACD | 000011 | Instruction, Special Inst | ruotiono | | | Comparand Register | MOV HM,CR | 0328H | Instruction: Special Instr | | | | Masked by MR1 | MOV HM,CR[MR1] | 0368H | Operation | Mnemonic | Op-Code | | Masked by MR2 | MOV HM,CR[MR2] | 03A8H | Shift Comparand Right | SFT CR, R | 0600H | | Mask Register 1 | MOV HM,MR1 | 0329H | Shift Comparand Left | SFT CR, L | 0601H | | Mask Register 2 | MOV HM,MR2 | 032AH | Shift Mask Register 2 Right | SFT M2, R | 0610H | | | | | Shift Mask Register 2 Left | SFT M2, L | 0611H | | Memory at Highest-priority Mat | ch, Location set Valid. | from: | Select Foreground Registers | SFR | 0618H | | Comparand Register | MOV HM,CR,V | 032CH | Select Background Registers | SBR | 0619H | | Masked by MR1 | MOV HM,CR[MR1],V | 036CH | Reset Seg. Cont. Reg. to Initial Val. | | 061AH | | Masked by MR2 | MOV HM,CR[MR2],V | 03ACH | . 13301 30g. 30m. 110g. to miliar val. | | 5517111 | | Mask Register 1 | MOV HM,MR1,V | 032DH | | | | | Mask Register 2 | MOV HM,MR2,V | 032EH | | | | | aok regiotoi 2 | • v i iivi,ivii \2, v | JUZZII | | | | | | | | | | | | | | | | | | | | | | I | | | | | | | | | | # **INSTRUCTION SET SUMMARY Continued** | | | CYCLETYP | E | | | | |-----------------|----------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------|--|--| | CYCLE<br>LENGTH | Command Write | Command Read | Data Write | Data Read | | | | Short | MOV reg, reg<br>TCO reg (except CT)<br>TCO CT (non-reset, HMA invalid)<br>SPS, SPD, SFR<br>SBR, RSC, NOP | | Comparand register<br>(not last segment)<br>Mask register<br>(not last segment) | | | | | Medium | MOV reg, mem<br>TCO CT (reset)<br>VBC (NFA invalid)<br>SFT | Status register or<br>16-bit register | Memory array<br>(NFA invalid) | Comparand register<br>Mask register | | | | Long | MOV mem, reg<br>TCO CT (non-reset, HMA valid)<br>CMP<br>VBC (NFA valid) | | Memory array (NFA valid) Comparand register (last segment) Mask register (last segment) | Memory array | | | Note: The specific timing requirements for Short, Medium, and Long cycles are given in the Switching Characteristics Section under the tELEH parameter. For two cycle Command Writes (TCO reg or any instruction with "aaaH" as the source or destination), the first cycle is short, and the second cycle will be the length given. **Table 6: Instruction Cycle Lengths** | 15 | 14 | 13 12 11 10 | | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------------------------------|----------------------|-------------|-----|----------------|---|---|----------------------------------------------------------|------------------------------------------|----------------------------------------------------------------|---------------------|-----------------------------------------|-------------------------------|----------------------------------------------------|----------|--------| | RST | | | Res | erved | | | CAI | M/RAM | Part. | Comp. Mask | | AR Ir | nc/Dec | Reserved | | | R<br>E<br>S<br>E<br>T<br>=<br>0 | | | | be set<br>0000 | | | 48 CAI<br>32 CAI<br>16 CAI<br>48 RAI<br>32 RAI<br>16 RAI | M/32 RA<br>M/48 RA<br>M/16 CA<br>M/32 CA | M = 001<br>M = 010<br>M = 011<br>M = 100<br>M = 101<br>M = 110 | MR1<br>MR2<br>No Cl | e = 00<br>= 01<br>! = 10<br>nange<br>11 | Decr<br>=<br>Dis<br>=<br>No C | ement<br>00<br>ement<br>01<br>sable<br>10<br>hange | Must I | pe set | | Note: | D15 reads back as 0. | | | | | | | | | | | | | | | **Table 7: Control Register Bit Assignments** ## REGISTER BIT ASSIGNMENTS | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------------------------|-----------------------------------------|--------------------------------------|---------------|------------------------------------|-----------------------------------------|----------|----------------------------------|--------------------------------|------------------|-------------------------------------------------------------|----------------|--------------------------------------|------------------------------------------------------------|--------------------------------|-----------------| | SDL | DCSL DCEL | | ÆL | SSL SCSL | | SL. | SCEL | | LDC | D | SCV | LSC | SS | XCV | | | Set Dest. Seg. Limits = 0 No Chng. = 1 | Co<br>Si<br>Li | nation<br>ount<br>cart<br>mit<br>–11 | Co<br>E<br>Li | nation<br>ount<br>nd<br>mit<br>–11 | Set Source Seg. Limits = 0 No Chng. = 1 | Co<br>St | urce<br>unt<br>art<br>mit<br>–11 | Sou<br>Cor<br>Er<br>Lir<br>00- | unt<br>nd<br>nit | Load<br>Dest.<br>Seg.<br>Count<br>= 0<br>No<br>Chng.<br>= 1 | So<br>Co<br>Va | nation<br>eg.<br>ount<br>llue<br>–11 | Load<br>Src.<br>Seg.<br>Count<br>= 0<br>No<br>Chng.<br>= 1 | Sou<br>Se<br>Coo<br>Val<br>00- | g.<br>unt<br>ue | | Noto: | Note: D15 D10 D5 and D2 read back as 0s | | | | | | | | | | | | | | | Note: D15, D10, D5, and D2 read back as 0s. **Table 8: Segment Control Register Bit Assignments** | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|----|----|----|----|----|---------------------------|---|---|------|------|--------|-------|------|---|---|---| | 2481L | 0 | 0 | 0 | 0 | 0 | | | | Next | Free | Addres | s, NF | 10–0 | | | | | 4481L | 0 | 0 | 0 | 0 | | Next Free Address, NF11-0 | | | | | | | | | | | | 8481L | 0 | 0 | 0 | | | Next Free Address, NF12-0 | | | | | | | | | | | Note: The Next Free Address register is read only, and is accessed by performing a Command Read cycle immediately following a TCO NF instruction. Table 9: Next Free Address Register Bit Assignments | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |-------|-----|-----|------|-------|-------------------------|----|----|----|----|---------|----------|-------|-----|----|-----|-----| | ALL | /FF | /MM | Skip | Empty | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 2481L | 0 | 0 | 0 | 0 | | | | - | Ma | tch Ado | Iress, A | M10-A | M0 | | | /MF | | 4481L | 0 | 0 | 0 | | | | | | Ma | tch Add | Iress, A | M11–A | .MO | | | /MF | | 8481L | 0 | 0 | | | Match Address, AM12–AM0 | | | | | | | | | | /MF | | Note: The Status register is read only, and is accessed by performing Command Read cycles. On the first cycle, bits 15–0 will be output, and if a second Command Read cycle is issued immediately after the first Command Read cycle, bits 31–16 will be output. **Table 10: Status Register Bit Assignments** | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|----|---------------------|----|----|----|----|---|---|---|----|----|---|---|---|---|---| | ſ | 2481L | | Device ID = 241H | | | | | | | | | PS | | | | | | | | 4481L | | Device ID = 441H | | | | | | | | PS | | | | | | | | | 8481L | | Device ID = 841H PS | | | | | | | | | S | | | | | | | _ | | | | | | | | | | | | | | | | | | Note: The Persistent Source register is read only, and is accessed by performing a Command Read cycle immediately following a TCO PS instruction. **Table 11: Persistent Source Register Bit Assignments** #### **ABSOLUTE MAXIMUM RATINGS** Supply Voltage Voltage on all other pins -0.5 to 4.6 Volts -0.5 to VCC +0.5 Volts (-2 Volts for 10 ns, measured at the 50% point) -40°C to +85°C second duration. Temperature under bias Storage Temperature DC Output Current -55°C to 125°C 20 mA (per output, one at a time, one Stresses exceeding those listed under Absolute Maximum Ratings may include failure. Exposure to absolute maximum ratings for extended periods may reduce reliability. Functionality at or above these conditions is not implied. All voltages referenced to GND. ## OPERATING CONDITIONS (voltages referenced to GND at the device pin) | Symbol | Parameter N | | Typical | Max | Units | Notes | |-----------------|-------------------------------|------|---------|----------------------|-------|-----------| | Vσ | Operating Supply Voltage | | 3.3 | 3.6 | Volts | | | V <sub>IH</sub> | Input Voltage Logic 1 | 2.0 | | V <sub>CC</sub> +0.5 | Volts | | | V <sub>IL</sub> | Input Voltage Logic 0 | -0.5 | | 0.8 | Volts | 1, 2 | | T <sub>A</sub> | Ambient Operating Temperature | 0 | | 70 | °C | Still Air | ## DC ELECTRICAL CHARACTERISTICS | Symbol | Parameter | | Min | Typical | Max | Units | Notes | |---------------------|------------------------------------------------------|--------------|-----|---------|-----|-------|------------------------------------------------| | lcc | Average Power Supply | 2481L | | 85 | 125 | mA | t <sub>ELEL</sub> = t <sub>ELEL</sub> (min); 9 | | | Current | 4481L | | 90 | 160 | mA | | | | 8481L | | | TBD | TBD | mA | | | I <sub>CC(SB)</sub> | Stand-by Power Supply Current Output Voltage Logic 1 | | | | 2 | mA | /E = HIGH | | VOH | | | | | | Volts | I <sub>OH</sub> = -2.0mA | | VOL | Output Voltage Logic 0 | | | | 0.4 | Volts | $I_{OL} = 4.0 \text{mA}$ | | I <sub>IZ</sub> | Input Leakage Current | /RESET | 6 | 9 | 12 | Kohms | $V_{IN} = 0 V$ | | | | TEST1, TEST2 | 6 | 10 | 13 | Kohms | $V_{IN} = V_{CC}$ ; 10 | | | | Others | -2 | | +2 | μΑ | $V_{SS} \le V_{IN} \le V_{CC}$ | | loz | Output Leakage Current | | -10 | | 10 | μΑ | $V_{SS} \le V_{OUT} \le V_{CC;}$ | | | | | | | | | DQ <sub>N</sub> = High Impedance | #### **CAPACITANCE** | Symbol | Parameter | Max | Units | Notes | |-----------------|--------------------|-----|-------|-------------------------------------------| | C <sub>IN</sub> | Input Capacitance | 6 | pF | $f = 1 \text{ MHz}, V_{IN} = 0 \text{ V}$ | | COUT | Output Capacitance | 7 | pF | f=1 MHz, V <sub>OUT</sub> =0 V | ## **AC TEST CONDITIONS** | Input Signal Transitions | 0.0 Volts to 3.0 Volts | |-------------------------------|------------------------| | Input Signal Rise Time | < 3 ns | | Input Signal Fall Time | < 3 ns | | Input Timing Reference Level | 1.5 Volts | | Output Timing Reference Level | 1.5 Volts | # **SWITCHING CHARACTERISTICS** (see note 3) | | | | Cycle Time | -1 | 0 | | |----|--------------------|------------------------------------|----------------------------------|-----|-------|-----| | No | Symbol | Parameter (all times in nanoseco | Min | Max | Notes | | | 1 | <sup>t</sup> ELEL | Chip Enable Compare Cycle Time | 100 | | | | | 2 | <sup>t</sup> ELEH | Chip Enable LOW Pulse Width | Short Cycle: | 30 | | 4 | | | | | Medium Cycle: | 55 | | 4 | | | | | Long Cycle: | 75 | | 4 | | 3 | t <sub>EHEL</sub> | Chip Enable HIGH Pulse Width | 15 | | | | | 4 | <sup>t</sup> CVEL | Control Input to Chip Enable LOW | 0 | | 5 | | | 5 | <sup>t</sup> ELCX | Control Input from Chip Enable LC | 10 | | 5 | | | 6 | <sup>t</sup> ELQX | Chip Enable LOW to Outputs Activ | 3 | | 6 | | | 7 | <sup>t</sup> ELQV | Chip Enable LOW to Outputs Valid | Chip Enable LOW to Outputs Valid | | | | | | | | | | 75 | 4,6 | | 8 | <sup>t</sup> EHQZ | Chip Enable HIGH to Outputs High | n-Z | 3 | 15 | 7 | | 9 | <sup>t</sup> DVEL | Data to Chip Enable LOW Set-up | Time | 0 | | | | 10 | <sup>t</sup> ELDX | Data from Chip Enable LOW Hold | Time | 10 | | | | 11 | t <sub>ELFFV</sub> | Chip Enable LOW to Full Flag Valid | d | | 75 | | | 12 | <sup>t</sup> EHMFX | Chip Enable HIGH to /MF Invalid | | 0 | | | | 13 | <sup>t</sup> EHMFV | Chip Enable HIGH to /MF Valid | | | 25 | | | 14 | <sup>t</sup> RLRH | Reset LOW Pulse Width | | 100 | | 8 | #### Notes: - 1. -1.0V for a duration of 10 ns measured at the 50% amplitude points for Input-only lines (Figure 5). - 2. Common I/O lines are clamped, so that signal transients cannot fall below -0.5V. - 3. At $0 70^{\circ}$ C and Vcc(min) to Vcc(max). - 4. See Table 6. - 5. Control signals are /W and /CM. - 6. With load specified in Figure 4, Test Load A.7. With load specified in Figure 4, Test Load B. - 8. /E must be HIGH during this period to ensure accurate default values in the configuration registers. - 9. With output and I/O pins unloaded. - 10. TEST1 and/or TEST2 may not be implemented on all versions of these products. #### **SWITCHING TEST FIGURES** ## SWITCHING TEST FIGURES COMPONENT VALUES | Component | | Value | Units | |-------------------|-------------|-------|-------| | VCC | | 3.3 | Volts | | R1 | | 635 | Ohms | | R2 | | 702 | Ohms | | C1 (includes jig) | Test Load A | 30 | pF | | | Test Load B | 5 | pF | # **TIMING DIAGRAMS** ## ORDERING INFORMATION | PART NUMBER | ORGANIZATION | CYCLETIME | PACKAGE | TEMPERATURE | VOLTAGE | |------------------|--------------|-----------|-------------|-------------|---------------| | MU9C2481L - 10DC | 2048 x 64 | 100ns | 44-PIN PLCC | 0-70° C | $3.3 \pm 0.3$ | | MU9C4481L - 10DC | 4096 x 64 | 100ns | 44-PIN PLCC | 0-70° C | $3.3 \pm 0.3$ | | MU9C8481L - 10DC | 8192 x 64 | 100ns | 44-PIN PLCC | 0-70° C | $3.3 \pm 0.3$ | ## **PACKAGE OUTLINE** Dimensions are in inches | | Dim. A | Dim. B | Dim. C | Dim. D | Dim. E | Dim. E1 | Dim. F | Dim. F1 | Dim. a | Dim. b | | |--------|--------|--------|--------|--------|--------|---------|--------|---------|------------|--------|--| | 44-pin | .170 | .017 | .018 | .100 | .650 | .685 | .590 | .05 | 3° | 43° | | | PLCC | .180 | TYP | .032 | TYP | .656 | .695 | .630 | TYP | <b>6</b> ° | 47° | | ## MUSIC Semiconductors Agent or Distributor: MUSIC Semiconductors reserves the right to make changes to its products and specifications at any time in order to improve on performance, manufacturability, or reliability. Information furnished by MUSIC is believed to be accurate, but no responsibility is assumed by MUSIC Semiconductors for the use of said information, nor for any infringement of patents or of other third party rights which may result from said use. No license is granted by implication or otherwise under any patent or patent rights of any MUSIC company. ©Copyright 1998, MUSIC Semiconductors http://www.music-ic.com email: info@music-ic.com **USA** Headquarters **MUSIC Semiconductors** 254 B Mountain Avenue Hackettstown, New Jersey 07840 USA Tel: 908/979-1010 Fax: 908/979-1035 USA Only: 800/933-1550 Tech. Support 888/226-6874 Product Info. Tel: +63 49 549 1480 Fax: +63 49 549 1023 Sales Tel/Fax: +632 723 62 15 Philippines Asian Headquarters **MUSIC Semiconductors** Carmelray Industrial Park Canlubang, Calamba, Laguna Special Export Processing Zone 1 **European Headquarters** **MUSIC Semiconductors** Torenstraat 28 6471 JX Eygelshoven Netherlands Tel: +31 45 5462177 Fax: +31 45 5463663