发送接收到的数据的状态机编码如下:
状态转移图如图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的统一管理。
结 语
OCP是免费的基于点对点传输的IP核的标准协议,可重配置以及可扩展性很强,可以实现真正意义上的IP核即插即用,减少SoC系统设计的时间。本文讨论了OCP-IP的协议与特点,设计了基于AMBA总线的OCP-IP接口,提出了一种IP自动封装的方法,为IP核的集成和管理带来极大的方便。