准备驱动移植适配Rust

This commit is contained in:
冯佳
2026-01-29 15:08:30 +08:00
parent e879b18602
commit 1bdeca55ea
68 changed files with 4371 additions and 4392 deletions

View File

@ -0,0 +1,103 @@
# 将驱动部分实现为Rust的解耦化方案
## 项目分析
当前项目使用C语言实现了一个基于STM32F407VET6的嵌入式系统包含以下结构
- **APP/**: 应用层代码包含main.c
- **BSP/**: 板级支持包,包含各种驱动实现
- **Core/**: 核心系统代码包含HAL配置
- **Drivers/**: 底层驱动包含CMSIS等
驱动实现特点:
- 模块化的BSP系统通过bsp_module.h定义了模块类型和操作
- 统一的驱动初始化接口bsp_init()
- 使用HAL层作为底层硬件抽象
## 实现目标
将驱动部分实现为Rust保持与现有C代码的兼容性实现
- 底层C代码 → Rust驱动层 → 上层C代码的架构
- 解耦化使用,使驱动可独立编译和测试
- 利用Rust的内存安全特性提高系统稳定性
## 实现步骤
### 1. 创建Rust项目结构
1. **创建Rust库项目**
- 在项目根目录创建`rust-drivers`目录
- 初始化Rust库`cargo init --lib rust-drivers`
2. **配置Cargo.toml**
- 添加必要的依赖
- 配置为静态库输出
- 设置目标架构为ARM Cortex-M4
### 2. 实现Rust驱动核心
1. **定义C兼容接口**
- 使用`#[no_mangle]``extern "C"`定义C可调用的函数
- 保持与现有BSP接口一致
2. **实现驱动模块**
- LED驱动
- 按键驱动
- W25QXX Flash驱动
- 以太网驱动
- 其他必要的驱动
3. **封装HAL层**
- 创建Rust绑定到现有的C HAL接口
- 提供类型安全的Rust API
### 3. 构建系统集成
1. **修改CMake配置**
- 添加Rust编译步骤
- 链接Rust生成的静态库
2. **创建构建脚本**
- 自动处理Rust依赖和编译
- 确保与现有C构建流程兼容
### 4. 测试与验证
1. **单元测试**
- 为Rust驱动编写单元测试
- 验证基本功能
2. **集成测试**
- 确保与现有C代码的兼容性
- 验证完整系统功能
### 5. 优化与改进
1. **性能优化**
- 减少FFI调用开销
- 优化Rust代码性能
2. **安全性改进**
- 利用Rust的所有权系统确保内存安全
- 防止常见的嵌入式系统错误
## 技术要点
- **FFI使用**正确处理Rust与C之间的数据转换
- **内存管理**确保Rust和C代码之间的内存安全
- **中断处理**:正确处理嵌入式系统中的中断
- **构建系统**确保Rust和C代码能够无缝集成
## 预期成果
- 保持现有C代码的完整性和兼容性
- 提供类型安全、内存安全的Rust驱动实现
- 实现驱动的解耦化,便于独立开发和测试
- 提高系统的整体稳定性和可靠性
## 风险评估
- **构建复杂性**需要同时管理C和Rust的构建流程
- **性能开销**FFI调用可能带来一定的性能开销
- **学习曲线**需要熟悉Rust和嵌入式开发的结合
通过合理的设计和实现可以将这些风险降到最低同时充分利用Rust的优势来提高系统质量。

View File

@ -0,0 +1,49 @@
# 添加LAN8720以太网驱动实现计划
## 1. 项目分析
- 项目使用模块化BSP结构和HAL抽象层
- 已有的BSP配置中包含以太网功能标志(BSP_BOARD_FEATURE_ETH)
- STM32F4xx_HAL_Driver中已包含以太网驱动源码
- 需要添加LAN8720 PHY芯片的支持
## 2. 实现步骤
### 2.1 HAL层扩展
-`HAL/Inc`目录添加`hal_eth.h`头文件,定义以太网接口
-`HAL/Src`目录添加`hal_eth.c`实现文件
-`HAL/Inc/arch/stm32f4`目录添加`hal_stm32f4_eth.h`
-`HAL/Src/arch/stm32f4`目录添加`hal_stm32f4_eth.c`实现
### 2.2 BSP层扩展
-`bsp_board.h`中添加以太网配置结构
-`bsp_board.h`的初始化函数结构中添加以太网初始化函数指针
-`stm32f407vet6_board.c`中添加以太网硬件配置
### 2.3 LAN8720驱动实现
-`BSP/Inc`目录添加`bsp_eth.h`头文件
-`BSP/Src`目录添加`bsp_eth.c`实现文件
- 实现LAN8720 PHY芯片的初始化和配置
- 实现以太网接口的基本操作函数
### 2.4 系统配置修改
- 修改`stm32f4xx_hal_conf.h`,启用以太网模块
- 修改系统时钟配置,确保以太网时钟正确设置
-`bsp_init.c`中添加以太网初始化调用
### 2.5 主程序集成
-`main.c`中添加以太网初始化代码
- 实现基本的以太网功能测试如MAC地址获取、链路状态检测
- 添加以太网相关的日志输出
## 3. 技术要点
- LAN8720 PHY芯片使用RMII接口
- 需要正确配置以太网相关的GPIO引脚
- 实现PHY芯片的复位和初始化流程
- 配置以太网MAC控制器和PHY芯片的通信
- 集成到现有的BSP和HAL架构中
## 4. 预期成果
- 成功初始化LAN8720以太网模块
- 能够检测以太网链路状态
- 能够获取和设置MAC地址
- 为后续的TCP/IP协议栈集成做好准备