0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于CPLD的多DSP和FPCA芯片怎样远程更新

PCB线路板打样 来源:互联网 作者:互联网 2019-11-13 17:42 次阅读

摘要:介绍了一种以CPLD为基础的对多DSPFPCA芯片实现程序远程更新、加载的设计方法。详细分析了软硬件架构及具体实施方案,对以DSP+FPCA为架构的信号处理模块实现远程更新、加载,有重要的使用价值。

关键词:远程加载;CPLD;FPGA器件;DSP

随着硬件技术的大力发展和加工丁艺技术的不断提升,芯片技术日益成熟,软件无线电技术得到广泛应用和迅猛发展。无线电系统在整体体系结构上发生了重大变化,正沿着综合化、模块化、通用化和智能化的方向快速推进。无线电系统将模块化、标准化的硬件构成基本平台,通过软件加载技术来实现尽可能多的功能,为多种信号的功能综合和互联互通提供了技术保障。随着模块应用灵活性要求的不断增加,软件维护及升级需求的日益迫切,给软件加载技术提出了更高要求。本文提出了一种基于CPLD的多处理器远程加载管理设计应用方案,系统实现了从远端下发命令字和更新数据即可完成模块的程序更新升级和重新加载,实现软件维护和模块功能切换,满足日益复杂的系统使用要求。

1 数字处理模块

数字处理模块主要完成基带信号调制解调、RS编解码算法实现、收发通道实时控制、导航算法实现、信息层的协议实现以及大量的数据融合算法实现等。硬件设计采用了FPGA+DSP的设计构架,以1颗Altera公司的Stratix系列FPGA和4颗TI公司的DSP作为设计核心完成以上功能实现,框图如图1所示。系统要求数字处理模块要适应系统通用化和智能化的设计要求,具备远程自动更新升级、加载等功能,为系统功能多样化、维护简易化打下基础。根据系统要求和模块设计实际,结合CPLD芯片稳定性高、设计灵活的自身特点,确定采用CPLD作为整个数字处理模块的功能管理芯片,实现对整个处理模块的电源管理、状态检测、上电复位管理、各DSP及FPGA的程序加载管理、远程更新等功能处理。

当系统需要对本模块的软件进行升级或者模块功能重构时,系统将更新命令字和更新内容通过SEDERS总线下发至DSP4,再送入CPLD进行解码、识别分类,根据指令要求启动CPLD对FLASH中的相应空间进行擦除、更新操作。当操作完成后,CPLD强行启动DSP或FPCA,重新加载FLASH中的程序,完成系统软件升级或者模块功能重构任务。

基于CPLD的多DSP和FPCA芯片怎样远程更新

2 远程更新硬件实现

远程更新和加载就是系统具有从远端通过下发指令或参数对处理模块中存储的应用程序进行修改升级的功能,模块内部控制单元启动加载模块,完成模块功能重构。反映到硬件功能就是主控芯片要具备擦除、读写模块内存储芯片的功能,可以控制模块内的各处理器及可编程器件重新加载运行新程序。数字处理模块采用4颗DSP芯片和1颗FPGA来完成系统的数据处理任务,因此在系统升级时需要对4个处理器或部分处理器及FPCA的程序进行更新并重新加载。所以主控芯片要具备擦除、读写各DSP和FPCA芯片挂接的FLASH芯片,并能对其完成程序加载。

硬件设计时FLASH芯片采用了集中式设计,多个DSP芯片和FPGA分段共享同一片大容量FLASH。共享存储器有利于提高模块可靠性、模块小型化设计、有利于主控模块对其操作控制,有效降低功能实现复杂度,也有利于扩充模块功能。一般FPGA设计多采用挂接与之匹配的FLASH芯片,这些专用存储芯片不但具备专用接口与FPGA匹配,而且内部嵌入了FPCA信息,硬件设计时只需要将FPCA设计成主动加载模式即可。系统上电后FPGA将自动识别存储器并完成程序加载,整个过程不需要外部干预。但对于通用存储芯片来说FPGA是无法实现自动加载的。而且这种远程控制也是要通过外部干预来实现的,所以FPGA只能设计为被动模式,通过主控模块完成加载过程。而ALTERA公司专门研发了一款MAXⅡ系列的CPLD来实现StratixⅢ系列FPGA的加载管理CPLD硬件框图如图2所示。

基于CPLD的多DSP和FPCA芯片怎样远程更新

2.1 通用接口存储器(CFI Flashl更新

系统将更新数据从上位机下发至处理模块。经过CPLD解码、识别系统更新要求。CPLD将启动擦写模块,对CFI_Flash的相应空间段进行数据擦除操作,同时将更新数据写入存储器中,实现系统程序升级更新。其流程框图如图3所示。

基于CPLD的多DSP和FPCA芯片怎样远程更新

2.2 程序重构

当CPLD按照系统要求将CFI Flash中程序更新完毕后,就会自动唤醒加载模块,对已更新的处理器或FPGA的程序进行重新加载。DSP的加载相对简单,将DSP设计成主机口加载模式,设计框图如图4所示。由CPLD强行复位相应DSP使其进入加载状态,然后从CFI_Flash中分别读出各DSP的目标数据,按照主机口加载时序写入DSP的内部静态存储区,加载完毕再对DSP初始化控制寄存器进行设置,完成加载过程并唤醒各DSP重新运行新程序。完成模块处理器的功能重构工作。

基于CPLD的多DSP和FPCA芯片怎样远程更新

对Stratix系列的FPGA而言,加载过程相对复杂,实现起来比较困难,因为FPGA在加载过程中不仅要满足时序控制,而且加载的数据内部还含有一定的器件信息,需要满足消息格式和CRC校验才能顺利完成加载。而器件信息和CRC校验方程用户是无法得到的,因此只能采用Alte ra公司设计的MAXⅡ系列CPLD来完成加载过程。这款CPLD内部自带一个并行加载模块(PARALLEL FLASHLOADER),此模块对FPCA有专用加载接口,内部嵌入了FPGA的加载控制时序及器件信息,象一道桥梁将FPCA和通用存储器无缝连接,但硬件设计时FPGA必须设置为被动加载方式,如图5所示。系统需要对FPGA程序重构时,只需通过逻辑启动CPLD的PFL模块,PFL模块从通用存储器中读取配置数据,并且将配置数据进行格式转换打包、CRC校验后按照FPGA的加载时序写入FPGA内部,然后上拉配置完成标志位来启动新程序运行,实现FPGA的功能重构。

基于CPLD的多DSP和FPCA芯片怎样远程更新

利用MAXⅡ系列CPLD不仅可以实现单个FPGA程序的加载,也可以根据实际应用需求通过硬件扩展以及在CPLD中增加泽码控制逻辑实现多个FPCA的加载。满足系统复杂的使用要求。

3 结束语

本设计采用MAXⅡ系列CPLD作为数字处理模块的主控芯片,来实现整个模块工作状态检测、时序管理以及多个DSP芯片和FPGA芯片的程序更新升级和加载,充分利用MAXⅡ系列CLPD芯片的硬件资源、合理调用内嵌加载逻辑模块,有效规避FPGA芯片与通用Flash芯片接口不匹配带来的设计缺陷,简化了FPGA芯片程序加载复杂度。不仅可以远程控制更新重构,还可实现动态重构,这都给处理器芯片以及FPGA芯片的加载方式和应用提出了更高的要求。

本模块已经随某通信终端完成了试飞鉴定测试,模块各项指标优异、远程更新、重构功能稳定可靠,均达到了设计要求。实现了系统模块通用化,波形功能多样化,使用维护智能化的设计要求。

责任编辑:ct

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1630

    文章

    21759

    浏览量

    604319
  • FPC
    FPC
    +关注

    关注

    70

    文章

    962

    浏览量

    63481
  • PCB设计
    +关注

    关注

    394

    文章

    4692

    浏览量

    85874
  • 可制造性设计

    关注

    10

    文章

    2065

    浏览量

    15630
  • 华强pcb线路板打样

    关注

    5

    文章

    14629

    浏览量

    43089
  • 华秋DFM
    +关注

    关注

    20

    文章

    3494

    浏览量

    4596
收藏 人收藏

    评论

    相关推荐

    一文解析芯片封装技术

    芯片封装(Multi-Chip Packaging, MCP)技术通过在一个封装中集成多个芯片或功能单元,实现了空间的优化和功能的协同,大幅提升了器件的性能、带宽及能源效率,成为未来高性能计算
    的头像 发表于 12-30 10:36 252次阅读
    一文解析<b class='flag-5'>多</b><b class='flag-5'>芯片</b>封装技术

    CPLD输出(3.3V)作TLC5510A的时钟,为什么CPLD和板子共地,芯片就发热?

    TLC5510A时钟电压多少伏? 我用CPLD输出(3.3V)作TLC5510A的时钟,为什么CPLD和板子共地,芯片就发热? 谢谢!
    发表于 12-26 07:09

    领域广泛应用,DSP芯片市场有多大?

    从全球范围来看,在数字化应用越来越广的情况下,DSP芯片使用率处于增长态势。那么,DSP芯片目前市场情况如何? 随着通信、消费电子、人工智能等领域的快速发展,对数字信号处理技术的要求也
    的头像 发表于 12-12 10:28 223次阅读
    <b class='flag-5'>多</b>领域广泛应用,<b class='flag-5'>DSP</b><b class='flag-5'>芯片</b>市场有多大?

    怎样配置ADS1261的通道采集模式?

    ADS1261: 怎样配置芯片通道采集模式
    发表于 11-20 06:42

    DSP音效处理芯片有什么作用

    DSP音效处理芯片是一种高级的音频处理技术,它在音频设备中扮演着至关重要的角色。DSP(Digital Signal Processor)即数字信号处理器,是一种专门用于快速实现数字信号处理
    的头像 发表于 09-24 16:11 899次阅读

    chrome插件新版本(v3版本)中的热更新,即加载更新远程js的方法探索

    1 主流方案及尝试 现在浏览器插件中,大多采用直接调用远程代码的方式进行热更新,由于安全策略逐步增强,越来越不支持热更新了;chrome在新v3版本插件中直接给禁止了;对于v2版本则即将废弃
    的头像 发表于 06-14 10:19 848次阅读
    chrome插件新版本(v3版本)中的热<b class='flag-5'>更新</b>,即加载<b class='flag-5'>更新</b><b class='flag-5'>远程</b>js的方法探索

    地发布设备更新“白名单”,仪器采购一触即发

    近日,地发布了设备更新服务机构、优势企业及产品的白名单,诸多仪器设备企业上榜,成为需求方设备更新采购时优先选择的“优质供应商”。
    的头像 发表于 05-23 09:10 454次阅读

    请问STM32F103与CPLD如何通信?

    CPLD芯片型号:EPM570T144C5 ARM芯片型号:STM32F103ZET6 两个芯片布置在同一块PCB上,它们之间的引脚连接如下: 地址线:A0~A15; 数据线:D0~D
    发表于 05-17 07:36

    共享充电宝语音芯片ic方案支持远程4g无线更新语音

    共享充电宝语音芯片ic方案支持远程4g无线wifi蓝牙更新语音 共享充电宝已经是遍布在大街小巷的好产品,解决了携带充电宝麻烦的痛点 但是很多的共享充电宝在人机交互方便,还做得不够好,比如:借、还设备没有语音提示,相关的状态也
    的头像 发表于 05-13 10:29 566次阅读
    共享充电宝语音<b class='flag-5'>芯片</b>ic方案支持<b class='flag-5'>远程</b>4g无线<b class='flag-5'>更新</b>语音

    DSP芯片性能参数有哪些重要指标?

    DSP芯片,即数字信号处理芯片,是一种专门用于数字信号处理的集成电路。它采用程序和数据分开的哈佛结构,具有专门的硬件乘法器,广泛采用流水线操作,提供特殊的DSP指令,可以快速地实现各种
    的头像 发表于 03-21 10:00 2294次阅读

    业务光端机在远程医疗中的应用:推动医疗信息化进程

    随着信息技术的不断发展,远程医疗作为一种新兴的医疗服务模式,正逐渐受到人们的关注。业务光端机作为一种高速、高效的光通信设备,其在远程医疗中的应用,为医疗信息化进程注入了新的活力。 一、
    的头像 发表于 02-23 14:07 481次阅读

    dsp芯片和arm芯片区别 dsp的应用领域

    DSP芯片和ARM芯片都是常见的处理器芯片,但它们在应用领域和架构设计上有着明显的差别。下面将详细介绍DSP
    的头像 发表于 02-01 10:17 6643次阅读

    dsp怎么调音质最好 dsp芯片和单片机的区别

    是使用DSP芯片来处理音频信号。DSP芯片具备强大的浮点计算能力和专用的数字信号处理指令集,可以高效地对数字音频信号进行滤波、均衡、压缩/解压缩等处理,以提高音质。 与
    的头像 发表于 01-25 11:06 1896次阅读

    CPLD和FPGA的区别

    增长。FPGA的LAB以网格阵列排列,随器件密度线性增长。CPLD互连包括LAB本地可编程阵列及中心可编程互连。FPGA器件除了包括本地互连,用于各个LAB,但是和LAB逻辑分开,器件还包括行列互连,这些互连跨过阵列中的多个LAB,以及整个芯片的长宽。
    的头像 发表于 01-23 09:17 1160次阅读

    什么是fpga和cpld cpld与fpga在结构上有何异同

    ,Programmable Logic Device)的一种。它们在数字电路设计中扮演重要的角色,具有高度的可定制性和灵活性。 首先,让我们来了解FPGA和CPLD的基本概念和原理。FPGA是一种集成电路芯片,由一系列
    的头像 发表于 01-22 18:05 2918次阅读