热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【MAX10评测】(四)配置

一般FPGA属于易失性芯片,类似于RAM,芯片上的数据和程序在掉电后不会保留,上电后程序需要从外部非易失性芯片加载,如EPCS系列芯片,也可以通过FPGA上JTAG接口或者串行接口写

         一般FPGA属于易失性芯片,类似于RAM,芯片上的数据和程序在掉电后不会保留,上电后程序需要从外部非易失性芯片加载,如EPCS系列芯片,也可以通过FPGA上JTAG接口或者串行接口写入。

 

         ▲而MAX 10系列FPGA的配置则很灵活,因其芯片内嵌配置闪存模块CFM(Configuration Flash Memory),可用于存放程序映象。如上图所示。MAX 10系列FPGA的配置过程在内部进行,首先通过JTAG将配置数据写入到CFM中,然后内部配置过程自动从CFM加载配置数据至MAX 10的配置内存CRAM(Configuration RAM)。

         深入CFM内部,可分为3个扇区:CFM0,CFM1和CFM2。如下表,MAX 10内部配置可分为5种模式,分别对应对2个扇区的不同使用情况:

 

 

         上表中内部配置共有5种模式:

1)  Dual Compressed Image:双压缩映像

2)  Single Uncompressed Image:单未压缩映像

3)  Single Uncompressed Image with Memory Initialization:单未压缩映像带内存初始化数据

4)  Single Compressed Image with Memory Initialization:单压缩映像带内存初始化数据

5)  Single Compressed Image:单压缩映像

         其中第1,2,5种模式,3个CFM扇区都用于存放映像;而第3,4种模式,未使用的扇区,主要是CFM1和CFM2,可配置成用户闪存模块UFM(User Flash Memory)。

         ▼在QuartusII 14.1中,可设置内部配置的模式,以生成对应的映像文件:

l  打开Device and Pin Options à Configuration;

l  Configuration scheme选择Internal Configuration;

l  Configuration mode中选择5种模式中的1种;

 

 

         可以发现,内部配置模式有一种是Dual Compressed Image,即在CFM中可以存放两个压缩映像,也就是说MAX 10 FPGA支持双启动模式Dual Boot。

 

         下面通过实例演示下MAX 10 FPGA的配置:

 

----------------------------------- 单映像配置 -----------------------------------

         QuartusII 14.1默认配置就是Single Uncompressed Image(912Kbits UFM),因此无需另外设置内部配置模式。

         在LED_FLASH工程的基础上修改了下,将LED的功能由闪烁效果改成呼吸灯的效果:▼新建呼吸灯版本,不同的版本可以在源代码相同的情况下选择不同的工程设置。

 

 

▼修改顶层源码:例化了呼吸灯模块BreathLeds;加粗部分代码,根据宏BREATH_EN选择LED的输出

 1 module LED_Flash_all(
2 input clk,
3 output LED1,
4 output LED2,
5 output LED3,
6 output LED4,
7 output LED5
8 );
9
10 …… (此处省略N行代码)
11
12 // Breath Led
13 wire bled;
14 BreathLeds breathleds_u(
15 .clk(clk),
16 .rst(1'b0),
17
18 .led(bled)
19 );
20
21 `ifdef BREATH_EN
22 assign LED1 = bled;
23 assign LED2 = bled;
24 assign LED3 = bled;
25 assign LED4 = bled;
26 assign LED5 = bled;
27 `else
28 assign LED1 = dec_cntr ;
29 assign LED2 = dec_cntr ;
30 assign LED3 = dec_cntr ;
31 assign LED4 = dec_cntr ;
32 assign LED5 = dec_cntr ;
33 `endif
34
35 endmodule

 

 

▼只在LED_BREATH版本中加入宏:Settings à Compiler Settings à Verilog HDL Input设置中,添加Verilog HDL macro:BREATH_EN。这种方法的好处就是无需在Verilog HDL源码中定义宏

 

 

         工程编译后默认只生成.sof文件,内部配置所需的.pof文件手动从.sof文件转换得到

▼打开File --> Convert Programming Files…

 

 

▼sof --> pof 转换

         1. Mode 选择为 Internal Configuration

         2.设置Options/Boot info…

         3.输入pof文件名

         4.勾选Create Memory Map File项,.map包含CFM和UFM地址,其中含有通过Option/Boot Info选项而进行的ICB设置。

         5.选择sof文件

         6.点击Generate生成pof文件

 

 

▼按以上步骤生成pof文件完成

 

 

▼通过Programmer下载pof,在Program/Configure勾选CFM扇区,由于当前内部配置模式为Single Uncompressed Image,三个扇区都需要使用

 

 

▼点击Start开始下载

 

 

▼下载完成

 

 

▼演示视频

 

----------------------------------- 双映像配置 -----------------------------------

         工程继续使用LED_FLASH,上篇中新建了LED_BREATH版本,工程中共有两个版本:LED_Flash和LED_BREATH▼

 

        

         ▼制作双配置映像,需要相应地在设置中奖内部配置模式设置Dual Compressed Image

 

 

 

         ▼然后开始编译,但是出现了错误Error (169130): Configuration mode specified as Remote but remote update block is not found in design,是缺少了什么模块

 

 

         查阅相关文档,原来是缺少这货:Altera Dual Boot IP,必须在工程中例化这个IP才能实现双映像配置。由于此IP接口是Avalon-MM的,需要先在Qsys中包装一下▼

 

 

         ▼在IP Catalog中搜索Dual Boot IP,然后点击添加

 

 

         ▼只需配置此IP的时钟,此例中为50MHz

 

 

         ▼将clk和reset连接后,一个基于Dual Boot IP的简单Qsys系统完成了

 

 

         ▼点击Generate HDL…,在弹出对话框中设置后,点击Generate

 

 

         ▼系统生成后,在顶层Verilog代码中例化生成的Qsys系统

1 dualboot dualboot_u(
2 .clk_clk(clk), // clk.clk
3 .reset_reset_n(1'b0) // reset.reset_n
4 );

 

         ▼成功编译后,可在层次结构中看到dualboot系统模块

 

 

         ▼切换另一个版本,记得内部配置模式也设置成Dual Compressed Image,不同的版本其设置是独立的,然后重新编译;两个版本分别生成两个sof文件:LED_Flash.sof和LED_BREATH.sof。

 

        

         ▼下一步是将两个sof文件装换成单个pof文件;与制作单映像配置方法相同,通过convert programming files生成pof,但有些不同,在Input files to convert需要添加两个sof文件

 

 

         ▼打开Programmer,添加LED_DualBoot.pof文件,在Program/Configure中勾选CFM,点击Start开始下载

 

 

         ▼下载成功

 

 

         ▼在双压缩映像模式中,可以使用BOOT_SEL 管脚来选择配置映像,在MAX 10评估套件中对应拨码开关DIP的第6位:ON状态选择第一个映像;OFF状态选择第二个映像

 

 

 

         ▼演示视频:上电默认加载第一个映像:呼吸灯程序;切换BOOT_SEL管脚状态后,加载了第二个映像:闪烁灯程序

 


推荐阅读
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 配置IPv4静态路由实现企业网内不同网段用户互访
    本文介绍了通过配置IPv4静态路由实现企业网内不同网段用户互访的方法。首先需要配置接口的链路层协议参数和IP地址,使相邻节点网络层可达。然后按照静态路由组网图的操作步骤,配置静态路由。这样任意两台主机之间都能够互通。 ... [详细]
author-avatar
安静哒发呆
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有