STM32F0DISCOVERY 外设固件示例 8 E* P- K! C$ Q- @, ^$ Y/ @- }2 J 简介 0 i% y, j7 |, q& A, J 本应用笔记介绍了为 STM32F0DISCOVERY 套件提供的一些外设固件示例。 % O2 F5 _) l) l" d2 Y. ~ 9 K$ z% x7 f |6 n9 Y( u) F# c 这些示例可立即使用,可帮助用户快速了解 STM32F0xx 外设和 STM32F0DISCOVERY 板硬件。每个示例都配备了一些预配置项目,涵盖到 EWARM (IAR Embedded Workbench®for ARM®)、MDK-ARM™、Atollic TrueSTUDIO® 和 Altium TASKING® 工具。 ! F( ^5 L( A7 j, T0 K 可以从 www.st.com/stm32f0discovery 下载固件应用程序软件包,其中就包含了这些示例。建议用户首先阅读 STM32F0DISCOVERY 套件 的软件和固件环境入门 (UM1523) 以熟悉STM32F0DISCOVERY 套件。 , J |9 [& K# ]& y1 L4 q9 |3 r6 \ 表 1 列出了本应用笔记所涉及的微控制器和开发工具。! W- Y) |4 p& j: b8 R , d' c4 s: G: x 1 ~$ ?1 ~: C5 R" \1 d" ~4 y# p 1 外设固件示例结构概述 " T: r8 O: D' [7 {9 G0 v1 r. c在 STM32F0DISCOVERY 固件应用程序软件包中提供了一些外设固件示例,这些示例位于\Project 文件夹下,如图 1 中所示。 1. VX.Y.Z 表示软件包版本,例如 V1.0.0。 0 G' P4 c8 u% d7 B. F 要运行示例,请使用首选工具打开项目,然后编译,再加载和运行项目。某些示例可能需要额外硬件,如示波器(以进行观测)。有关必需硬件的更多详细信息,请参见每个示例中提供的自述文件。 2 时钟配置 1 O0 B& W/ v2 A. D$ K STM32F0-Discovery 套件固件软件包中提供的外设示例以 48 MHz 运行,且使用 HSI 作为时钟源。 用户可以修改配置以使用 HSE(晶振模式或旁路模式)作为时钟源,但是这需要改变 Discovery套件硬件。 每个示例中提供的“system_stm32f0xx.c”文件都进行了定制,用户可以选择以下三个配置之一(通过取消注释 adequate define)来配合 Discovery 使用。 5 U1 K6 j; v0 S* M 2.1 PLL_SOURCE_HSI HSI 时钟信号通过内部 8 MHz RC 振荡器来生成,可直接用作系统时钟,或者经 2 分频用作PLL 输入。 ( L* M7 G) p! u% @( |# f* {8 t HSI RC 振荡器的优点是时钟源成本较低(无外部元件),而且启动时间也比 HSE 晶振的启动时间更快。但是,即使是经过了校准,其频率的精度仍然低于外部晶振或陶瓷谐振器。 % o% z- w+ s# g: M8 Z' s! h/ J 注: 此配置为默认配置。 3 J6 i. T7 j. Z 2.2 PLL_SOURCE_HSE 可以通过两种时钟源来生成高速外部时钟信号 (HSE): • HSE 外部晶振/陶瓷谐振器 • HSE 用户外部时钟 Discovery 套件未随附 HSE 晶振。要连接到该晶振需要进行一些硬件改造。 # Y1 ~5 b# `4 E/ d$ i 有关更多详细信息,请参见“STM32F0 Discovery 套件用户手册 (UM1525)”中的“4.7 OSC时钟”一节。 4 Z9 V1 X! w' L1 ` 2.3 PLL_SOURCE_HSE_BYPASS * ~% K! [ ?# _ g9 B3 k 在此模式中,将通过外部时钟(频率固定为 8 MHz,来自于 ST-Link 电路)来旁路 HSE。它用于对 PLL 进行时钟控制,并且 PLL 用作系统时钟源。 % z: S7 Q% K7 R$ I6 a5 m* S 要通过来自 ST-Link 电路的时钟来旁路 HSE,必须进行某些硬件改造。有关更多详细信息,请参见“STM32F0 Discovery 套件用户手册 (UM1525)”中的“4.7 OSC 时钟”一节。 3 外设固件示例说明 " ]; p* l+ h9 U! q. C6 n' X) C 3.1 GPIO 翻转示例 , F7 W# G0 x' U# M0 r 目的 2 j7 Z0 j9 V! M( I' u# O. s+ L 此示例说明如何使用 BSRR 和 BRR(端口位设置/复位寄存器高电平与低电平)以最快速度翻转 I/O。 GPIO 端口连接到 AHB 总线;使用 BSRR 和 BRR 寄存器时,需要两个周期来拉高一个引脚,并需要另外两个周期来拉低该引脚。因此,GPIO 引脚能够以 AHB 时钟的 1/4 进行切换。 说明 在此示例中,PC8 和 PC9(以推挽输出模式配置)不停地翻转: • 通过在 BSRR 寄存器中设置对应的位来拉高 PC8 和 PC9。 6 n- y* L6 s) a$ v0 `4 K5 |4 p • 通过在 BRR 寄存器中设置对应的位来拉低 PC8 和 PC9。 , f. y6 C) h2 U+ b k8 x: l 在本示例中,HCLK 配置为 48 MHz,因此 PC8 和 PC9 以 12 MHz 翻转。 ( W1 T) B$ s% `/ I 要实现 I/O 最大翻转频率,必须配置编译器选项进行高速优化。 3.2 EXTI 示例 % T1 x7 C8 [, _) j 目的 本示例表明如何配置外部中断线。 [' c# L6 ?+ A! [ ~/ @7 ] 说明 . l& I3 `' r- M! b4 {4 Q4 X 在本示例中: • PA0 引脚在悬空输入状态下配置。 • PA0 配置为外部中断源线 0 (EXTI0)。 • EXTI 线 0 配置为在 PA0 引脚上检测到的每个上升沿上生成一个中断。每次按 User(用户)按钮时都会触发中断。 • 在 NVIC(嵌套向量中断控制器)中,配置了 EXIT 线 0 中断优先级并且使能了中断。 当执行程序并且用户按 User(用户)按钮(EXTI0 中断程序)时,将切换 LED3(与 PC9 连接)和 LED4(与 PC8 连接)。 3.3 SysTick 示例 目的 本示例说明如何配置系统节拍定时器以及如何将其用于生成 1 ms 时基。 说明 # \2 ]0 }! o& Y$ u2 ]2 F, [ 在本示例中: • 系统节拍定时器初始化。 • 系统节拍定时器中断在 NVIC 中使能。 • 系统节拍定时器/计数器以自由运行模式启动以产生周期中断。 • 每隔 1 ms 触发一次系统节拍定时器中断。 • 根据系统节拍定时器计数结束事件,实现延迟函数。 两个 LED(LED3 和 LED4)通过延迟函数定义的计时来切换 . B4 q; ^ N {; d$ N " T. @+ V) r: O( z |
谢谢图图的分享 |
支持~~~~~ |
STM32固件库分享,超全系列整理
三创电子(Tcreate)-STM32F030核心板代码
STM32F0 ADC(DMA中断)多通道,注释超详细
FreeRTOS在STM32F030上的移植
基于STM32移植而引发的疑问经验分享
分享STM32F051中文参考手册(重制书签版)
游名:STM32F0+Trinamic智能步进驱动芯片TMC5160(最高20A)参考原...
【MCU实战经验】+STM32F030的步进电机加减速
STM32F0的中文技术参考手册(标签处理过)
基于STM32F030硬件SPI经验分享