你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

查看: 494|回复: 2

【中文文档】AN4062_STM32F0DISCOVERY外设固件示例

[复制链接]

1347

主题

1124

回帖

0

蝴蝶豆

管理员

最后登录
2020-12-9
发表于 2019-3-26 13:05:05 | 显示全部楼层 |阅读模式
STM32F0DISCOVERY 外设固件示例

简介

本应用笔记介绍了为 STM32F0DISCOVERY 套件提供的一些外设固件示例。

这些示例可立即使用,可帮助用户快速了解 STM32F0xx 外设和 STM32F0DISCOVERY 板硬件。每个示例都配备了一些预配置项目,涵盖到 EWARM (IAR Embedded Workbench®for ARM®)、MDK-ARM™、Atollic TrueSTUDIO® 和 Altium TASKING® 工具。

可以从 www.st.com/stm32f0discovery 下载固件应用程序软件包,其中就包含了这些示例。建议用户首先阅读 STM32F0DISCOVERY 套件 的软件和固件环境入门 (UM1523) 以熟悉STM32F0DISCOVERY 套件。

表 1 列出了本应用笔记所涉及的微控制器和开发工具。

2.png


1 外设固件示例结构概述

在 STM32F0DISCOVERY 固件应用程序软件包中提供了一些外设固件示例,这些示例位于\Project 文件夹下,如图 1 中所示。

1.png
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)通过延迟函数定义的计时来切换

.............

想了解更多,请下载原文阅读




回复

使用道具 举报

14

主题

719

回帖

58

蝴蝶豆

金牌会员

最后登录
2020-12-1
发表于 2019-3-26 15:58:18 | 显示全部楼层
谢谢图图的分享
回复 支持 反对

使用道具 举报

1

主题

126

回帖

14

蝴蝶豆

高级会员

最后登录
2020-9-28
发表于 2019-5-26 23:07:41 | 显示全部楼层
支持~~~~~
回复 支持 反对

使用道具 举报

请先关注话题后回复
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版