## Order of Operations List \*Assumes NOR Bit Array

| Step # | General Step Description                | Write Operation                                                                                                        | Search Operation                                                                   |
|--------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| 1      | Incoming initial control + data signals | i_WENB -> Low<br>Write Address onto WA lines<br>Write Data onto WD lines                                               | i_WENB -> High<br>Search Data onto SD lines                                        |
| 2      | CLK rises<br>Before precharge, correct? | -                                                                                                                      | -                                                                                  |
| 3      | Precharging                             | Need to Precharge WL -> 0? Precharge BLs -> Vdd/2? No SL precharge? No ML precharge?                                   | Precharge SLs -> 0<br>Precharge ML -> 1<br>No BL precharge?<br>No WL precharge?    |
| 4      | Drive Data                              | Drive write data onto BL pairs  (one high, other low, depending on write 1 or 0)                                       | Drive search value onto SL pairs  (one high, other low, depending on write 1 or 0) |
| 5      | Trigger Action                          | Raise the WL of desired write address to trigger write cycle  (Low BL line will then write stored value to bit cell)   | What triggers ML evaluate?  (No ML discharge = Match. Yes ML discharge = no match) |
| 6      | End of Action Events +<br>Final Outputs | None? No "write success" feedback.<br>When are we officially donewriting?<br>Assumed complete after some hold<br>time? | Found -> High if match<br>Return match address onto MA lines if<br>match           |
| 7      |                                         |                                                                                                                        |                                                                                    |

## Inputs

- » WA<2:0> write-address
- » WD<7:0> write data
- » SD<7:0> search data
- » WENB write-enable bar (low = write, high = match)
- » CLK clock

## Outputs

- » MA<2:0> match-address
- » FOUND (high = match found, low = no match)

## **System Timing**



- Output data must be stored until next value arrives
- t<sub>su</sub> Setup time for your input vectors
- t<sub>m</sub> Match time