# Modular SRAM-based Binary Content-Addressable Memories



#### Ameer M.S. Abdelhadi and Guy G.F. Lemieux

Department of Electrical and Computer Engineering

University of British Columbia

Vancouver, Canada



#### Binary Content-Addressable Memory (BCAM)





#### **BCAM Applications**





#### Motivation - FPGAs





#### Objectives



#### Use BRAMs to construct

- Modular and flexible
- Storage efficient
- Single-cycle
- Performance oriented



BCAMs

#### Algorithmic Heuristics





#### **Register-Based BCAM**

#### Concurrent register read and compare



Limited resources Complex routing Fits small BCAMs



Single-cycle

Brute-Force Transposed-Indicators-RAM (1) A Traditional BRAM-based BCAM

#### Key idea: Transposed RAM - data becomes addresses

#### Write











Brute-Force Transposed-Indicators-RAM (2) Storing Data to Multiple Addresses

- How can we store data to multiple addresses?
  - Specify addresses using one-hot coding
  - Each bit indicates a match or "store at location"
- PROBLEM: Depth of CAM is limited by data width of RAM
  - *e.g.* to build 1M deep CAM, we need 1M bits wide
  - In FPGAs: 1000 BRAMs x 32bit wide = 32K deep CAM



#### BRAM-based Single-cycle Depth of CAM is limited by RAM width



#### **BCAM** Cascading

#### • PROBLEM:

• Patterns are encoded as RAM addresses

➢RAM depth is exponential to pattern width

RAM Depth = 2<sup>Pattern Width</sup>

- Solution: Cascading
  - 1. Divide pattern into smaller slices
  - 2. Search for each slice separately
  - 3. If all slices are found  $\rightarrow$  pattern match!

➢RAM depth is linear to pattern width

#### RAM Depth = $2^{Slice Width} \times (Pattern Width / Slice Width)$





Hierarchical Search 2D BCAM (1) Narrow and Deep BCAM









• Divide address space into sets







- Divide address space into sets
  - RAM: each set in a line





- Divide address space into sets
  - RAM: each set in a line
  - Transposed-RAM: indicates "pattern in set?"





- Divide address space into sets
  - RAM: each set in a line
  - Transposed-RAM: indicates "pattern in set?"
- Hierarchical Search:
  - 1. Find a set (row) with match using a 1D BCAM



Match pattern '3' -



- Divide address space into sets
  - RAM: each set in a line
  - Transposed-RAM: indicates "pattern in set?"
- Hierarchical Search:
  - 1. Find a set (row) with match using a 1D BCAM
  - 2. Search this set (row) in parallel for a specific match



RAM





#### Hierarchical Search 2D BCAM (3) Pros and Cons





PROBLEM: is it possible to regenerate matches for all addresses?





PROBLEM: is it possible to regenerate matches for all addresses?

#### Key observation

Transposed RAMn columns (set of addresses)is a sparse matrixaccommodates n matches (1's) at most!





#### PROBLEM: is it possible to regenerate matches for all addresses?

Key observation

Transposed RAMn columns (set of addresses)is a sparse matrixaccommodates n matches (1's) at most!

Key idea: use indirect indices to point to intra-set matches

Cascadable

Scalable (linear growth)

#### Supports wider patterns





Intra-set Match Indicators

PROBLEM: is it possible to regenerate matches for all addresses?

Key observationTransposed RAMn columns (set of addresses)is a sparse matrixaccommodates n matches (1's) at most!

Key idea: use indirect indices to point to intra-set matches Cascadable

Scalable (linear growth)

Supports wider patterns









• Divide address space into sets





- Divide address space into sets
- Store sets with a match in Indicators-RAM





- Divide address space into sets
- Store sets with a match in Indicators-RAM
- Transposed-RAM stores indices to all matches in set





- Divide address space into sets
- Store sets with a match in Indicators-RAM
- Transposed-RAM stores indices to all matches in set
- Hierarchical Search:





- Divide address space into sets
- Store sets with a match in Indicators-RAM
- Transposed-RAM stores indices to all matches in set
- Hierarchical Search:
  - Find indices of all matching sets in Transposed-RAM





- Divide address space into sets
- Store sets with a match in Indicators-RAM
- Transposed-RAM stores indices to all matches in set
- Hierarchical Search:
  - Find indices of all matching sets in Transposed-RAM
  - Read Indicators-RAM using indices from Transposed-RAM



























#### **Open Source**

### http://ece.ubc.ca/~lemieux/downloads/

# Modular and parametric Verilog files

Run-in-batch simulation and synthesis manager















# Thank You!



# Backup Slides





![](_page_41_Picture_2.jpeg)