summaryrefslogtreecommitdiffhomepage
path: root/src/cam.v
blob: 5fefb81c59f854daff29c3d0ef8ebce45a05ac80 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/* 
 * 	cam.v
 * 	
 * 	 Copyright (C) 2025 Private Island Networks Inc.
 *   Copyright (C) 2018-2022 Mind Chasers Inc.
 *
 *   Licensed under the Apache License, Version 2.0 (the "License");
 *   you may not use this file except in compliance with the License.
 *   You may obtain a copy of the License at
 *
 *       http://www.apache.org/licenses/LICENSE-2.0
 *
 *   Unless required by applicable law or agreed to in writing, software
 *   distributed under the License is distributed on an "AS IS" BASIS,
 *   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *   See the License for the specific language governing permissions and
 *   limitations under the License.
 *	
 *	function: single cycle, parameterized CAM 
 *	
 */

module cam #(parameter DEPTH = 8, DATAW = 32)
(
	input	rstn,
	input	clk,
	
	// input for programming
	input  	prgclk,
	input 	sel,
	input 	we,
	input 	[$clog2(DEPTH)-1:0] addr,		// include two lsbits for the byte selects
	input 	[DATAW-1:0]	d_i,
	output [DATAW-1:0] d_o,
	
	input 	search,
	input	[DATAW-1:0] search_address,
	
	// output
	output reg match
);

	
	reg [DATAW-1:0] content[0:DEPTH-1];
	reg valid[0:DEPTH-1];
	integer i,j;
	
	// Program the CAM
	always @(posedge prgclk, negedge rstn)
		if( !rstn ) begin
			for (i=0; i < DEPTH; i=i+1)	begin
				content[i] <= 'd0;
				valid[i] <= 1'b0;
			end
		end
		else if ( we && sel )
			begin
				content[addr] <= d_i;
				valid[addr] <= 1'b1;
			end
		
	assign d_o = valid[addr] ? content[addr] : 'd0;

		
	// search the CAM
	always @(posedge clk) begin
		match <= 1'b0;
		for (j=0; j < DEPTH; j=j+1)	begin
			if (search && valid[j] && search_address == content[j])
				match <= 1'b1;
		end
	end
	
	
endmodule

Highly Recommended Verilog Books