The present invention relates generally to memory devices and in particular to a system and method for testing memory devices, in particular, content addressable memory (CAM) devices, and priority encoders for CAMs.
Testing of memory devices is extremely time consuming and costly. Testing, however, is necessary to identify errors. If errors are not identified data could become corrupted. In particular, data in CAMs is often used to access addresses in networks and information and data to be sent may be misdirected with results ranging from non-delivery to mis-delivery. In testing CAMs, it is customary to write data into the CAM memory storage locations in the form of successive numbers, presented in binary code.
In conventional testing of a priority encoder, the CAM memory has to be loaded multiple times. The number of times that the CAM memory has to be loaded is typically equivalent to the number of bits in the priority encoder output. That is, if a priority encoder has ten output bits the CAM memory has to be loaded ten times. Part of the priority encoder test requires comparing two adjacent words. Using a binary representation of numbers requires several bits in the comparand register to be masked to cause the adjacent words to match with the masked comparand.
The present invention provides a system and method that shortens the time to test memory storage locations of memory devices, in particular CAMs and thus, reduce costs. In the present invention the CAM is loaded with data presented in Gray Code, wherein two successive data segments always differ by only a single bit.
The present invention also provides a system and method for testing a priority encoder of a CAM. Using Gray Code, only one bit of data in the comparand needs to be masked for two adjacent/successive memory storage locations to match the contents of the comparand. The advantage of the method of the present invention is that the CAM memory only has to be loaded with one set of data to conduct all the priority encoder tests described herein. The present invention, thus, translates into a significant reduction in test time and cost.
a is a nibble;
b is a word;
a is a pair of words of eight nibbles each, the first word starting with Gray Code state q0 as the first nibble of the present invention;
b is a pair of words of eight nibbles each, the first word starting with Gray Code state q1 in the first nibble of the present invention;
c is a pair of words of eight nibbles each, the first word starting with Gray Code state q3 in the first nibble of the present invention;
d is a pair of words of eight nibbles each, the first word starting with Gray Code state q2 in the first nibble of the present invention;
e is a pair of words of eight nibbles each, the first word starting with Gray Code state q6 in the first nibble of the present invention;
f is a pair of words of eight nibbles each, the first word starting with Gray Code state q7 in the first nibble of the present invention;
g is a pair of words of eight nibbles each, the first word starting with Gray Code state q5 in the first nibble of the present invention;
h is a pair of words of eight nibbles each, the first word starting with Gray Code state q4 in the first nibble of the present invention;
i is a pair of words of eight nibbles each, the first word starting with Gray Code state q12 in the first nibble of the present invention;
j is a pair of words of eight nibbles each, the first word starting with Gray Code state q13 in the first nibble of the present invention;
k is a pair of words of eight nibbles each, the first word starting with Gray Code state q15 in the first nibble of the present invention;
l is a pair of words of eight nibbles each, the first word starting with Gray Code state q14 in the first nibble of the present invention;
m is a pair of words of eight nibbles each, the first word starting with Gray Code state q10 in the first nibble of the present invention;
n is a pair of words of eight nibbles each, the first word starting with Gray Code state q11 in the first nibble of the present invention;
o is a pair of words of eight nibbles each, the first word starting with Gray Code state q9 in the first nibble of the present invention;
p is a pair of words of eight nibbles each, the first word starting with Gray Code state q8 in the first nibble of the present invention;
q is an exemplary embodiment of Gray Code state 0 (q0) of the present invention;
a is a flowchart of the method for testing a CAM in accordance with the present invention;
b is a flowchart of the error processing depicted in
a is an exemplary method for testing a priority encoder of a CAM using the present invention;
b is an alternative exemplary method for testing a priority encoder of a CAM using the present invention; and
The present invention will be described in connection with exemplary embodiments illustrated in
The Gray Code is a reflective binary representation of numbers that corresponds to a single bit changing from a binary number to its successor. Table 1 presents numbers as decimal numbers (0-15), in binary format (four bits), in Gray Code and the corresponding Gray Code state.
The Gray Code is called a reflective code because if the above exemplary table is folded in half after the decimal number “7”, then other than the high order bit the codes reflect or mirror each other. That is, the number “8” is represented in Gray Code as “1100” and the number “7” is represented in Gray Code as “0100” with the last three bits of the two numbers being identical. Moving away from the fold, the same is true for “9” and “6” which differ only in the most significant bit in their Gray Code representations. The same would be true for a table of the decimal digits from zero to seven folded after the number “3”. That is, the number “3” represented by Gray Code “010” and the number “4” represented by Gray Code “110” only differ by the most significant bit. The same would be true extending the representation to five bits (decimal numbers 0-31) and folding the table after the number “15”. The last column of the table represents the states or translation of the Gray Code as a binary number. For example, the decimal number “2” is represented in binary as “0010” and in Gray Code as “0011” so the state would be “q3”, where the letter “q” is the designation for “state” and the number “3” is the translation of the Gray Code (“0011”) to a decimal number.
a is a nibble of a data word, where a nibble in the present example is a group of four bits. Since a byte is eight bits, a half byte or nibble is almost always four bits. While other groupings of bits (e.g., two bits, six bits, 8 bits (byte)etc.) will also work for purposes of the testing described herein, a four bit nibble is convenient because it takes four bits to represent a hexadecimal (hex) digit and most data words are a multiple of four bits or one hex character. For example, a 32 bit word is eight hex (four bit) characters. However, a six bit grouping/data segment would be five hex characters and an extra two bits. Typically, CAM words are between 96 and 160 bits. While a 96 bit word would easily accommodate either hex (4 bit) characters or six bit data segment, a 160 bit word would not easily accommodate a six bit data segment. Any grouping of bits (bit structure or data segment) could be used to generate a Gray code state diagram used for the testing described herein, up to and including an entire word. Nibbles will be used as the exemplary data segment. Nibbles will be labeled from right to left. That is bit 0 is the rightmost bit of a nibble, followed by bit 1, followed by bit 2 and ending with bit 3. Eight nibbles make up the word shown in
a-3p show two successive 32 bit words as the data in the words proceeds from one state to the next as various bits of nibbles are tested and set. In the first (leftmost, high order) nibble of the first word of
For example, the first nibble of the first word in
The second nibble of the first word of
It should also be noted that each adjacent nibble differs from the preceding nibble in a single bit. That is, the first nibble of
Referring now to Table 2, each state of the finite state machine/diagram is set out separately to understand what is being done in each state. Setting a bit means that the value of the bit is set to “1” and clearing a bit means that the value of the bit will be “0”.
The finite state machine depicted in
Each nibble has its own copy of the sixteen state finite state machine/diagram with each nibble being one state ahead of its predecessor and one state behind its successor. This also means that other nibbles in the entire memory device are in the same state at the same time (given no errors). As described above, a single bit of the data in any given nibble is tested and based on the results of that test cycle, a second bit of the data in that nibble is set or cleared (set/clear cycle). Assuming that a test cycle is different than a set/clear cycle, it would take only 32 cycles to completely test a memory device—sixteen test cycles and sixteen set/clear cycles—because all nibbles in the entire memory device could be tested concurrently. This represents a significant reduction in the time and, therefore, cost of testing a memory device, in particular a CAM.
Each state of the Gray Code state diagram/machine described herein could be implemented by a two gate processor circuit (assuming no errors) using a combination of AND, OR, XOR, NAND and/or NOR gates. Error control may dictate additional gates. Overall, however, since each state of the Gray Code state diagram/machine described herein tests only one bit of a nibble and sets/clears only one bit of a nibble, the circuitry is relatively straightforward.
a is a flowchart of the method 500 for testing a CAM in accordance with the present invention. Method 500 would be practiced for each nibble of each word of a memory device, e.g., CAM, of the present invention. Gray code data is preloaded into each nibble at step 505 and the initial state of the data in each nibble is noted. At step 510 and the current state is set to the initial state. Based on the initial state of the nibble, the appropriate bit is tested at step 515. If an error is not encountered, then the appropriate bit is set or cleared at step 520 and the current state is incremented to the next (Gray Code) state at step 525. The current state is compared to the initial state at step 530 if the test has cycled back to the initial state, then all possible values have been tested for the nibble under test (and thereby all nibbles). Should an error have been identified at step 515, then error processing 535 would be as described above.
b is a flowchart of method 550 for the error processing 535 of method 500 depicted in
It be may desirable not to have to keep track of nibbles starting (and thus progressing through) in a variety of Gray code states. In an alternative exemplary embodiment, each nibble of the entire CAM is set to, for example, Gray Code state q0 or Gray Code state q15. This would result in the same initial Gray code state for each nibble. Once set the nibbles proceed from one Gray code state to the next as described above.
In another alternative embodiment, the present invention may be used to test a priority encoder of a CAM. A priority encoder is a device with a plurality of inputs (N+1), wherein each of the inputs has an assigned priority. Typically in a priority encoder, the input IN0 is assigned the highest priority, and the priority level descends linearly as the number (location) of the input increases. Input INn thus has the lowest priority.
A CAM is typically used as a search engine wherein a match is sought between the data in the comparand register, and data stored in each word in the CAM. The CAM then outputs the address of the word in the CAM that matches the comparand. In a CAM however, more than a single word may match the comparand, but the CAM needs to indicate the address of only one of the matching words.
The priority encoder identifies the highest priority active input on the match lines of the CAM. Even if several inputs are simultaneously active, the priority encoder will only indicate the activity of the input with the highest priority. The priority encoder is used in the CAM as the means to translate the position (within the CAM) of a matching word, into a numerical address representing that location. The priority encoder is also used to only translate the location of one word (the highest priority word), and ignore all other simultaneously matching words.
A typical priority encoder is comprised of two blocks. The first block is called the “highest priority indicator”, and is followed by the “address encoder” block.
The structure and operational details of an exemplary priority encoder are described in U.S. patent application Ser. No. 10/188,971, entitled “NOVEL PRIORITY ENCODER” filed Jul. 5, 2002 by Zvi Regev, which is incorporated in its entirety herein by reference.
Many methods are used to convert the output of the highest priority indicator into a numerical value. The simplest method is that of a look-up table.
The CAM considered in the present invention supports a comparand containing a ‘0’, ‘1’, or ‘X’ (don't care) for each bit. A ‘0’ will match only a zero in the entries compared. A ‘1’ will match only a one in the entries compared. An ‘X’ will match either a zero or a one. Implementations of both binary and ternary CAMs can have this type of a comparand implementation, but not all binary or ternary CAMs do. The CAM is arranged so that the comparator at every entry has a single “match” indicator going to the priority encoder. The priority encoder has a plurality of “match” inputs, each one from a different entry in the CAM noted earlier as the N+1 input. The priority encoder outputs the “address” of one matching entry or a “no-match” indication if no “match” input is set to “true”. The priority encoder is constructed such that each “match” input has a fixed address and priority and the inputs are labeled to indicate the address and the priority in the format “match[x]”, where x indicates both the address and the priority. Lower addresses have higher priority. If more than one match is indicated, it is always the “highest-priority” match that is output by the priority encoder. Match[0]“is the highest priority match indication input. “Match[N]”, where N is the number of words in the CAM, is the lowest priority match indication input.
Further details of a priority encoder can be found in U.S. patent application Ser. No. 10/188,971 referenced earlier.
Testing a priority encoder requires testing all possibilities of a single match and at least adjacent entry multiple matches. When only a single entry should match, the “match-output” should be indicated and the “multi-match output” must not be indicated. When two or more entries match, both the “match-output” and “multi-match output” must be indicated. Since almost all of the defects in a CAM priority encoder occur between two adjacent entries in the priority encoder, it is sufficient to test a condition where every two adjacent entries are the only ones that match. Whether this condition holds true is a function of the design of the CAM.
Although testing of a priority encoder contemplates using a Gray code of 96 or more bits commensurate with the size of typical CAM memory storage locations, for ease of discussion and explanation, a four bit Gray code is used as an example.
At step 910 the entire CAM array is searched for an exact (single) match of each of the Gray codes. For each pass of the search, the priority encoder should output the binary address corresponding to the Gray code specified, with the “match-output” indicated and the “multi-match output” NOT indicated. (If a “multi-match output” is detected by the priority encoder, then there is clearly an error because each and every data word/storage location of the CAM should be different and represent its binary address in Gray code.) The first pass of the search indicated at step 910 would be for “0000 . . . ”, where “0000 . . . ” will be the Gray code for the first data word of the CAM using the number of bits required to Gray code the address of that location. For example, if a CAM has 65 k 32-bit words, then it would require sixteen bits to uniquely address each word. The priority encoder will return address of “0000 . . . ” with a match set/indicated and multi-match not set/indicated. The next Gray code searched for would be “ . . . 0001”, then “ . . . 0011”, etc. This sequence guarantees that every match entry operates properly and that the priority encoder returns the correct data.
With the Gray code data in the CAM remaining unchanged, at step 915, combinations of two adjacent entries are searched. For example, searching for “000X” should match both entries 0 and 1. The priority encoder will return the address “0000” (highest priority address), and both “match output” and “multi-match output” should be set/indicated. The next pass of the search indicated at step 915 would be for “00X1”. This should match entries 1 and 2. The address output should be “0001”, with both match and multi-match set/indicated. Table 3 shows the word number, the binary address of the word number, the Gray Code content of the binary address, the comparand that would be used for each of the adjacent entries, the priority address and the words with Gray Code data that are compared using the comparand.
The search undertaken at step 915 tests multiple matches on adjacent words only. For random multiple matches throughout the CAM address range, some words may have to be re-written. If, however, a quasi-random test, wherein a “don't care” bit is placed on any of the most significant bits is sufficient, then the quasi-random test could be conducted without any changes to the loaded Gray Code data.
Table 3 is a simplified version of what would be required for priority encoder testing. Table 3 includes the Gray code data for four bits only to simplify the discussion. As indicated to test a 65 k word memory a sixteen bit address would be required. A sixteen bit Gray code table would be quite large to represent in a table so a four bit Gray code table is used in this example to illustrate the invention. Step 915 tests adjacent entries of the CAM array. The use of Table 3 will be described by example. The first/leftmost column indicates the word number and the second column indicates the binary equivalent of the word number indicated in the first column. The third column indicates the Gray Code content of the word number. That is, the content of binary address “0000” is “0000”. The content of binary address “0111” is “0100”. Using comparand “000X” would compare the content of words 0 and 1, where word 0 holds Gray Code “0000” and word 1 holds Gray Code “0001”. This is indicated in the last column of Table 3. The lower address has the higher priority so the priority address is word 0 as indicated in the fifth column of Table 3. Comparand “010X” would compare the contents of words 6 and 7, where word 6 holds Gray Code “0101” and word 7 holds Gray Code “0100”. This is indicated in the last column of Table 3. Word 6 has the higher priority address as indicated in the fifth column of Table 3. In all cases only one comparand bit ever has a value “X” in this test.
In the above example and
The above example is illustrative only. In a typical CAM memory the number of bits in a word ranges from 96 to 160 or even perhaps greater. A 256 k entry CAM memory array would, for example, require eighteen bits to address the entries of the CAM (218=262,144=256 k). Thus, the address range that can be tested using the present invention is very large.
Thus, testing a priority encoder of a CAM is accomplished as depicted in
A system for testing a priority encoder of a CAM would retain the coupling of a processor with the CAM as depicted in
The memory controller 1002 is also coupled to one or more memory buses 1007. Each memory bus accepts memory components 1008 including at least one CAM device for testing. A processor circuit of the present invention may be used in conjunction with CAM 1008. The processor circuit may be used to test both memory locations of CAM 1008 and a priority encoder of CAM 1008 in accordance with any of the embodiments of the present invention disclosed above in connection with
The primary bus bridge 1003 is coupled to at least one peripheral bus 1010. Various devices, such as peripherals or additional bus bridges may be coupled to the peripheral bus 1010. These devices may include a storage controller 1011, an miscellaneous I/O device 1014, a secondary bus bridge 1015, a multimedia processor 1018, and an legacy device interface 1020. The primary bus bridge 1003 may also coupled to one or more special purpose high speed ports 1022. In a personal computer, for example, the special purpose port might be the Accelerated Graphics Port (AGP), used to couple a high performance video card to the processing system 1000.
The storage controller 1011 couples one or more storage devices 1013, via a storage bus 1012, to the peripheral bus 1010. For example, the storage controller 1011 may be a SCSI controller and storage devices 1013 may be SCSI discs. The I/O device 1014 may be any sort of peripheral. For example, the I/O device 1014 may be an local area network interface, such as an Ethernet card. The secondary bus bridge may be used to interface additional devices via another bus to the processing system. For example, the secondary bus bridge 1016 may be an universal serial port (USB) controller used to couple USB bus devices 1017 via to the processing system 1000. The multimedia processor 1018 may be a sound card, a video capture card, or any other type of media interface, which may also be coupled to one additional devices such as speakers 1019. The legacy device interface 1020 is used to couple legacy devices, for example, older styled keyboards and mice, to the processing system 1000.
The processing system 1000 illustrated in
While the invention has been described and illustrated with reference to specific exemplary embodiments, it should be understood that many modifications and, substitutions can be made without departing from the spirit and scope of the invention. Accordingly, the invention is not to be considered as limited by the foregoing description but is only limited by the scope of the appended claims.
Number | Date | Country | |
---|---|---|---|
Parent | 10327045 | Dec 2002 | US |
Child | 11474496 | Jun 2006 | US |