用户登陆 用户注册
您的位置:首页> 技术文章>内容正文
一种基于移位寄存器的CAM的Verilog HDL实现
[正文]:摘要:一种利用verilog hdl设计cam的方案,该方案以移位寄存器为核心,所实现的can具有可重新配置改变字长、易于扩展、匹配查找速度等特点,并在网络协处理器仿真中得到了应用。
关键词:cam 移位寄存器 verilog hdlcam(content addressable memory,内容可寻址存储器)是一种特殊的存储阵列。
它通过将输入数据与cam中存储的所有数据项同时进行比较,迅速判断出输入数据是否与cam中的存储数据项相匹配,并给出匹配数据项的对应地址和匹配信息。
cam以其高速查找、大容量等特点而被广泛地应用于电讯、网络等领域。
本文介绍一种用verilog hdl设计cam的方案。
该方案以移位寄存器为核心,具有可重新置改变字长、易于扩展、匹配查找速度快等特点。
1 cam功能描述
点击查看大图片
cam的基本框图如图1所示。
与ram相似,cam是将数据项存储在一个阵列中。
每个数据项的位数叫做字宽,cam中所有数据项的条数叫做cam的深度。
通过字宽和深度可以表征cam中容量。
在写cam模式(配置)时,write_e信号有效,match_e信号无效,此时通过地址线addr选择data_in输入的数据将要被写放哪一个单元;在读cam模式(查找匹配)时,write_e信号无效,match_e信号有效,cam将不使用地址线,而是直接将data_in读入的数据与cam中存储的各条数据项进行并行比较。
如果cam中含有与此时输入数据相匹配的存储数据项,cam将从match_addr输出此存储数据项的地址,并且通过math_ok输出匹配成功的信息。
在查找匹配模式时,由于cam是将输入数据与存储数据项并行比较,所以速度极快。
同时,由于不需要通过地址线来寻址数据项,cam将不受地址线宽度的限制,容易扩展。
2 基于移位寄存器的cam的设计为了说明设计方案,以一个宽度为4位、深度为1的基本cam存储单元为例。
利用这样一个基本存储单元,通过适当级联,可以构成任意字宽和深度的cam。
该基本单元采用一个16位的移位寄存器、一个4位的比较器,外加16位的计数器和一个"二选一"的选择器构成。
如图2所示。

点击查看大图片
在写cam模式时,write_e信号有效,data_in输入的是将要写入数据存储项的4位数据。
计数器进行从"1111"到"0000"的减计数,并将计数输出值与data_in输入值进行比较。
若二者相同,比较器输出"1"到移位寄存器中;不同则输出"0"到移位寄存器中。
在16个时钟周期之后,将完成data_in输入数据与计数器输出的所有情况的比较。
这样,移位寄存器中将存入15个"0"和一个"1"。
在读cam模式时,match_in为"1",此时,data_in输入的数据直接送到移位寄存器的地址端,它将决定移位寄存器输出其16个位中的哪一位。
如果该位输出"1",则表示此时data_in与原来写入该单元的数据相同,即发生匹配;反之则输出"0",表示无匹配项。
以上讨论只是针对4位字宽的数据项的读写,而对于更长字宽的数据项,必须进行字宽扩展。
可用多个比较器和移位寄存器组成的存储数据项并联在一起,组成一个字结构,即把输入的数据按每4位分为一组,每组对应一套比较器和移位寄存器,每组只产生一个最终的mtach_out信号。
例如,对于16位的数据项,就需要4组这样的结构。
这4组基本结构中的读和写可以同时完成。
只有4组都产生匹配信号,最终的match_out输出才有"1",表明读入的16位data_in数据与存储的数据项匹配。
cam只需要存储多个数据项,因此需要多个字结构的深度扩展。
将这些字结构中的比较器和移位寄存器分别组合在一起,构成比较器阵列和移位寄存器阵列。
为了在写cam时进行写入数据的定位,还需要一个地址译码模块来指出是对哪一个数据项进行写操作。
在读cam时,得到输入数据与各个存储数据项的匹配信息之后,还要对这些匹配信息进行编码,得到最后要输出的相匹配的存储数据项的地址match_addr和是否发生匹配的信息match_ok。

点击查看大图片
完整的cam结构框图见图3。
3 基于移位寄存器的cam的verilog hdl实现硬件描述语言veriloghdl是一种应用于电路设计的描述语言,具有行为级、寄存器传输级、逻辑门级和开关级等多层次描述。
它简单易读,描述与工艺无关,并且得到许多eda工具的支持。
利用verilog hdl语言进行电路设计可以大大节省设计时间和成本。
本设计以一个数据项字宽为16位、深度为8的cam为例,进行verilog hdl设计,并利用xilinx virtex系列中xcv1000器件进行综合。
综合后的仿真分析表明,该方案是合理可行的。

点击查看大图片
图4为匹配查找的时序仿真结果,cam中预先放入了0019h,001ah,…,001dh五个数据。
clk为系统时钟,data_in为数据输入,match_enable为读cam(查找)允许信号,global_rst为全局清零信号,r_match_addr为匹配地址输出信号,r_match_ok为是否发生匹配信号。
从仿真波形可以看出,输入数据经过两个时钟周期,输出匹配信息,包括是否匹配和相匹配的存储数据项的地址。
如果不匹配,是否匹配的信号为0,而输出地址线不变。
本方案以移位寄存器设计cam,在写模式下需要16个时钟周期完成一个数据项的写入;读模式仅需一个时钟周期。
它具有速度快、易于重新配置、易于扩展等特点。
本方案中的cam利用xilinx virtex系列器件实现,时钟最高频率可达80mhz以上。
以本方案为基础,扩展到32位、36位的实用化cam已运用于网络协处理器的仿真测试中,并取得了较好的效果。



网站首页 培训课程 维修指南
技术文章 家电专栏 供应信息
求购信息 培训资讯 展会信息
电脑专栏 教程下载 资料下载
常用软件 PLC教程 PLC资料
变频伺服 低压电器 维修资料
人机界面 自控仪表 工控机类
文章标题: 搜文章
中国工控资源网手机版 2012
电话:010-67577139 13811659603
培训咨询QQ:657167934 471895637 销售咨询QQ:623769457
联系邮箱:zggkzyw@163.com
 京ICP备11002135号
报时(2026-04-07 04:29:29) 流量统计