当前位置:首页 > 工业控制 > 电子设计自动化

引言

随着半导体技术的发展,深亚微米工艺加工技术允许开发上百万门级的单芯片,已能够将系统级设计集成到单个芯片中即实现片上系统SoC。IP核的复用是SoC设计的关键,但困难在于缺乏IP核与系统的接口标准,因此,开发统一的IP核接口标准对提高IP核的复用意义重大。本文简单介绍IP核概念,然后从接口标准的角度讨论在SoC设计中提高IP核的复用度,从而简化系统设计和验证的方法,主要讨论OCP(开放核协议)。

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方接收命令并执行所要求的操作。

图1 OCP工作原理示意图

每一个OCP接口都是可根据连接实体的要求进行配置的(通过选择需要的信号或某一信号的位宽),也是互相独立的,例如系统中通信发起者总是会需要比目标方更多的地址位数用来选择发起者所要求的目标。

OCP接口信号

OCP通过命令完成实体间的通信操作,在接口为选择的命令配置相应信号,所有的信号都是在时钟上升沿采样,是完全的同步设计。OCP接口信号包括数据信号、边带信号和测试信号。数据信号又分为基本信号、简单扩展信号、猝发信号和多线程扩展信号。所有IP核都需要基本数据信号中的一组信号,其他可选信号用于支持通信需要,实现可配置和可扩展性。

基本数据信号包括:Clk、MAddr、MCmd、MData、MDataValid、MRespAccept、SCmdAccept、SData、SDataAccept、SResp。其中只有CLK和MCmd是必须的,其他可选。Mcmd是传输命令,指出主方OCP传输类型,包括读、写和广播类型的八种命令。简单扩展信号增加了OCP接口地址空间、字节使能和核在不同阶段的特征信息。猝发式扩展信号允许猝发传输,可设置不同猝发传输模式的参数。多线程扩展信号支持OCP接口的多线程处理。边带信号传送诸如复位、中断、错误和核特性标志等控制信息,也是IP核与系统间交换控制和状态信息的手段,可以同请求/响应信号异步,但与时钟上升沿同步。测试信号支持扫描、时钟控制和JTAG。

OCP接口时序及接口状态机

以简单读写操作的时序为例说明OCP接口时序要求,如图2所示。

图2 读/写操作的时序

在上升沿1处OCP Master方通过将MCmd由Idle变为Wr开始进入请求状态,在此周期内把地址A1和数据D1分别送到MAddr和MData信号线上,Slave必须在同一个周期内发出SCmdAccept有效信号;Slave在上升沿2处开始接收地址和数据并进行内部写操作;在上升沿4处MCmd赋值为Rd,OCP进入读请求状态,在这个周期内Master方将地址放在MAddr信号线上,在同周期Slave发出SCmdAccept有效信号;在上升沿5处Slave方置SResp为DVA从而开始响应阶段,请求阶段结束,根据从MAddr获得的地址读取数据并放到SData信号线上;在上升沿6处开始Master方收到Slave的响应信号并开始读数据,响应阶段完成。

图3是在读、写操作中请求阶段和响应阶段主、从两方的状态机。

图3 读/写状态机

Master和Slave都是从IDLE状态开始,当检测到MCmd变为读或写时Master转为请求阶段,Slave转到读或写状态。如果是读操作,Master的请求状态持续到SCmdAccept有效,Slave在完成读操作后发出SCmdAccept有效信号并置SResp为DVA,Slave变为响应状态,Master进入IDLE状态;SResp是NULL时,Slave没有进入响应状态Master进入Wait Resp状态,等待Slave进入响应状态。如果是写操作,没有响应信号,当SCmdAccept有效时Master的请求阶段结束进入IDLE状态,Slave处理写操作,完成后进入IDLE状态。

结语

OCP是基于核的免费开放的接口协议,可以根据不同IP核的通信要求进行配置和扩展,能够实现硬件集成真正的即插即用,允许系统集成根据应用需要选择最好的IP核和互联机制。OCP为IP核设计提供了解决可配置性和接口的较好办法,实现了IP核与系统集成的Socket接口,能够做到核的模块化和即插即用特性。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭