
前言 一些应用中,涉及到对存储设备的数据访问,例如 uSD 卡、U 盘。具备 USB OTG 控制器的 STM32,可以实现对 U 盘访问的支持。本文介绍 STM32 对于 U 盘访问的硬件/软件实现。介绍如何利用 STM32CubeMX,一步一步实现 STM32 访问U 盘。仅需要简单的几个步骤, 实现 U 盘访问的应用开发。 $ m, {# F; X( C! T 一 MSC 类简介% F. H$ {1 z3 }+ [ MSC (Mass Storage Class) 是 USB 规范提供的一种 USB 大容量存储设备类,允许一个 USB 接口的设备与 USB 主机相连接,以便在两者之间传输文件。USB MSC 传输协议分为 CBI (Control / Bulk / Interrupt) 和 BOT (Bulk-only Transfer)。BOT协议在不影响功能的情况下省去了对 Interrupt 端点的需求,被存储设备广泛支持。STM32 提供的 USB 库支持 USB MSCBOT 协议。, m: y4 K8 u# t: a; d* I/ ^ MSC 设备包含很多种,例如 U 盘、读卡器、移动硬盘等。STM32 通过内含的 USB OTG 控制器(支持主机模式)和USB 主机库,实现对 MSC 类的支持,进而实现对 U 盘访问的支持。本文中不涉及到 USB MSC (Mass Storage Class) 的详细介绍 ,更多 MSC 类介绍,请参考《USB 进阶培训_Part1_USB 类的介绍》。3 w0 [4 O J; L& q( K 二 MSC 在 STM32 上的实现 2.1 硬件支持 不同的 STM32 系列,对 USB 的支持情况如下。对于 STM32F105/107、STM32F2、STM32F4、STM32F7 和STM32H7 系列,部分型号支持 USB OTG,能够实现 USB 主机和从机。U 盘作为 USB MSC 设备,需要 STM32 作为 USBMSC 主机,实现两者间的访问。(注:系列中不是所有型号都支持 OTG,以具体型号手册为准。) ![]() 2 T H* B8 C: ]2 c2 i- f+ Z STM32 OTG 硬件电路图如下所示。CN3 为 USB 连接器。: |5 B P# y2 C1 ~. _' u1 A : J+ u5 s+ C9 G) Z ![]() K; m. H! c% M 对于 STM32 OTG,配置为仅主机模式时,不需使用 OTG_ID,可将其引脚用于其他功能。并且在不使用 SRP (Session Request Protocol) 和 HNP (Host Negotiation Protocol) 时,可不连接 VBUS 至 PA9。电路简化如下图。 ![]() 更多关于 STM32 USB 硬件设计,请参考《AN4879 USB hardware and PCB guidelines using STM32 MCUs》。/ F7 d0 M4 X* U' D8 c6 i4 N 2 C J$ F) O: J! }' ]: y- q( \ , l4 d/ P5 h) z+ m% V3 f G. \* H 2.2 软件支持8 b. B6 E' D: S5 e# @. B STM32 拥有丰富的软件资源,推荐如下两个软件包: STM32Cube 软件包(包含 USB/OTG 库,支持 MSC 协议) STM32CubeMX 辅助开发工具(辅助开发自定义板上应用). G* _9 H3 ^- E( V, j- \ 上述软件都是免费对外开发,可在意法半导体官网 www.st.com 下载。2 L8 M5 t5 E9 y2 S" }9 N- B; e6 \ + x4 ]! |; L5 J 三 U 盘访问实现例 一步一步呈现访问 U 盘的 STM32 开发过程,实现对 U 盘的读写等操作。在下面的步骤详解中,会介绍一些主机库和应用机制的内容。如果希望快速开发,可以直接按照步骤开发,略过讲解性的内容。 4 h/ S5 @$ Z. Z4 F$ }$ ?( n+ a ![]() 3.1 前期准备4 A+ g& F6 {% h$ w2 X 出于遵循完全一致的实验步骤考虑,实例基于 ST 发布的 STM32F469I-DISCO 板。除此之外,开发者也可以根据自己的目标板的具体情况,参考后面介绍的实例进行配置。 注 1:STM32F469I-DISCO 板的原理图、用户手册等资源可通过链接获取。9 T! J7 S& I; S0 _ 注 2:STM32CubeF4 可以按照介绍方式获取,或者直接在官网下载,然后通过 STM32CubeMX 的本地导入软件包功能 完成导入。 3.2 应用实现 3.2.1 开发流程 结合 STM32CubeMX 的软件开发流程如下图。 5 \1 g6 z) |: E0 n. a! p" R ![]() 3.2.2 开发步骤详解: m& J' Z( g" f- Z/ m7 G 接下来一步一步呈现实现过程。 1. 打开 STM32CubeMX,点击 File\New Project,选择 STM32F469NI(STM32F469I-DISCO 上微控制器型号)。; P, `4 K: S, v8 o1 x4 E6 Y 2. 外设和中间件的选择。首先结合 STM32F469I-DISCO 板的原理图,了解功能实现必备的接口的使用情况,如下表所示。 ![]() 1 i" A a9 Q* r% b: `' y 注1. 在不考虑 SRP 和 HNP 时,访问 U 盘,只需要 STM32 的 USB OTG 的 USB 数据正负线即可。根据硬件情况,选择调试接口、外部时钟、USB OTG FS 和 USB 中间件,如下图所示。 : c6 P# n$ j# A% E* J/ O ![]() k& x% L* k6 Y5 F! }4 j( @8 N 在引脚分布图,PB2 引脚上单击鼠标左键,选择 ‘GPIO_Output’,如下图所示。3 o4 [4 w3 \# n6 a/ L + S7 }5 H8 ?, Z$ K4 p0 i ![]() 3. 配置时钟,使 USB 时钟为 48MHz,如下图。其中,步骤 2 中外部高速晶振值要和硬件上匹配。由于 USB 时钟精度要求高,STM32F469 内部时钟无法达到要求,必须选用外部高速时钟,如步骤 3 所示。对于 HCLK(处理器时钟,步骤 6 配置),根据性能需要进行设置,或者简单的设置为最大值。- ?4 ^' ]' D) C- r 5 S3 X" C. V7 O& Q! y2 w9 C ![]() 6 U; x, V$ M/ \/ c* _; L 4. USB 和关联的引脚配置。主要对 VBUS 使能引脚进行配置及关联。 在 USB_HOST 界面,配置 Drive_VBUS_FS 关联引脚为 PB2(与硬件连接对应)。VBUS 电源开关器件为STMPS2151STR,高电平使能。所以配置如下,在初始化后为低电平(图中步骤 7~10)。其他保持默认。 ![]() $ |' q. ]. t, |; U' g/ n 5. 设置工程,如下图所示(点击菜单栏\Project\Settings 打开)。选择对应的 IDE 和希望基于的 STM32Cube 软件包位置。实例简单,堆栈占用小,堆栈配置保持默认即可。除 EWARM 外,STM32CubeMX 还支持 MDK-ARM、TrueStudio、SW4STM32 等。 1 m: s0 ]: c2 x/ I& A) H1 x F7 c ![]() 6. 点击菜单栏\Project\Generate Code 生成工程。 工程生成后,会出现提示框,点击 ‘Open Project’打开工程。工程架构和文件结构如下图(右侧为 USB 主机应用架构)。生成工程包含全部层的实现,开发者在生成工程的基础上,可直接调用写读等 API,实现对 U 盘的访问。 ![]() 注: USB 主机库和各文件功能介绍,请参考《UM1720 STM32Cube USB host library》。( v* ~% a1 K8 x8 s& u 7. 添加 U 盘访问实现。 STM32CubeMX 生成的工程,调用 STM32Cube USB 主机库。在库中,软核将 USB 事件传输至用户层,并执行回调用户函数。方便在用户层的回调函数中添加应用实现。用户回调事件如下表。 4 [! n# N9 ^" ]# v( s9 } ![]() USB 软核状态机如下图所示。 9 t! R; O6 d8 q) g, @ ![]() 3 G: ]" b; L k% e0 O$ \ 在 HOST_CLASS 状态中,软核会通知应用类初始化完成。对 U 盘的访问,应放置在应用层接收到类初始化完成事件后,即 HOST_USER_CLASS_ACTIVE 事件后,否则无法正常工作。& o7 |! [: ~/ [: A+ a6 E0 b. M% { 在工程中添加/修改对 U 盘的写读访问操作和相关源码,如下表所示。7 ^& \- R5 {, b! w ![]() ![]() ![]() ![]() 注1. 省略号为了表示还有其他没有改动部分的源码,不用添加进源码中。展现的源码为了更好的表现出对应工程中位置,包含一些生成工程时原有的源码。' i- @; C3 [ ~$ @6 } 注2. MX_DriverVbusFS()中,需要根据实际情况进行配置。实验板上采用的电源开关 STMPS2151STR 高电平有效。在一些系列 STM32 的生成工程中,MX_DriverVbusFS 函数原型已经生成,此时无需再添加这个函数的声明,但要确认函数中引脚设置对应关系(形参为 1 时表示要激活)。1 ?/ Y% @: F- ^( @ 8. 编译生成的应用固件。 利用 IDE 进行编译、链接、下载到目标板,实现 U 盘信息获取和读写操作。1 @4 w! T+ m' O& E 9 ]( P+ x+ Q. Z0 G& b5 w% e8 N! V9 j 四 测试&验证 连接 U 盘至 STM32F469I-DISCO 板的 USB_User 连接口。IAR 进入在线调试模式,利用在线调试,查看获取到的 U 盘信息和写读缓存中的数据情况。$ C, h/ y$ i, Y v# W9 ^3 f1 h! k 运行完毕后,连接 U 盘至 PC,利用 PC 上安装的 Active@ Disk Editor(外部链接)查看 U 盘对应扇区数据(10 扇区对应起始位置为 5120),从而验证 U 盘信息获取和写读功能正常。如下图所示。 ![]() ! m( y T# m H0 L4 Y+ I 五 小结 STM32CubeMX 加速了 STM32 的开发过程。即使类似 USB 这种复杂的外设使用,也可以如上述实现例,只需要几个步骤即可以实现 USB 应用。并且提供了除 MSC 类之外,HID、UAC、CDC 等类支持; c1 x* x; E' n$ `0 w0 Y / a4 i6 p( i0 X! u . S% Z" ] F( l0 s; |. n 2 O$ v5 i$ S+ a: B% e5 k! p 7 g5 m7 V6 o! b8 M. _8 G! Y % o+ v% z2 W0 f , t& c6 {8 [- n 3 @8 Q3 ^+ L1 m; I* X " J" A {) S# H% r$ Z' L V; L ' W% i0 B5 q( a8 v( V ! X- u# ?$ V% D. D4 E) o- m - m( a6 I4 V5 N8 b V0 Q * k+ u. Q7 C) [3 r, M. u* ?$ K |
实战经验 | Keil工程使用NEAI库的异常问题
STM32 ISP IQTune:真正零门槛的免费ISP调整软件
【经验分享】STM32 新建基于STM32F40x 固件库的MDK5 工程
意法半导体MCU双供应链策略,打消中国客户后顾之忧
【经验分享】基于STM32使用HAL库实现USB组合设备CDC+MSC
2024意法半导体工业峰会:赋能智能电源和智能工业,构筑可持续未来
ST推出灵活、面向未来的智能电表通信解决方案,助力能源转型
意法半导体 x Qu-Bit Electronix:推动新一轮的数字声音合成革命
从STM32 MPU产品看嵌入式系统中微处理器的新变化
【Hot!】STM32全系列开发板都支持Arduino开发,你知道吗?