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

相关文章

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

python常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

Java进程CPU使用率过高排查步骤详细讲解

《Java进程CPU使用率过高排查步骤详细讲解》:本文主要介绍Java进程CPU使用率过高排查的相关资料,针对Java进程CPU使用率高的问题,我们可以遵循以下步骤进行排查和优化,文中通过代码介绍... 目录前言一、初步定位问题1.1 确认进程状态1.2 确定Java进程ID1.3 快速生成线程堆栈二、分析

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3