FPGA的配置方式PS——Passive serial

2024-02-05 07:38

本文主要是介绍FPGA的配置方式PS——Passive serial,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

FPGA的配置方式PS——Passive serial


    FPGA的配置方式,很多种,前一段时间主要用了一下PS——Passive serial,被动串行的加载方式。在这个模式下,FPGA被动的等待配置起始信号,然后接受配置文件,完成配置。即每次在FPGA上电时,由外部器件完成FPGA的配置。

    这个方式的实现(或者说选择),是由FPGA的硬件连接来完成的,硬件连接如下图:


MSEL这组信号决定了FPGA的配置方式:


(根据官方文档的说明,这两个管脚不要连接在微控制器上或者其他的器件上来做下载方式的选择,也不要使用电阻上拉或下拉,最好直接连载在VCC或者GND上)

可以看到上图选择了Passive serial的配置方式,除了MSEL这组信号,其他的信的如下:

nCEo:这个可以理解为nCE out用于给多片FPGA配置时使用;

CONF_DONE:这个信号信号是一个开路输出,也就是上面为甚都是上拉,一句话就是这个信号就是当FPGA配置完成后,告诉主控,我配置结束了。

nSTATUS:一样,开路输出,需上拉,这个信号反应FPGA的配置过程状态的信号,一会儿看时序图。

nCE:chip select,用来选择当前的FPGA,如果有多片,这个就有用了;

DATA0,DCLK:俩个配置过程正真干活的信号,数据和时钟,DCLK上升沿,FPGA采集DATA0的信号,至于放哪里,FPGA内部自己搞定了;多说一句,FPGA中,除了LE,PLL等用户可用的逻辑,其实还是有一些他的控制逻辑的,就比如这个控制PS,还有控制AS;

nCONFIG:这个信号很重要,由主控告诉FPGA,要开始配置了,即产生起始信号。

上图就完成了整个PS配置的硬件连接,其中External Host选择MAX II系列的CPLD,memory选择一片flash;

CPLD作为配置FPGA的Host,需要一段代码逻辑来完成这个功能,例如需要读取flash、需要给flash加载FPGA的配置文件、需要配置FPGA。那这不是苦大仇深了,还要研究flash的读写时序和FPGA的配置时序?统统不用,Altera提供了这个方案,肯定是有相关的IP,在Altera的IP核生成工具里面选择Parallel Flash Loader这个IP,然后对IP做一些简答的配置,如下图:

虽然都由IP核完成,但是最少得明白IP核干了些神马工作,IP对FPGA的配置时序如下,至于关键的时序是多少,我们并不去实现这个IP,所以不用了解,但是他们在相应的器件手册中都有:


从上图中,我们可以看到整个配置过程如下:

1、  nCONFIG在被CPLD配置为低电平后,一个上升沿表示要开始配置FPGA;

2、  上升沿结束后,FPGA的nSTATUS由低电平被FPGA释放,有外部的电阻上拉为高电平,告诉CPLD,FPGA已经接受到其实信号,开始接受数据;

3、  接下来,DCLK和DATA开始传输信号;

4、  当传输完成之后,FPGA将CONF_DONE释放,并有外部电阻上拉,表示配置结束;

5、  FPGA内部完成初始化,进如user mode ,开始执行用户的逻辑。

这篇关于FPGA的配置方式PS——Passive serial的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/680195

相关文章

win10安装及配置Gradle全过程

《win10安装及配置Gradle全过程》本文详细介绍了Gradle的下载、安装、环境变量配置以及如何修改本地仓库位置,通过这些步骤,用户可以成功安装并配置Gradle,以便进行项目构建... 目录一、Gradle下载1.1、Gradle下载地址1.2、Gradle下载步骤二、Gradle安装步骤2.1、安

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

java程序远程debug原理与配置全过程

《java程序远程debug原理与配置全过程》文章介绍了Java远程调试的JPDA体系,包含JVMTI监控JVM、JDWP传输调试命令、JDI提供调试接口,通过-Xdebug、-Xrunjdwp参数配... 目录背景组成模块间联系IBM对三个模块的详细介绍编程使用总结背景日常工作中,每个程序员都会遇到bu

Java发送SNMP至交换机获取交换机状态实现方式

《Java发送SNMP至交换机获取交换机状态实现方式》文章介绍使用SNMP4J库(2.7.0)通过RCF1213-MIB协议获取交换机单/多路状态,需开启SNMP支持,重点对比SNMPv1、v2c、v... 目录交换机协议SNMP库获取交换机单路状态获取交换机多路状态总结交换机协议这里使用的交换机协议为常

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的