NES(FC) FPGA游戏卡开发笔记(2)---- 开发环境搭建(FPGA/CPU选型篇)

2023-10-28 19:10

本文主要是介绍NES(FC) FPGA游戏卡开发笔记(2)---- 开发环境搭建(FPGA/CPU选型篇),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

我的需求

国产的FPGA哪个适合我呢?

智多晶SA5Z-30

小梅哥SA5Z-30开发板

开发资料和开发软件

总结

安路EF2L45LG144 FPGA开发板

高云小蜜蜂系列FPGA GW1N

傲格芯(AGM)

1K FPGA选型

CPU选型


为了支持国产芯片事业,优先选择国产的FPGA和CPU。

国产的便宜?国产的能买到吗?国产的开发板多吗?国产的开发资料多吗?开发资料详细吗?Bug多吗?

这几天网上搜了下资料,也下载了相关的资料文档,开发软件,简单使用了一下,说说其中的感受吧。

我的需求

整个方案是需要两个FPGA,一个CPU。这个和N8 Por一样。

1)CPU需要SDIO和usb。没有SDIO,至少也有2个以上的SPI,一个接tf卡,一个接外部flash,或者一个接FPGA,配置FPGA,下载游戏rom。usb可有可无,实在没有用串口和主机连接。CPU至少提供256KB的片内flash,64KB的SRAM,越多越好。最好提供方便使用的BSP包。没有的话CPU资料详细也可以。因为要做个sdio或者spi固件实现,fatfs文件系统。usb固件实现。

2)FPGA,一个1K,一个6K左右的逻辑单元,开发软件要求不高,综合和仿真,下载调试。FPGA新手,功能多了学习不过来。仿真和调试要求稍微高些,方便发现问题。

3)考虑带cpu核的FPGA,可以少一块芯片,需要资源同上。

4)mapper FPGA开发板能提供100个pin左右的IO接口。

国产的FPGA哪个适合我呢?

以前没关注,现在国内的FPGA厂商还不少,紫光同创,安路,智多晶,易灵思,高云,京微齐力,AGM(傲格芯)等等等。

由于前几年芯片荒,不知道现在改善了没有,从淘宝查看了一下这些家的开发板,低端的选择其实不是很多,或者根本没有芯片卖。比较合适的是安路,智多晶,高云,AGM。其他的太高端,低端玩家基本没戏。

如果选择带CPU核FPGA的需要关注资料中CPU相关资料是否详细。纯FPGA只要关注开发板资源是否够,开发软件是否方便使用。

智多晶SA5Z-30

小梅哥SA5Z-30开发板

9和15可以使用的GPIO口。一共是78根线。有些不用的接口也可以使用。9原来是准备LCD的,有些接口以及定义为VCC和G,连线的时候需要注意不要使用这些接线。

另外的考虑是这个FPGA带arm m3核,板上带usb-uart接口,spi-sd卡,flash和sram。只要自制一块带2个SRAM(存放PPU和CPU的ROM),3.3v-5v电压转接芯片,就可以进行开发 。

优势:内置Cortex-m3硬核,3万的逻辑单元(太多了?),开发板基本满足最低要求,除了IO口稍微有点少。

劣势:网上SA5Z-30的只有这一种,其他智多晶的低端FPGA也是这种开发板。SA5Z-30太贵了。一片可以买其他好几种芯片了。CPU提供128KB指令RAM和32KB数据RAM,对我的需求来说有点少。

开发资料和开发软件

官网提供了SA5Z-30的数据手册和器件概述文档。从嵌入式开发者角度来说,CPU的支持的外设很少(或者可以说基本没有),需要用户用FPGA去实现?对CPU的描述的文档非常简单,用户如何使用,如何运行代码,配置寄存器(有没有寄存器?)。

淘宝店家小梅哥提供的网上开发资源(这个比官网的多些):

芯路恒资料与技术支持专区 - 芯路恒电子技术论坛 - Powered by Discuz!

 

设计实例有些verilog和m3核的实现实例。M3核的实现中还有ucos的移植代码。具体在芯片上怎么使用可能需要阅读这些代码了,资料还是有点上,对FPGA开发新手来说需要折腾。

官网提供的FPGA开发软件是hqfpga(海麟)。

 简单安装使用了一下,从RTL综合,布线,生产bit stream文件下载调试。基本满足我的要求。

没提供仿真和调试分析(我没具体用过,不知道这些怎么去做,有可能可以用第三方的软件去做)。和国外的Quartus相比还是差距很大,一步一步来吧。

总结

可能能满足我的需求,但开发难度有些大,很多资源接口需要自己去实现。CPU片内资源比较少。

安路EF2L45LG144 FPGA开发板

安路的小精灵系列FPGA,EF2/EF3可以满足要求。淘宝上有EF2的开发板,IO管脚够用,串口转usb,(IO口是3.3v的吗?)。低端开发板的差不多就下面这种,可选余地不是很多。

官网提供芯片资料和软件下载,下载了数据手册,其他应用例程开发指南资料需要注册会员,我注册了会员告诉会员等级不够,还是不能下载。有可能淘宝店家可以提供更多了开发资料。

高云小蜜蜂系列FPGA GW1N

 淘宝上GW1N系列的开发板大部分是邮票板,提供的IO口太少。

官网提供的资料也比较多,在国产FPGA厂商中算不错的,带核的芯片没有开发板,也就没有关注。开发软件Gowin下载了个教育版,正式版需要申请license。教育版支持的芯片大概就几种了。

使用流程国内软件的都差不多,不在详述。

傲格芯(AGM)

AG32VF407(带RISC-V核)

考虑了两个开发板,第一种FPGA带CPU,第二种不带。

官网资料下载提供了数据手册和supra FPGA开发软件。比较少。

另外一个http://www.tcx-micro.com 提供了比较多的开发资料。

因为一开始关注的是AG32VF407(兼容STM32F407?,其实资源比F407要少。),并下载了嵌入式软件开发环境(risv-v),支持VS-code下的Platformio开发环境。具体使用说明见下一篇。

后考虑资源之后,觉得还是纯FPGA比较合适。

1K FPGA选型

低端的1K FPGA开发板很多,IO基本够,选择AGM的就可以。

CPU选型

国产MCU很多,因只要看芯片上的资源信息,很快就决定选择雅特力科技的AT32F403RCT,文档和代码例子也足够。片内提供:256KB flash 和96KB sram(224KB怎么使能?)

外部接口SDIO/SPI/USB

外部可以接四个SRAM或flash(四个片选),比如直接连三个SRAM进行访问。

这篇关于NES(FC) FPGA游戏卡开发笔记(2)---- 开发环境搭建(FPGA/CPU选型篇)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

gradle安装和环境配置全过程

《gradle安装和环境配置全过程》本文介绍了如何安装和配置Gradle环境,包括下载Gradle、配置环境变量、测试Gradle以及在IntelliJIDEA中配置Gradle... 目录gradle安装和环境配置1 下载GRADLE2 环境变量配置3 测试gradle4 设置gradle初始化文件5 i

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步