- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
开放核协议—IP核在SoC设计中的接口技术.doc
开放核协议—IP核在SoC设计中的接口技术
摘??? 要:本文介绍了IP核的概念及其在SoC设计中的应用,讨论了为提高IP核的复用能力而采用的IP核与系统的接口技术。 关键词:SoC;IP核;OCP
引言随着半导体技术的发展,深亚微米工艺加工技术允许开发上百万门级的单芯片,已能够将系统级设计集成到单个芯片中即实现片上系统SoC。IP核的复用是SoC设计的关键,但困难在于缺乏IP核与系统的接口标准,因此,开发统一的IP核接口标准对提高IP核的复用意义重大。本文简单介绍IP核概念,然后从接口标准的角度讨论在SoC设计中提高IP核的复用度,从而简化系统设计和验证的方法,主要讨论OCP(开放核协议)。
图1 OCP工作原理示意图
图2? 读/写操作的时序
图3? 读/写状态机
OCP简介基于IP核复用技术的SoC 设计使芯片的设计从以硬件为中心转向以软件为中心,芯片设计不再是门级的设计,而是IP核和接口及其复用设计。IP核集成到系统所要考虑的问题包括:同步,例如全局执行、数据交换和协议方面的同步操作;协议转换,不同模块间不兼容的协议的转换,封装可用来解决这个问题,但需要考虑时序约束;I/O缓存,为满足系统行为和时序约束可能需要缓存数据。另外,出于对核设计的保护会故意隐藏一些信息,而这些信息在集成时可能需要。为解决这些问题需要一个好的接口标准,一些大公司现在已有自己的IP核接口标准,比如Altera的Avalon,Atlantic、IBM的CoreConnect、ARM的AMBA等。因为核的多样性,使用完全相同的接口是不现实的,OCP将软件中的分层概念应用到IP核接口,提供一种具有通用结构定义、可扩展的接口协议,方便了IP核与系统的集成。OCP协议使IP核与系统的接口与IP核的功能无关,设计人员不需要了解核内部也能利用它进行系统设计。OCP接口允许设计者根据不同的目的配置接口,包括接口的数据宽度、交换的握手协议等,在SoC设计中可以裁剪核的功能,降低设计复杂性,减小面积,同时满足SoC的要求;OCP接口还保持核在集成到系统的过程中自身完全不被改变,就是说在总线宽度、总线频率或电气负载有变化时核保持不变。使用OCP接口的设计可以交付即插即用的模块,同时支持核的开发与系统设计并行,节省设计时间。
OCP接口运行机制OCP定义两个通信实体间点到点的接口。其中一个实体作为通信的主体(Master),另一个作为从体(Slave)。只有Master可以发命令,Slave响应Master的命令,接收或发送数据。封装接口模块必须担当每个连接实体的对应端,当连接实体是Master时,封装接口模块就作为对应的Slave;当连接实体是Slave时,封装接口模块作Master。OCP的工作原理如图1所示。图中有三个IP核,其中左边标有Initiator的IP核是通信的发起方,作Master;右边标有Target的是通信的目标方,作Slave;中间的既可作Master又可作Slave;下面的框图代表封装接口模块;从Master出来并进入Slave的箭头表示请求命令,从Slave出来并进入Master的箭头表示响应;加黑的线段代表片上互连总线。两个IP核通过接口通信的过程是:作为Master的 IP核发出请求命令给对应的Slave端(总线封装接口模块);封装接口模块通过片上总线将请求命令(OCP并不指定片上互连总线的工作机制,而是把OCP命令转换成总线上的传送)传送给接收方的总线封装模块;接收方的总线封装模块再作为Master把这种内部总线传输转换成合法的OCP命令传送给目标IP核;其作为Slave方接收命令并执行所要求的操作。每一个OCP接口都是可根据连接实体的要求进行配置的(通过选择需要的信号或某一信号的位宽),也是互相独立的,例如系统中通信发起者总是会需要比目标方更多的地址位数用来选择发起者所要求的目标。OCP接口信号OCP通过命令完成实体间的通信操作,在接口为选择的命令配置相应信号,所有的信号都是在时钟上升沿采样,是完全的同步设计。OCP接口信号包括数据信号、边带信号和测试信号。数据信号又分为基本信号、简单扩展信号、猝发信号和多线程扩展信号。所有IP核都需要基本数据信号中的一组信号,其他可选信号用于支持通信需要,实现可配置和可扩展性。基本数据信号包括:Clk、MAddr、MCmd、MData、MDataValid、MRespAccept、SCmdAccept、SData、SDataAccept、SResp。其中只有CLK和MCmd是必须的,其他可选。Mcmd是传输命令,指出主方OCP传输类型,包括读、写和广播类型的八种命令。简单扩展信号增加了OCP接口地址空间、字节使能和核在不同阶段的特征信息。猝发式扩展信号允许猝发传输,可设置不同猝发
文档评论(0)