RP-HAL项目中RP2350芯片的USB启动模式实现解析
2025-07-10 19:26:19作者:庞队千Virginia
在嵌入式开发中,特别是使用Raspberry Pi Pico系列开发板时,开发者经常需要实现将设备重置并进入USB启动模式(BOOTSEL)的功能。本文将深入分析在RP-HAL项目中如何为RP2350芯片实现这一关键功能。
RP2350的启动模式机制
RP2350芯片作为RP2040的升级版本,保留了类似的启动机制。当芯片复位时,通过特定的配置可以使其进入USB启动模式,此时设备会表现为一个USB大容量存储设备,允许开发者通过拖放方式烧录固件。
传统RP2040的实现方式
在RP2040-HAL中,开发者可以直接调用reset_to_usb_boot函数来实现这一功能。该函数接受两个参数:
gpio_activity_pin_mask:用于指定一个GPIO引脚作为活动指示灯disable_interface_mask:用于控制暴露的USB接口
RP2350的实现差异
RP2350虽然保留了类似的功能,但其实现方式有所不同。开发者需要通过直接调用ROM函数来实现相同的功能。具体实现方式如下:
unsafe {
let rom_table = 0x0000_0000 as *const u32;
let reset_to_usb_boot = rom_table.offset(56).read() as *const fn(u32, u32);
reset_to_usb_boot(0, 0);
}
这段代码首先获取ROM表的基地址,然后通过偏移量56找到reset_to_usb_boot函数的指针,最后调用该函数实现复位到USB启动模式。
技术实现要点
-
ROM表访问:RP2350的ROM中包含了一系列预定义的函数,通过固定的偏移量可以访问这些函数。
-
函数指针转换:需要将读取的地址转换为正确的函数指针类型,确保安全调用。
-
参数传递:与RP2040版本类似,可以传递GPIO活动指示灯掩码和接口禁用掩码参数。
开发建议
-
在实现这一功能时,建议将其封装为安全的函数接口,避免在应用代码中直接使用不安全块。
-
考虑添加错误处理机制,虽然ROM函数通常可靠,但仍需考虑异常情况。
-
对于需要频繁切换启动模式的应用场景,可以将此功能集成到开发工作流中,实现自动化烧录和调试。
通过理解这些底层机制,开发者可以更灵活地控制RP2350芯片的启动行为,为嵌入式开发工作流提供更多可能性。
登录后查看全文
热门项目推荐
相关项目推荐
暂无数据
热门内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
540
3.77 K
Ascend Extension for PyTorch
Python
351
415
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
612
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
338
185
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
987
253
openGauss kernel ~ openGauss is an open source relational database management system
C++
169
233
暂无简介
Dart
778
193
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.35 K
758
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
115
141