STM32F0DISCOVERY 外设固件示例
简介
本应用笔记介绍了为 STM32F0DISCOVERY 套件提供的一些外设固件示例。
这些示例可立即使用,可帮助用户快速了解 STM32F0xx 外设和 STM32F0DISCOVERY 板硬件。每个示例都配备了一些预配置项目,涵盖到 EWARM (IAR Embedded Workbench®for ARM®)、MDK-ARM™、Atollic TrueSTUDIO® 和 Altium TASKING® 工具。
可以从 www.st.com/stm32f0discovery 下载固件应用程序软件包,其中就包含了这些示例。建议用户首先阅读 STM32F0DISCOVERY 套件 的软件和固件环境入门 (UM1523) 以熟悉STM32F0DISCOVERY 套件。
表 1 列出了本应用笔记所涉及的微控制器和开发工具。
1 外设固件示例结构概述
在 STM32F0DISCOVERY 固件应用程序软件包中提供了一些外设固件示例,这些示例位于\Project 文件夹下,如图 1 中所示。
1. VX.Y.Z 表示软件包版本,例如 V1.0.0。
要运行示例,请使用首选工具打开项目,然后编译,再加载和运行项目。某些示例可能需要额外硬件,如示波器(以进行观测)。有关必需硬件的更多详细信息,请参见每个示例中提供的自述文件。
2 时钟配置
STM32F0-Discovery 套件固件软件包中提供的外设示例以 48 MHz 运行,且使用 HSI 作为时钟源。
用户可以修改配置以使用 HSE(晶振模式或旁路模式)作为时钟源,但是这需要改变 Discovery套件硬件。
每个示例中提供的“system_stm32f0xx.c”文件都进行了定制,用户可以选择以下三个配置之一(通过取消注释 adequate define)来配合 Discovery 使用。
2.1 PLL_SOURCE_HSI
HSI 时钟信号通过内部 8 MHz RC 振荡器来生成,可直接用作系统时钟,或者经 2 分频用作PLL 输入。
HSI RC 振荡器的优点是时钟源成本较低(无外部元件),而且启动时间也比 HSE 晶振的启动时间更快。但是,即使是经过了校准,其频率的精度仍然低于外部晶振或陶瓷谐振器。
注: 此配置为默认配置。
2.2 PLL_SOURCE_HSE
可以通过两种时钟源来生成高速外部时钟信号 (HSE): • HSE 外部晶振/陶瓷谐振器 • HSE 用户外部时钟
Discovery 套件未随附 HSE 晶振。要连接到该晶振需要进行一些硬件改造。
有关更多详细信息,请参见“STM32F0 Discovery 套件用户手册 (UM1525)”中的“4.7 OSC时钟”一节。
2.3 PLL_SOURCE_HSE_BYPASS
在此模式中,将通过外部时钟(频率固定为 8 MHz,来自于 ST-Link 电路)来旁路 HSE。它用于对 PLL 进行时钟控制,并且 PLL 用作系统时钟源。
要通过来自 ST-Link 电路的时钟来旁路 HSE,必须进行某些硬件改造。有关更多详细信息,请参见“STM32F0 Discovery 套件用户手册 (UM1525)”中的“4.7 OSC 时钟”一节。 3 外设固件示例说明
3.1 GPIO 翻转示例
目的
此示例说明如何使用 BSRR 和 BRR(端口位设置/复位寄存器高电平与低电平)以最快速度翻转 I/O。
GPIO 端口连接到 AHB 总线;使用 BSRR 和 BRR 寄存器时,需要两个周期来拉高一个引脚,并需要另外两个周期来拉低该引脚。因此,GPIO 引脚能够以 AHB 时钟的 1/4 进行切换。
说明
在此示例中,PC8 和 PC9(以推挽输出模式配置)不停地翻转:
• 通过在 BSRR 寄存器中设置对应的位来拉高 PC8 和 PC9。
• 通过在 BRR 寄存器中设置对应的位来拉低 PC8 和 PC9。
在本示例中,HCLK 配置为 48 MHz,因此 PC8 和 PC9 以 12 MHz 翻转。
要实现 I/O 最大翻转频率,必须配置编译器选项进行高速优化。
3.2 EXTI 示例
目的
本示例表明如何配置外部中断线。
说明
在本示例中: • PA0 引脚在悬空输入状态下配置。 • PA0 配置为外部中断源线 0 (EXTI0)。 • EXTI 线 0 配置为在 PA0 引脚上检测到的每个上升沿上生成一个中断。每次按 User(用户)按钮时都会触发中断。 • 在 NVIC(嵌套向量中断控制器)中,配置了 EXIT 线 0 中断优先级并且使能了中断。
当执行程序并且用户按 User(用户)按钮(EXTI0 中断程序)时,将切换 LED3(与 PC9 连接)和 LED4(与 PC8 连接)。
3.3 SysTick 示例
目的
本示例说明如何配置系统节拍定时器以及如何将其用于生成 1 ms 时基。
说明
在本示例中: • 系统节拍定时器初始化。 • 系统节拍定时器中断在 NVIC 中使能。 • 系统节拍定时器/计数器以自由运行模式启动以产生周期中断。 • 每隔 1 ms 触发一次系统节拍定时器中断。 • 根据系统节拍定时器计数结束事件,实现延迟函数。 两个 LED(LED3 和 LED4)通过延迟函数定义的计时来切换
|