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

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads