本发明专利技术公开一种可综合的CPU模型,本CPU模型配置多个总线接口,每个总线接口均有自己的ID。所述CPU模型包括指令获取模块、指令解析模块、数据比较模块、接口仲裁路由模块和总线协议生成模块。指令获取模块用于获取模型运行所需的指令,并将指令提供给指令解析模块;指令解析模块将编译后的指令解析成CPU能够识别的二进制,达到区分指令功能的目的,然后将解析后的指令传递至数据比较模块;数据比较模块将执行完指令的结果与收到的指令进行比较,从而判断指令是否正确执行;接口仲裁路由模块根据指令内容决定发送的总线端口;总线协议生成模块将接收到的指令或数据按照总线协议格式发送到总线接口。送到总线接口。送到总线接口。
【技术实现步骤摘要】
一种可综合的CPU模型
[0001]本专利技术涉及一种可综合的CPU模型,用于CPU与总线之间的逻辑功能验证。
技术介绍
[0002]随着集成电路的不断发展,系统设计的规模越来越大,模块划分的也越来越复杂,作为调度系统工作的核心CPU,显得也越来越重要。一般CPU作为系统的重要组成部分,多采用授权的IP,使用的灵活性和便利性均受到限制。在整个ASIC设计过程之中,前期需要配置CPU参数,将CPU集成进系统,进行RTL仿真,后期还需要进行FPGA综合下板子调试。经过一系列的行为才能通过CPU调度整个系统,观察整个系统的行为是否符合预期。但是若只是验证CPU外的逻辑功能,这将带来巨大的时间成本以及人力成本。
技术实现思路
[0003]针对现有技术的缺陷,本专利技术提供一种可综合的CPU模型,通过模仿CPU的行为,驱动不同类型总线进行系统的读写等操作,来实现CPU系统对外围模块的配置和使用,达到CPU系统原型验证的目的,甚至可以在简单的无需复杂运算的场合,实现对CPU的全替换。
[0004]为了解决所述技术问题,本专利技术采用的技术方案是:一种可综合的CPU模型,本CPU模型配置多个总线接口,包括指令获取模块、指令解析模块、数据比较模块、接口仲裁路由模块和总线协议生成模块;所述指令获取模块用于获取模型运行所需的指令,并将指令提供给指令解析模块;指令解析模块实现对编译后的指令解析成CPU能够识别的二进制,达到区分指令功能的目的,然后将解析后的指令传递至数据比较模块;数据比较模块将执行完指令的结果与收到的指令进行比较,从而判断指令是否正确执行;接口仲裁路由模块根据指令内容决定发送的总线端口;总线协议生成模块将接收到的指令或数据按照总线协议格式发送到总线接口,达到将数据转换成标准总线协议接口的功能。
[0005]进一步的,所述指令获取模块为指令存储模块、指令读取模块、外设接口中的一种或多个组合。
[0006]进一步的,指令获取模块为多个组合时,CPU模型设置指令获取启动模块,所述指令获取启动模块为外部引脚接拨码开关。
[0007]进一步的,本CPU模型挂载的总线接口类型包括AHB总线接口、APB总线接口和AXI总线接口。
[0008]进一步的,本CPU挂载AHB总线接口时,指令获取模块获取的指令包括PORTID、CMD、W/R、BURST、SIZE、ADDR、DATA共7部分,PORTID指明发送的指令或数据到达哪个总线接口,CMD表示发送的是数据还是指令,W/R表明该笔传输是读还是写,BURST代表该笔传输的
burst类型,SIZE表示该笔传输的数据大小,ADDR为接受命令的具体地址,DATA为发送的具体数据。
[0009]进一步的,本CPU挂载APB总线接口时,指令获取模块获取的指令包括PORTID、CMD、W/R、ADDR、STRB、DATA共6部分,PORTID指明发送的指令或数据到达哪个总线接口,CMD表示发送的是数据还是指令,W/R表明该笔传输是读还是写,ADDR为接受命令的具体地址,STRB为APB 4使用的STRB信号,DATA为发送的具体数据。
[0010]进一步的,本CPU挂载AXI总线接口时,指令获取模块获取的指令包括PORTID、CMD、W/R、BURST、SIZE、LENGTH、ADDR、DATA共8部分,PORTID指明发送的指令或数据到达哪个总线接口,CMD表示发送的是数据还是指令,W/R表明该笔传输是读还是写,BURST代表该笔传输的burst类型,SIZE表示该笔传输的数据大小,LENGTH表示此次传输的数据长度,ADDR为接受命令的具体地址,DATA为发送的具体数据。
[0011]进一步的,本模型支持的协议包括AHB、AHB
‑
lite、AMBA 2 APB、AMBA 3 APB、AMBA 4 APB、AXI3、AXI4、AXI4
‑
LITE。
[0012]本专利技术为一种可综合的CPU模型,有以下有益效果:1、模型为完全可综合设计,可以实现对系统的原型验证;2、可根据系统需求,配置支持的总线接口个数;3、在无需复杂运算的场合可实现对CPU的替代,突破对CPU IP的依赖;4、该模型较传统CPU而言,结构简单,可以通过较少的模块来实现传统的CPU的功能,从而提高指令执行的效率;5、用该模型替换传统的CPU,可以减少RTL集成复杂度,减少CPU配置参数的复杂度,从而用较少的时间即可验证系统电路逻辑功能的正确性,减少项目整体的开发周期。
附图说明
[0013]图1为实施例1所述可综合CPU模型框图;图2为内嵌指令存储的可综合CPU模型框图;图3为从外部存储读取指令的可综合CPU模型框图;图4为外设接口获取指令的可综合CPU模型框图;图5为挂载AHB总线接口时,指令结构示意图;图6为挂载APB总线接口时,指令结构示意图;图7为挂载AXI总线接口时,指令结构示意图。
具体实施方式
[0014]下面结合附图和具体实施例对本专利技术做进一步的说明。
[0015]实施例1本实施例公开一种可综合的CPU模型,如图1所示,本CPU模型挂载n个总线接口,n为大于1的正整数,n可根据系统需求配置。
[0016]CPU模型包括指令获取模块、指令解析模块、数据比较模块、接口仲裁路由模块和总线协议生成模块。
[0017]所述指令获取模块用于获取模型运行所需的指令,并将指令提供给指令解析模
块;指令解析模块实现对编译后的指令解析成CPU能够识别的二进制,达到区分指令功能的目的,然后将解析后的指令传递至数据比较模块;数据比较模块将执行完指令的结果与收到的指令进行比较,从而判断指令是否正确执行;接口仲裁路由模块根据指令内容决定发送的总线端口;总线协议生成模块将接收到的指令或数据按照总线协议格式发送到总线接口,达到将数据转换成标准总线协议接口的功能。
[0018]本实施例中,所述指令获取模块由指令存储模块、指令读取模块、外设接口组合而成,三种模块均可实现指令获取。为了确定指令获取的方式,CPU模型设置指令获取启动模块,所述指令获取启动模块为外部引脚接拨码开关,通过拨码开关确定由三个模块中的一个来获取指令。
[0019]实施例2本实施例中,如图2所示,所述指令获取模块为指令存储模块,即通过内嵌指令存储的方式获取指令,获取后的指令传递至指令解析模块。
[0020]实施例3如图3所示,本实施例的指令获取模块为指令读取模块,即通过外部存储读取指令的方式获取指令,获取后的指令传递至指令解析模块。
[0021]实施例4如图4所示,本实施例的指令获取模块为外设接口,即通过外设接口获取指令,获取后的指令传递至指令解析模块。
[0022]上述三种实施例中的CPU模型均可以挂载包括AHB总线接口、APB总线接口和AXI总线接口在内的AMBA总线接口。
[0023]如图5所示,CPU模型挂载AHB总线接口时,指令获取模块获取的指令包括PORTID、CMD、W/本文档来自技高网...
【技术保护点】
【技术特征摘要】
1.一种可综合的CPU模型,其特征在于:本CPU模型配置多个总线接口,每个总线接口均有自己的ID;所述CPU模型包括指令获取模块、指令解析模块、数据比较模块、接口仲裁路由模块和总线协议生成模块;所述指令获取模块用于获取模型运行所需的指令,并将指令提供给指令解析模块;指令解析模块将编译后的指令解析成CPU能够识别的二进制,达到区分指令功能的目的,然后将解析后的指令传递至数据比较模块;数据比较模块将执行完指令的结果与收到的指令进行比较,从而判断指令是否正确执行;接口仲裁路由模块根据指令内容决定发送的总线端口;总线协议生成模块将接收到的指令或数据按照总线协议格式发送到总线接口,达到将数据转换成标准总线协议接口的功能。2.根据权利要求1所述的可综合的CPU模型,其特征在于:所述指令获取模块为指令存储模块、指令读取模块、外设接口中的一种或多个组合。3.根据权利要求2所述的可综合的CPU模型,其特征在于:指令获取模块为多个组合时,CPU模型设置指令获取启动模块,所述指令获取启动模块为外部引脚接拨码开关。4.根据权利要求1所述的可综合的CPU模型,其特征在于:本CPU模型挂载的总线接口类型包括AHB总线接口、APB总线接口和AXI总线接口。5.根据权利要求4所述的可综合的CPU模型,其特征在于:本CPU模型挂载AHB总线接口时,指令获取模块获取的指令包括PORTID、CMD、W/R、BURST、SIZE、ADDR、DATA共7部分,PORTID指明发送的指令或数据到达哪个总线接口,CMD表示发送的是数据还是指令,W/R表明该笔...
【专利技术属性】
技术研发人员:师开伟,孙中琳,
申请(专利权)人:山东华芯半导体有限公司,
类型:发明
国别省市:
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。