RSICV国产芯片之CHV208
1. 芯片选型分析的对比维度
分析或者对标应用的芯片替代思路
1.1 内核/主频/存储空间支持
内核能力/指令集支持(考虑工具链兼容性);
主频:对比计算能力是否满足基本要求
存储:内存--数据搬移空间决定数据运算的复杂度, FLASH--程序空间决定程序的复杂度
1.2 外设接口: (传感器接入,信号获取)
UART/I2C/SPI--数字外设接口能力,路数,最高主频(刷新率),接口协议是否通用
ADC/运放--模拟信号接口能力, 位数,信噪比,信号处理范围
SDIO
1.3 驱动能力
PWM--路数,分辨率,最高频率
DAC--位数,精度
1.4音视频
I2S--音频接口(比如数字功放,数字硅麦)
DVP--视频接口,SPI摄像头接入
MIPI--屏或者摄像头接口
1.5 连接能力:
无线: 蓝牙、wifi、SUB-G
以太网/CAN/USB
1.6 其他资源(软件开发的便利性):
DMA--高速数据交换必备
TIMER定时器--灵活处理任务调度
CRC--外设通信
CHIPID--加密及身份互认
电源管理(待机模式/功耗)--是否足够灵活,能够满足不同工况低功耗要求和宽电压适应能力。
1.7 开发环境:
IDE支持
烧录调试模式
HAL库/RTOS支持
样例工程可用性,代码是否友好等;
2. CH32V208系列应用选型
参考沁恒官网:
产品中心 - 南京沁恒微电子股份有限公司

V208资源也很丰富,主频够高,FLASH 稍小128K, RAM64K

资源差不多,只是引脚数不同,估计是一个die;
支持OPA和12bit的ADC, 其实可以用来做测温应用;
3. 开发环境上手
参考贴:
沁恒 CH32V208(一): CH32V208WBU6 评估板上手报告和Win10环境配置-CSDN博客
3.1 代码编译环境IDE--MRS(MounRiverStudio)
第一次用MRS打开CH208的项目,会安装环境:

代码架构:

GPIO_TOGGLE例程:
int main(void)
{u8 i = 0;NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);SystemCoreClockUpdate();Delay_Init();USART_Printf_Init(115200);printf("SystemClk:%d\r\n", SystemCoreClock);printf( "ChipID:%08x\r\n", DBGMCU_GetCHIPID() );printf("GPIO Toggle TEST\r\n");GPIO_Toggle_INIT();while(1){Delay_Ms(250);GPIO_WriteBit(GPIOA, GPIO_Pin_0, (i == 0) ? (i = Bit_SET) : (i = Bit_RESET));}
}
3.2 调试环境建立:
评估板资源分布:

烧录/调试的选项, 有三种方式
3.2.1 2线SWD模式, 配合WCH-LINKE
优点: 可以在MRS里debug,可以动态调试,更符合从STLINK+KEIL迁移过来的开发者;
缺点:需要配WCH-LINKE设备;
硬件连接
引脚P6-DEBUG

WCH-LINKE连接SWD接口, 在MRS里可以直接下载调试。
如果用WCH-LINKE的话,也可以用 WCH-LinkUtility.exe 下载。

专用烧录工具比IDE里的功能要更齐备。
3.2.2 (USB/串口)WCHISPTool.exe 下载升级
稍稍麻烦一点, BOOT0接地(0)重启动烧录, 接高电平(1)重启动运行程序。

优点:不需要专用工具,USB/串口都可以烧录;
缺点:需要准备一根飞线,在烧录和运行状态下配置切换接线;
强调: 串口烧录,必须BOOT0-VDD, BOOT1-GND连接好复位才行!
然后烧录后, 重新BOOT0-GND即可以进入程序运行状态;
实测,USB口和UART口都可以通过isptool正常烧录。
GPIO-TOGGLE例程串口连接正常情况下,上电有打印消息;
注意,要点灯的话,需要将排针的LED1连接到PA0, 即可实现blink点灯......

3.2.3 通过bootloader, 串口在线烧录程序(推荐)
利用IAP例程的架构实现串口直接烧录(在线升级)。 --生产环境更实用。
注意: app一定要配置Link.ld文件,指定FLASH/RAM大小:
FLASH (rx) : ORIGIN = 0x00005000 , LENGTH = 128K RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 64K

这样就提高调试效率了,可以USB插着用于IAP更新下载固件APP, 串口插着打印调试;
入口在xxx_it.c程序中的软中断入口:
void SW_Handler(void) {__asm("li a6, 0x5000");__asm("jr a6");while(1);
tips: IAP里加入简单的固件校验,还可以用于固件加密等扩展应用。
注意,此处有坑!
如果用IAP升级,USB可以直接用工具选择bin文件升级;
!!!但是如果是串口升级,注意IAP给的bootloader例子里是用的串口3作为升级串口,串口1依然是printf调试打印串口,且波特率是57600(当然,可以修改)。 代码,查看IAP例子的main.c:
int main(void) {SystemCoreClockUpdate();Delay_Init();USART_Printf_Init(115200);printf("SystemClk:%d\r\n", SystemCoreClock);printf( "ChipID:%08x\r\n", DBGMCU_GetCHIPID() );Set_USBConfig();USB_Init();USB_Port_Set(DISABLE, DISABLE);Delay_Ms(700);USB_Port_Set(ENABLE, ENABLE);USB_Interrupts_Config();USBFS_Init();USART3_CFG(57600);while(1){EP2_RecData_Deal();if( USART_GetFlagStatus(USART3, USART_FLAG_RXNE) != RESET) {UART_Rx_Deal();}if (End_Flag){Delay_Ms(10);IAP_2_APP();while(1);}} }
所以升级用的USB-TTL模块要接在PB10-RX, PB11-TX:

几种方式比较, 应该通过加载BOOTLOADER后用USB升级是最方便的操作,无需借助其他工具,直接插USB就可以了。

4. 拿到SDK的入门路径
4.1 外设:
BLINK-->外部中断/KEY-->UART-->SPI/I2C/FLASH
-->TIMER/PWM-->ADC/DAC/RTC
-->DMA/WDT/SDIO
***射频
4.2 RTOS操作系统
FREERTOS内核-->任务-->任务间通信-->任务和中断协同
相关文章:
RSICV国产芯片之CHV208
1. 芯片选型分析的对比维度 分析或者对标应用的芯片替代思路 1.1 内核/主频/存储空间支持 内核能力/指令集支持(考虑工具链兼容性); 主频:对比计算能力是否满足基本要求 存储:内存--数据搬移空间决定数据运算的…...
理解神经网络
神经网络是一种模拟人类大脑工作方式的计算模型,是深度学习和机器学习领域的基础。 基本原理 神经网络的基本原理是模拟人脑神经系统的功能,通过多个节点(也叫神经元)的连接和计算,实现非线性模型的组合和输出。每个…...
Android 之 List 简述
一、简单创建方式 Android 开发中,列表有很多种类,如ArrayList、LinkedList、List、MutableList等,创建列表的方式如下所示: fun listDemo() {// 使用 listOf 创建不可变的空列表val list listOf<Int>()val list1 listOf…...
设计模式の中介者发布订阅备忘录模式
文章目录 前言一、中介者模式二、发布订阅模式三、备忘录模式 前言 本篇是关于设计模式中介者模式、观察者(发布-订阅)模式、以及备忘录模式的学习笔记。 一、中介者模式 中介者模式是一种行为型设计模式,其核心目的是为了减少对象之间的复杂…...
云手机群控能用来做什么?
随着云手机的发展,云手机群控技术逐渐从小众的游戏多开工具,发展为涵盖多个领域的智能操作平台。不论是手游搬砖、短视频运营,还是账号养成等场景,云手机群控都展现出了强大的应用潜力。本文将为大家详细解析云手机群控的应用场景…...
fpgafor循环语句使用
genvar i;//循环变量名称 generate for(i0;i<4;ii1)begin:tx//自己定义名称 //循环内容 end endgenerate12位的16进制乘以4就是48位位宽的2进制 因为 222*2(2^4)16...
【FastAPI】BaseHTTPMiddleware类
一、概述 在FastAPI中,BaseHTTPMiddleware 类是Starlette框架提供的一个抽象基类,它允许开发者基于HTTP请求/响应接口编写ASGI中间件。 这个类对于希望实现自定义中间件逻辑的开发者来说是非常重要的工具。 通过继承 BaseHTTPMiddleware 并实现特定的方…...
Solon v3.0.5 发布!(Spring 可以退休了吗?)
Solon 框架! 新一代,面向全场景的 Java 应用开发框架。从零开始构建(非 java-ee 架构),有灵活的接口规范与开放生态。 追求: 更快、更小、更简单提倡: 克制、高效、开放、生态 有什么特点&am…...
网络安全攻防演练中的常见计策
大家觉得有意义记得关注和点赞!!! 引言 在网络安全攻防演练里面,用于分析攻击者动机和行为的,国外的有基于攻击链分析的模型(如Cyber Kill Chain和ATT&CK)和基于威胁行为的模型(…...
SD卡模块布局布线设计
1、SD/TF/SIM卡的定义 2、SD/TF/SIM卡模块引脚定义以及图示 3、SD/TF/SIM卡接口布局和布线 4、小结 1、BGA两线交叉时,可以在源头将两线互相短路连接,然后再输出口删除一小节线,然后CHRLX/V,这样就可以换两条线的网络,…...
Flask-----SQLAlchemy教程
存session session[username] username # 存储数据到 session 取session username session.get(username) render_template return render_template(index.html, usernameAlice),渲染一个包含 username 变量的模板。 redirect return redirect(url_for(profil…...
STM32 高级 物联网通信之CAN通讯
目录 CAN通讯介绍 物理层 协议层 CAN的帧(报文)种类 1 数据帧(发送单元->接受单元) 2 远程帧(接受单元->发送单元) 3 错误帧(发送方发送数据错误会发送的状态帧) 4 过载帧(接收方放不下会发送到的状态帧) 5 帧间隔(状态) 数据帧介绍 远程帧介绍 C…...
“乡村探索者”:村旅游网站的移动应用开发
3.1 可行性分析 从三个不同的角度来分析,确保开发成功的前提是有可行性分析,只有进行提前分析,符合程序开发流程才不至于开发过程的中断。 3.1.1 技术可行性 在技术实现层次,分析了好几种技术实现方法,并且都有对应的成…...
前端案例---自定义鼠标右键菜单
之前右击出现默认的选项菜单,使用evt.preventDefault()把默认的去掉,然后自定义右击的样式 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible"…...
浅谈归一化
在深度学习中,对网络层进行归一化(Normalization,简称Norm)是一个重要的技巧。常见的归一化方法包括批归一化(Batch Normalization)、层归一化(Layer Normalization)、实例归一化&am…...
lodash常用函数
文章目录 一、数组1、chunk分组2、difference、differenceBy、differenceWith3、findIndex4、intersection、intersectionBy、intersectionWith5、union、unionBy、unionWith 二、对象1、pick、omit 2、get、set三、数学1、sum、sumBy2、range 四、工具函数1、isEqual、isEmpty…...
触控算法总结
一、触控湿手指算法的具体实现原理涉及多个方面的技术和方法,主要包括以下几个关键点 1.电容变化检测 电容式触摸屏通过检测电容变化来确定触摸位置。当手指接触屏幕时,会引起电容的变化。然而,当手指湿润时,水分会影响电容值,导致触摸屏误判成无法正确识别触控点 2.噪声过滤: …...
齐次矩阵包含平移和旋转
第一个矩阵旋转矩阵 A [ R 1 0 0 1 ] A\left[\begin{matrix}R_{1} & 0\\0 & 1\end{matrix}\right] A[R1001] 第一个平移矩阵 B [ 1 T 1 0 1 ] B\left[\begin{matrix}1 & T_{1}\\0 & 1\end{matrix}\right] B[10T11] C [ R 2 0 0 1 ] C\left[\be…...
Move AI技术浅析(四):运动跟踪与估计
一、运动跟踪与估计模块概述 运动跟踪与估计 是 Move AI 的核心模块之一,其主要任务是从提取到的关键点特征中,分析和理解运动的动态特性,包括运动轨迹、速度、加速度、方向等。该模块通常包括 时间序列分析 和 运动估计 两个子模块。 时间…...
NCR+可变电荷块3——NCB/cell绘图1
文献method参考: 蛋白质序列数据从uniprot中获取 https://www.uniprot.org/uniprotkb/P46013/entry https://www.uniprot.org/uniprotkb/P06748/entry、 1,电荷分布计算: Charge distribution was calculated as the sum of the charges …...
网络六边形受到攻击
大家读完觉得有帮助记得关注和点赞!!! 抽象 现代智能交通系统 (ITS) 的一个关键要求是能够以安全、可靠和匿名的方式从互联车辆和移动设备收集地理参考数据。Nexagon 协议建立在 IETF 定位器/ID 分离协议 (…...
[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解
突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 安全措施依赖问题 GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...
XCTF-web-easyupload
试了试php,php7,pht,phtml等,都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接,得到flag...
Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)
文章目录 1.什么是Redis?2.为什么要使用redis作为mysql的缓存?3.什么是缓存雪崩、缓存穿透、缓存击穿?3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...
python/java环境配置
环境变量放一起 python: 1.首先下载Python Python下载地址:Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个,然后自定义,全选 可以把前4个选上 3.环境配置 1)搜高级系统设置 2…...
STM32+rt-thread判断是否联网
一、根据NETDEV_FLAG_INTERNET_UP位判断 static bool is_conncected(void) {struct netdev *dev RT_NULL;dev netdev_get_first_by_flags(NETDEV_FLAG_INTERNET_UP);if (dev RT_NULL){printf("wait netdev internet up...");return false;}else{printf("loc…...
在四层代理中还原真实客户端ngx_stream_realip_module
一、模块原理与价值 PROXY Protocol 回溯 第三方负载均衡(如 HAProxy、AWS NLB、阿里 SLB)发起上游连接时,将真实客户端 IP/Port 写入 PROXY Protocol v1/v2 头。Stream 层接收到头部后,ngx_stream_realip_module 从中提取原始信息…...
【git】把本地更改提交远程新分支feature_g
创建并切换新分支 git checkout -b feature_g 添加并提交更改 git add . git commit -m “实现图片上传功能” 推送到远程 git push -u origin feature_g...
EtherNet/IP转DeviceNet协议网关详解
一,设备主要功能 疆鸿智能JH-DVN-EIP本产品是自主研发的一款EtherNet/IP从站功能的通讯网关。该产品主要功能是连接DeviceNet总线和EtherNet/IP网络,本网关连接到EtherNet/IP总线中做为从站使用,连接到DeviceNet总线中做为从站使用。 在自动…...
全志A40i android7.1 调试信息打印串口由uart0改为uart3
一,概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本:2014.07; Kernel版本:Linux-3.10; 二,Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01),并让boo…...
