基于OCP-IP的SOC总线即插即用的实现

发布者:心连心意最新更新时间:2011-05-28 关键字:SOC总线  即插即用 手机看文章 扫描二维码
随时随地手机看文章

    引言

    SOC设计的快速发展是以IP核复用为基础的。IP核的复用极大地提高了SoC系统设计的开发效率,SoC 片上总线的选择是IP核间集成与互连的关键技术之一。目前片上总线如ARM公司提出的AMBA总线、OPEN CORES组织提出的WishBONe总线、IBM公司提出的CoreConnect总线等。SoC片上总线的多样性对IP核的封装规范提出了要求。标准的IP核封装规范有助于提高IP核的复用甚至实现核的即插即用。基于提高IP核复用以及即插即用目的,OCP-IP组织提出了OCP-IP标准。

  1 OCP-lP标准介绍

  1.1 OCP协议

  OCP(Open Core Protoco1)标准是OCP-IP组织制定的一种以提高IP核的复用及实现IP核的即插即用为目的的IP核标准。SoC芯片设计不再是门级的设计,而是IP核复用及其接口的设计。IP核要集成到一个SoC系统中,要考虑很多问题,例如:模块间的同步,如全局执行、数据交换的同步操作等;协议转换匹配,不同IP核模块间可能使用不同的协议,这样必须考虑协议转换的问题。这些问题给IP复用带来了一定的难度,并使SoC芯片的time-to-market (上市时间)延长。为解决这些问题,一些大公司提出了自己的总线接口标准,如ARM的AMBA总线、IBM的CoreConnect总线、Altera的 Avalon总线等。因为核的多样性,使用完全相同的总线接口是不现实的。这就意味着,如果总线A上的一个IP核要移植到另一系统的总线B上,就需要更改此IP的接口以及数据交换的方式。如果设计者不了解总线B的数据交换协议,这样就对SoC系统的开发带来一系列困难。OCP-IP正是针对这些问题提出的。OCP协议是免费的,独立于具体的总线。它将软件中的分层概念应用到IP核接口,提供一种具有通用结构定义、可扩展的接口协议,能完全满足IP内核通信机制的所有要求,方便了IP核与系统的集成。

  OCP协议使IP核的功能与系统的接口无关,设计人员不需要了解IP核的功能也能利用它进行系统设计。OCP接口允许设计者根据不同的目的配置接口,包括接口的数据宽度、交换的握手协议等,并且在SoC设计中可以裁剪核的功能,降低设计复杂性,减小面积,同时满足SoC的要求;OCP接口还保持核在集成到系统的过程中完全不被改变(即在总线宽度、总线频率或电气负载有变化时核保持不变)。使用OCP接口的设计可以交付即插即用的模块,同时支持核的开发与系统设计并行,节省设计时间。

  OCP采用套接口(socket)的方法实现IP核的即插即用,如图1所示。Target Bus A表示总线A,Target Bus B表示总线B。不论总线A或者总线B是哪一类总线协议,只要总线上提供了OCP的接口,那么符合OCP协议的IP核就可以随意集成到任意总线上去,不需要重新设计IP核的接口。



  1.2 OCP通信方式

  OCP协议定义了两个通信实体问点到点的接口。其中一个实体作为通信的主体(Master),另一个作为从体(Slave)。只有MaSTer可以发命令,Slave响应Master的命令,接收或发送数据。封装接口模块必须担当每个连接实体的对应端,当连接实体是Master时,封装接口模块就作为对应的Slave;当连接实体是Slave时,封装接口模块作Master。

  OCP的系统架构如图2所示。图中有3个IP核,其中左边标有主控的IP核是通信的发起方或者主控方,称为Master;最右边标有目标的是通信的目标对象,称为Slave;中间的IP核既可作为Master又可作Slave;下面的框代表OCP-IP封装接口模块;从Master出来并进入Slave的箭头表示OCP请求命令,从Slave出来并进入Master的箭头表示OCP的响应。2个IP核通过接口通信的过程是:功能为Master的IP核发出请求命令给对应的Slave端(总线封装接口模块);封装接口模块将请求命令转换成对应的总线命令传送给接收方的总线封装模块;接收方的总线封装模块再作为Master,把对应的内部总线传输转换成标准的OCP命令传送给目标IP核,目标IP核接收到命令并响应命令和返回读写的数据。

  2 基于AMBA总线的OCP接口设计

  AMBA(Advaneed Microcontroller Bus Architecture)总线规范是ARM公司设计的一种用于高性能嵌入式系统的总线标准。AMBA总线规范是开放标准,通过ARM公司的授权就可以免费获得。它独立于处理器和制造工艺技术,增强了各种应用中的外设和系统IP核单元的可重用性。2.O版AMBA标准定义了3组总线:AHB(AM-BA高性能总线)、ASB(AMBA系统总线)、和APB(AM-BA外设总线)。AHB总线应用于要求高速度高带宽的系统。本文以AHB总线为例,说明OCP -IP如何集成到SOC系统总线上。AMBA总线基本传输时序如图3所示。HCLK表示AMBA系统时钟,HADDR[31:0]表示32位地址总线, HWDATA[31:O]表示32位写操作时的数据总线,HREADY是AMBA总线的读写状态信号(状态为低电平时,表示一次读写操作完成), HRDATA[31:0]表示读操作时的数据总线。

  OCP-IP核的功能是可裁剪的,即OCP-IP的大部分信号都是可选择的。根据核的功能,选择使用不同的信号。OCP协议*有三大类型号:数据流信号 (dataflowsignals)、边带信号(sideband)、测试信号(test signals)。数据流信号主要包括:基本信号(basic signals)、简单扩展信号(simple extensions signals)、突发扩展信号(burst exten-sions signals)和线程扩展信号(thread extensions signals)。边带信号主要包括:复位(。Reset)、中断(Interrupt)、错误(Error)等信号。测试信号主要包括用于支持扫描 (Scan)、时钟控制和IEEE 1149.1(JTAG)的信号。此处用到的OCP信号包括:Reset(复位)、Clk(时钟)、En-ableClk(时钟使能)、MAddr(地址)、MCmd(命令)、MData(数据)、SCmDACcept(命令接受)、SData(Slave数据)、SResp(操作成功标志)。简单的 OCP读写时序如图4所示。Request Phase表示请求阶段,Response Phase表示响应阶段。A处由系统Master发出1个WR写命令,并给出地址A1和数据D1。随即Slave发出命令接受响应ScmdAccept,此处一个周期完成了一个写周期操作,不需要Slave给出写操作成功响应。C处系统Master发出一个RD读命令,并给出要读取的地址A2。Slave 随即给出命令接受响应信号SCmdAccept,在下一个时钟周期D处Slave给出要读取的数据D2并在Slave响应信号SResp上给出读操作成功标志DVA。此处读操作用了2个时钟周期。


  OCP-IP跟AMBA总线的通信通过设计2个状态机来实现,1个用于接收AMBA总线上的流水数据,1个用于发送接收的数据并以OCP标准的方式发送。接收数据的状态机编码如下:


  H_CTRL_PHASE1用于存储第1级流水指令,H_CTRL_PHASE2用于存储第2级流水指令,其状态转移图如图5所示。当AMBA总线上发出第1个读写指令,状态机进入H_CTRL_PHASE1状态,并将第1个读写指令转换成OCP命令。因为AMBA总线是基于流水的操作,所以第2条指令的发出不需要等第1条指令执行结束。这时候,状态机进入H_CTRL_PHASE2状态,并将此指令存储起来,等OCP命令执行结束立即将此存储的指令转换成OCP命令。这时如果AMBA总线上再次发出第3条指令,则状态机进入H_CTRL_PHASE1状态,并存储此指令。




  发送接收到的数据的状态机编码如下:

  状态转移图如图6所示。当接收数据的状态机接收到AMBA总线上的命令时,状态机让OCP接口进入第1个读写操作状态,即READl状态或者WRITE1 状态。如果AMBA总线上有持续的流水操作命令,状态机进入READ2状态或者WRITE2状态,即在AMBA流水操作的条件下,以1结尾的状态的下一个状态一定是以2结尾的状态,反之以2结尾的状态的下一个状态一定是以1结尾的状态。



  3 OCP-IP标准封装软件设计

  OCP是一种IP的标准,但不仅仅是IP的接口和数据的交换方式,还规定了IP的配置、端口等信息,即所谓的OCP配置文件。读取OCP配置文件中的内容,就可以知道此IP对应的OCP接口的性能,从而对总线上的接口进行配置,进而实现IP的即插即用。虽然IP的功能是多样的,总线的数据交互方式也是多样的,但OCP接口的时序是固定的。这样就可以通过设计软件提取IP的端口信息,并自动生成相应的OCP接口模块。该封装软件运行流程如图7所示。用户的 IP可以直接挂在该SOC平台上进行验证,同时也可以直接集成到其他带有OCP接口的SoC系统中去,加快IP的验证和系统的设计。

  封装软件采用MFC(微软基础类库)来编写。通过设计用户界面,用户只要输入IP的时钟、地址、数据、读写控制信号等,就可以自动生成1个OCP的接口,以及标准的配置文件,从而实现IP的即插即用以及IP的统一管理。

  4 结语

  OCP是免费的基于点对点传输的IP核的标准协议,可重配置以及可扩展性很强,可以实现真正意义上的IP核即插即用,减少SoC系统设计的时间。本文讨论了OCP-IP的协议与特点,设计了基于AMBA总线的OCP-IP接口,提出了一种IP自动封装的方法,为IP核的集成和管理带来极大的方便。

关键字:SOC总线  即插即用 引用地址:基于OCP-IP的SOC总线即插即用的实现

上一篇:CAN通信卡的Linux设备驱动程序设计实现
下一篇:基于RS - 485 总线的数据采集系统

推荐阅读最新更新时间:2024-05-02 21:24

Trinamic推出即插即用智能步进电机系统,高精度、可靠性
Trinamic的PD-1378 PANdrive智能步进电机系统结合了强大的步进电机和闭环驱控操作, 具有更高的精度、可靠性、效率和安全性。 TRINAMIC运动控制有限公司宣布推出其最新的 PANdrive™智能电机产品线, 增加了PD-1378该产品配备了性能卓越的步进伺服驱动控制器。 一个完整的机电一体化解决方案,闭环驱动控制部分支持12…48V直流电压和9A RMS电流的驱动功率,易于使用的PANdrive通过CAN总线接口进行控制,支持CANopen或TMCL协议。 “借助现成的高集成电机机构,机器制造商可以提高效率并缩短新设备的上市时间。凭借行业领先的运动控制功能集成化设计,工程师可以更专注于使其产品与
[工业控制]
Trinamic推出<font color='red'>即插即用</font>智能步进电机系统,高精度、可靠性
ADI公司即插即用型天线芯片
帮助航空电子和通信设备设计人员简化相控阵雷达设计 中国,北京 — Analog Devices, Inc. (ADI)今日推出高集成度有源天线波束成形芯片ADAR1000,其支持相控阵雷达和通信系统设计人员利用紧凑的固态解决方案快速取代庞大的机械转向天线平台。ADAR1000芯片可简化设计,显著缩减空中交通管制、监控、通信和天气监测所用相控阵雷达系统的尺寸、重量及功耗。对于航空电子设计人员而言,ADAR1000支持平板天线阵列,这可以缩小传统雷达系统的外形尺寸,有助于设计出更小更轻的飞机。新型ADAR1000是即插即用型芯片,使得没有或仅有很少射频经验的设计人员也能扩展雷达系统的性能并延长其工作寿命。 4通道ADA
[测试测量]
ADI公司<font color='red'>即插即用</font>型天线芯片
滑铁卢大学研发的即插即用车轮组件旨在提高电动汽车的产量
虽然特斯拉电动汽车等可能引发了大量关注,但许多电动汽车实际上是专为城市使用而设计的小型车辆,由苦苦挣扎的创业公司制造。通过简化设计和生产流程,新的车轮模块可以帮助提高构建此类车辆的经济可行性。 该组件由加拿大滑铁卢大学的一个团队创建,每个独立单元包括一个带集成电动机的车轮,以及制动、悬架、转向和控制系统(由车辆现有的电池组供电)。 汽车制造商可以简单地将预制的车轮单元固定在汽车车架的角落上,而不必从头开始设计和制造所有这些独立的部件。然后,转向、加速和制动命令将以电子方式从车厢传递,而不是机械地传递。作为这种安排的附带好处,其取消了诸如转向柱之类的部件,车内将有更多的空间用于乘客或货物。 在该技术的当前状态下,每个模块重约4
[汽车电子]
滑铁卢大学研发的<font color='red'>即插即用</font>车轮组件旨在提高电动汽车的产量
电源系统设计:非完全“即插即用
许多年前,我们就已经开始使用“即插即用”一词来描绘一些易于使用的事物了。与过去相比,如今许多复杂设备在设置、配置和启用等方面都要比以往便捷得多。 今天,客户希望产品可以“开盒即用”。这样的期望与过去相比或多或少得到了合理满足。然而,这种外在的简单性却稍含欺骗成分。作为工程师,我们必须花更多心思简化产品的外在使用,尽管其内部可能相当复杂。 按照这种趋势,IC 组件供应商已经在努力简化其部件,充分满足系统设计人员的使用需求。与不久的过去相比,大多数 IC 产品说明书都提供详细的设计方程式、外部组件选择指南,乃至建议性 PCB 布局图,可帮助将给定 IC 整合于系统级设计。几乎所有编录中的 IC 都提供有评估套件,以帮助系统设计人员在开
[电源管理]
电源系统设计:非完全“<font color='red'>即插即用</font>”
有Tarari 电路板解决方案 木马将无所遁形
LSI 公司日前宣布推出四系列全新 Tarari “即插即用型” 内容与安全处理器电路板,旨在满足从入门级到高性能网络的深层数据包检测要求。这些全新的解决方案采用创新的Tarari T10 芯片与软件架构,可为 OEM 厂商提供强劲的动力和高度的灵活性,使其能够经济有效地解决各种网络安全问题。 除了提供基于芯片的专用标准产品和定制芯片外,LSI 现可在业界面向深层数据包检测提供各种尺寸外形的电路板。这些全新的电路板可与不同尺寸外形的标准 PCIe、微型 PCIe、微型 PCI以及高级整合型适配卡 (AdvancedMC™) 等完美搭配,从而使 Tarari 内容和安全处理器解决方案轻松集成于现有网络安全、服务质量、基
[测试测量]
集成数字电源管理的DC/DC转换器支持即插即用
当电子系统变得日益复杂且功能更加丰富时,对板级电源管理与控制的要求也变得越来越复杂,单个PCB上不同提供多个低电压、高电流是设计人员经常要面对的问题。将电源转换架构与电源管理用数字方法集成到单芯片,实现智能化且高效的转换与控制,已经在Zilker Labs的ZL2005得到体现。继ZL2005之后,Zilker Labs又拓展了适合低功耗应用的ZL2105。 ZL2105除了继承ZL2005的数字电源管理功能、简单的可配置性及高效率外,还进一步集成了MOSFET和升压二极管。Zilker Labs创始人兼市场营销副总裁Jim Templeton称,ZL2105是业界首款整合了全数字电源管理功能的3A电源转换单芯片,配置灵活
[电源管理]
集成数字电源管理的DC/DC转换器支持<font color='red'>即插即用</font>
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved