引言
随着半导体技术的发展,深亚微米工艺加工技术允许开发上百万门级的单芯片,已能够将系统级设计集成到单个芯片中即实现片上系统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接口地址空间、字节使能和核在不同阶段的特征信息。猝发式扩展信号允许猝发传输,可设置不同猝发传输模式的参数。多线程扩展信号支持OCP接口的多线程处理。边带信号传送诸如复位、中断、错误和核特性标志等控制信息,也是IP核与系统间交换控制和状态信息的手段,可以同请求/响应信号异步,但与时钟上升沿同步。测试信号支持扫描、时钟控制和JTAG。
OCP接口时序及接口状态机
以简单读写操作的时序为例说明OCP接口时序要求,如图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是在读、写操作中请求阶段和响应阶段主、从两方的状态机。
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接口,能够做到核的模块化和即插即用特性。
- 接口技术(41224)
- 开放核协(6033)
相关推荐
IP核是指什么?分为哪几种形式
IP核生成文件:XilinxAltera
IP核简介
IP核简介
ip核使用问题
开放核协议:IP核在SoC设计中的接口技术
AD9683的引脚如何与zynq 7015芯片中的JESD204 ip核端口对应相连?
ATM流量控制器IP核的设计和实现
FPGA IP核的相关问题
FPGA的软核、硬核以及固核的概念
LCD的通用驱动电路IP核设计
MES50HP——IP核安装与查看用户指南
NioslI中如何设计SOPC的LCD显示驱动IP核
PCIE项目中AXI4 IP核例化详解
QUARTUS II中IP核的调用方法
Quartus 中ATAN IP核的使用问题
TEMAC核有哪些功能
VIP系列IP核使用
Vivado IP核锁定的解决办法分享
Vivado生成IP核
WCDMA无线接口技术
planahead中ip核生成时的warning如何去掉
quartus ip核破解
quartus ii的IP核中的 sincos核怎么使用?
quartusII FFT ip核
vivado 调用IP核 详细介绍
【锆石A4 FPGA试用体验】IP核之PLL(一)新建IP核
一款USB OTG IP核的设计与实现,不看肯定后悔
什么是IP核保护技术?
使用Arm DesignStart处理器核搭建SoC流程
关于IP核
关于altera系列芯片FIR IP核在使用过程中的问题
关于fpga的IP核
可以在EDK中使用ISE的IP核吗?
基于IP核的SoC接口技术
基于IP核的PCI总线接口设计与实现
基于SOC/IP的智能传感器设计研究
基于FPGA的IP核的DDS信号发生器如何用IP核
基于FPGA的FFT和IFFT IP核应用实例
基于FPGA的USB接口IP核设计
基于层次模型的USB2.0接口芯片IP核固件的设计
如何在SOPC的NiosII中设计LCD显示驱动IP核?
如何将IP软核与硬核整合到芯片上,两者有什么对比区别?具体怎么选
如何根据Xilinx官方提供的技术参数来实现对IP核的读写控制
如何获得打印机接口IP核?
如何设计RS232异步串行口IP核?
怎么在FPGA上对OC8051 IP核的修改与测试?
怎么在Vivado HLS中生成IP核?
怎样使用Arm DesignStart计划开放的处理器核搭建SoC系统呢
玩转Zynq连载21——Vivado中IP核的移植
详细操作 vivado 调用IP核(附图)
请教使用IP核的latency问题
请教大神怎样使用ARM DesignStart计划开放的处理器核搭建SoC系统呢
请问下什么叫不可使用IP核?
请问成像/视频IP核是否包含在主板附带的软件开发中?
采用EDA软件和FPGA实现IP核保护技术
针对I2C的主方式串行扩展通信的接口IP核设计
面向SoC的开放式IP核接口协议OCP研究

面向SoC的开放式IP核接口协议(OCP)研究

开放核协议—IP核在SoC设计中的接口技术

IP核在SoC设计中的接口技术解析

评论