AG32 MCU+FPGA 使用感受

前言:

        笔者35+了,10多年前开始玩单片机/FPGA啥的,从现在回想过去,眼下真的是我们国家微电子发展的好时候。各种各样的国产单片机,FPGA啥的,想想本科的时候用的Freescale,后来用的STM32,真的感叹国家发展的很快,虽然差距还存在。

        在找国产FPGA玩的过程中发现了AGM AG32系列的RISCV + FPGA的配合,断断续续把玩了两个星期,下面是使用感受和一些个人的看法。

AG32简单介绍

        AG系列这个是RISCV+FPGA(2K LE,只能做简单点的逻辑)的配合方式,价格还算便宜(淘宝48PIN 7.5的样子),和某些FPGA里面内带硬核M3(高云)和或者M33(智多晶)实际上是比较像的。官方说CPU可以跑到200M。

        这种架构与市场上的单片机+FPGA分立集成的开发板比起来,最大的优势是逻辑部分可以直接连单片机的总线,AG的是AHB总线,可以通过DMA搬运数据,甚至自己就可以做DMA主机。

        芯片的RAM 128K,默认是MCU独占,但是可以划分一部分让逻辑部分通过AHB使用;FLASH的话100Pin以上1M,其他256K,但是后100K是用来配置LOGIC的,这样看来256K还是够呛,但是实际上用到了FPGA,基本都会上100PIN吧?

        芯片只有一个PLL,这个PLL是LOGIC和MCU共用的,这样会有一个问题,这个MCU的时钟是无法动态配置的,基本就是锁定了的,功耗控制可能会是一个问题。

开发环境:

硬件方面:

        产品与GD32/STM32的PIN脚完全一致,笔者就是直接把旧的开发板换芯:

        

        买家还会推荐你买他们的下载器,基本上就是一个CMSIS-DAP + altera usb blaster + USB串口的大杂烩,如果没有其他下载器可以买一个,实际上JLINK啥的也能用,没啥必要,最主要这块下载器板子设计的比较丑,还没有外壳。AG32系列可以用JTAG或者SW下载。

开发环境方面:

        软件是厂商自己魔改的vscode + platfromIO + sdk的方式。需要特别说明,用了他的SDK破坏platfromIO原来的工作环境,无法新建其他工程了,需要对c:\user\用户名\.platfromio 文件夹先进行备份,然后来还切换文件夹适应不同的使用环境,这个相当麻烦(毕竟没人只用你家单片机啊!),希望后续厂家改改。

        Arduino:不支持

        Micropython : 不支持。

FPGA开发:

        实际上FPGA开发,是“借用”了Altrea quartus的开发环境。先在vscode里面新建工程,配置工程里面VE文件的FPGA、MCU、芯片PIN脚之间的连接信号,然后prepare logic ,就会生成一个quartus 工程,里面已经把所有的ve文件里面的信号,以及AHB总线信号给配置好了,然后就是自己写逻辑,然后编译生成。

        之后在用厂家自己的supra软件,将东西转换一下,成为一个bin文件。

        然后用烧录器吧这个bin文件烧录到FLASH的后100K。

        “借用”这个事情不好评价啊,毕竟起步阶段,但是用下来还是熟手的。

MCU开发:

        用的是官方自己写的SDK,和STM32和GD32差不多。不过与GD32基本照抄STM32的标准外设库的行为比起来,AG家的库写的还是挺不错的,看得出在让用户简洁编程上面下了不少的功夫,基本所有外设、Freertos、usb啥都写了库。另外还有非常有参考性的MCU+FPGA联合开发的库,里面通过AHB总线直接访问、或者是转APB之后访问低速外设。

        总的来说,我觉得软件开发环境除了独占PlatfromIO之外,其他都还是不错的。

优缺点

        这款芯片的价位和功能让我非常容易想起GD32/ESP32单片机。

 STM/GD32ESP32AG32
成本4(C6t6)6.5(C3-FH4)
10(S3+8MFlash)
7.5 (48pin)
13.9(100pin)
硬件集成便捷性差(指定IO/有限REMAP)好(IO交换矩阵)好 (FPGA交换PIN)
开发环境一般(独占platfromIO)
开发难度低(micropython有手就行)高(得配置的东西很多)
支持力度高(随便百度一大堆回答)中(arduino优秀,mp一般,idf地狱)低(只能问原厂,问多几句就会问你是哪个公司的,要用多少pcs,啥时候量产...)

总结和建议:

1、东西还是不错的,不过比上手一般的单片机要难不少。

2、只用单片机,它的性价比比ESP32低,建议需要使用到FPGA等场合才使用。笔者读书时的一个项目就是用CIS扫描后做数字识别,为了满足CIS的严格时序用到了STM32 + CPLD的架构,现在可以芯片搞定。

3、如果能决定入手,因为原厂的资料比较散乱,请把原厂给你的文档全部看一遍再进行上机

4、SDK我发现还是有一些BUG的,需要有一定的动手能力才能解决,如果是初学者,劝退。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/684240.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SpringCloud Gateway基础入门与使用实践总结

官网文档:点击查看官网文档 Cloud全家桶中有个很重要的组件就是网关,在1.x版本中都是采用的Zuul网关。但在2.x版本中,zuul的升级一直跳票,SpringCloud最后自己研发了一个网关替代Zuul,那就是SpringCloud Gateway一句话…

面试(03)————多线程

目录 一、线程和进程的区别? 二、并行和并发的区别? 三、线程创建的方式有哪些? 3.1、继承Thread类 3.2、实现Runnable接口 3.3、实现Callable接口 3.4、线程池 四、Runnable和Callable的区别? 五、在启动线程的时候&am…

git-生成SSH密钥

git-生成SSH密钥 1 打开命令窗口2 操作 1 打开命令窗口 选择"Git Bash Here",打开Git命令窗口 2 操作 查看当前用户名称 git config user.name配置你的邮箱,“6xxxqq.com” 填写自己的邮箱 git config --global user.email "6xxxqq…

WPF真入门教程32--WPF数字大屏项目实干

1、项目背景 WPF (Windows Presentation Foundation) 是微软的一个框架,用于构建桌面客户端应用程序,它支持富互联网应用程序(RIA)的开发。在数字大屏应用中,WPF可以用来构建复杂的用户界面,展示庞大的数据…

计算机网络错题答案汇总

王道学习 第1章 计算机网络体系结构 1.1 1.2

Nvidia 目前的市值为 3.01 万亿美元,超过苹果Apple

人工智能的繁荣将英伟达的市值推高到足以使其成为全球第二大最有价值的公司。 英伟达已成为全球第二大最有价值的公司。周三下午,这家芯片制造巨头的市值达到 3.01 万亿美元,领先于苹果公司的 3 万亿美元。 喜好儿网AIGC专区:https://heehe…

独著出书的出版流程是怎样的?

独著出书的出版流程一般包括以下几个步骤: 1. 准备书稿:确保书稿内容完整、准确,并符合出版社的要求。 2. 选择出版社:根据书稿的主题和内容,选择合适的出版社。可以考虑出版社的专业性、声誉和出版范围等因素。 3.…

2.1.4 采用配置类与注解方式使用MyBatis

实战概述:采用配置类与注解方式使用MyBatis 创建MyBatis配置类 在net.huawei.mybatis.config包中创建MyBatisConfig类,用于配置MyBatis核心组件,包括数据源、事务工厂和环境设置。 配置数据源和事务 使用PooledDataSource配置MySQL数据库连接…

Vue3【四】使用Vue2的写法写一个新的组件子组件和根组件

Vue3【四】使用Vue2的写法写一个新的组件 Vue3【四】使用Vue2的写法写一个新的组件 Vue3是向下兼容的&#xff0c;所有可以使用Vue的选项式写法 运行截图 目录结构 文件源码 App.vue <template><div class"app"><h1>你好世界! 我是App根组件<…

Java Web学习笔记13——JSON

JavaScript自定义对象 定义格式&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Js-对…

SCT53600TVB具有反向电流保护的理想二极管控制器

4.7V至65V工作范围 – 65V反向额定电压 用于外部N沟道MOSFET的电荷泵 20mV正向压降调节 12V栅极驱动电压 带启用输入 驱动高侧外部N沟道MOSFET 1μA关断电流&#xff08;EN低&#xff09; 60μA工作静态电流&#xff08;EN高&#xff09; 2.3-A峰值…

为什么要做与运算?网关如何和ip做与运算?

在计算机网络中&#xff0c;“与运算”是一个基本而重要的概念&#xff0c;尤其在IP地址和子网掩码的处理中起着关键作用。本文将解释为什么要进行与运算&#xff0c;以及网关如何和IP地址进行与运算。 为什么要做与运算&#xff1f; 1. 确定网络地址 与运算&#xff08;AND…

常规操作-ArcGIS常用标注技巧

常规操作-ArcGIS常用标注技巧 1、简单的"&“符号&#xff1a;多字段表达只需要用”&"符号&#xff0c;多个字段之间需要空格&#xff0c;空格符号需要加双引号。 表达式为&#xff1a; [字段] & " " & [字段] 2、“VBnewline"应用…

MySQL深分页,limit 100000,10 优化

文章目录 一、limit深分页为什么会变慢二、优化方案2.1 通过子查询优化&#xff08;覆盖索引&#xff09;回顾B树结构覆盖索引把条件转移到主键索引树 2.2 INNER JOIN 延迟关联2.3 标签记录法&#xff08;要求id是有序的&#xff09;2.4 使用between...and... 我们日常做分页需…

debrief 中用到的计算方法

//累加时长方法 function calculateCumulativeSum(array, key) { return array.reduce((accumulator, currentValue, currentIndex) > { if (currentIndex 0) { accumulator[currentIndex] currentValue[key]; } else { accu…

python-15(Xpath)

1.XPath 1.1.什么是XPath XPath&#xff08;XML Path Language&#xff09;是一种用于在XML文档中定位和选择节点的语言。它是W3C&#xff08;World Wide Web Consortium&#xff09;定义的一种标准查询语言&#xff0c;广泛用于解析和操作XML文档&#xff0c;也可以操作html…

TensorBoard在pytorch训练过程中如何使用,及数据读取问题解决方法

TensorBoard 模块导入日志记录文件的创建训练中如何写入数据如何提取保存的数据调用TensorBoard面板可能会遇到的问题 模块导入 首先从torch中导入tensorboard的SummaryWriter日志记录模块 from torch.utils.tensorboard import SummaryWriter然后导入要用到的os库&#xff0…

STAT313 Chap5 多变量核密度估计带宽选择(下)

本文原创笔记&#xff0c;禁止转载。有问题可私信付费找我咨询。 直接插入法的基本步骤 步骤1&#xff1a;计算初始估计&#xff08;Pilot Estimate&#xff09; 选择一个初始的带宽矩阵 G \mathbf{G} G 和核函数 L L L 。计算初始密度估计&#xff1a; f ~ ( x , G ) 1 …

机器人舵机:关键要素解析与选择指南

在机器人技术日新月异的今天&#xff0c;舵机作为机器人的核心部件之一&#xff0c;扮演着至关重要的角色。它的性能直接关系到机器人的运动控制、稳定性以及精度等方面。那么&#xff0c;在选择和使用机器人舵机时&#xff0c;我们需要关注哪些关键要素呢&#xff1f;本文将为…

锐捷校园网自助服务系统 login_judge.jsf 任意文件读取漏洞复现(XVE-2024-2116)

0x01 产品简介 锐捷校园网自助服务系统是锐捷网络推出的一款面向学校和校园网络管理的解决方案。该系统旨在提供便捷的网络自助服务,使学生、教职员工和网络管理员能够更好地管理和利用校园网络资源。 0x02 漏洞概述 校园网自助服务系统/selfservice/selfservice/module/sc…