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

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.