STM32F4是由ST(意法半导体)开发的一种高性能微控制器,之前学习过51单片机的相关知识,现在看STM32F4的芯片,不得不说它强大的外设功能,还有就是固件库。对于STM32这样庞大的芯片,内部寄存器实在太多,如果操作的外设比较多,那么就需要花很多时间查询底层寄存器内容,而且即使程序写好,如果要换其他端口或者外设的话,修改起来非常麻烦,而且容易出错,移植性也差。基于这些原因,ST公司推出一套固件库,内部已经将STM32的全部外设寄存器的控制封装好,给用户提供一些API函数,用户只需要学习如何使用这些API函数即可。
CMISIS(Cortex MicroController Software Interface Standard)ARM Cortex微控制器软件接口标准。总的来说CMSIS就是统一各芯片厂商固件库内函数的名称。接下来,我们从一个简单的点亮LED的实验开始,自定义一个系统时钟初始化函数,(配置一个库函数模板在这里不说了,普中科技的开发板资料特别全)
首先添加一个led.h头文件
#ifndef _LED_H
#define _LED_H
#include"stm32f4xx.h"
void LED_Init(void);
#endif
然后是LED_Init(void)函数定义,添加led.c源文件
#include "led.h"
void LED_Init()
{
GPIO_InitTypeDef GPIO_InitStructure;//定义结构体变量
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF,ENABLE);//使能端口时钟
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_OUT;//输出模式
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_10;//管脚设置为PF9
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_100MHz;//速度为100MHz
GPIO_InitStructure.GPIO_OType=GPIO_OType_PP;//推挽输出
GPIO_InitStructure.GPIO_PuPd=GPIO_PuPd_UP;//上拉
GPIO_Init(GPIOF,&GPIO_InitStructure);//初始化结构体
}
最后看下他的主函数main.c
#include "stm32f4xx.h"
#include "led.h"
void delay(u32 i)
{
while(i--);
}
void RCC_HSE_Config(u32 pllm,u32 plln,u32 pllp,u32 pllq)
{
RCC_DeInit(); //将外设RCC寄存器重设为缺省值
RCC_HSEConfig(RCC_HSE_ON);//设置外部晶振(HSE)
if(RCC_WaitForHSEStartUp()==SUCCESS) //等待HSE起振
{
RCC_HCLKConfig(RCC_SYSCLK_Div1);//设置AHB时钟(HCLK)
RCC_PCLK2Config(RCC_HCLK_Div2);//设置APB2时钟(PCLK2)
RCC_PCLK1Config(RCC_HCLK_Div4);//设置APB1时钟(PCLK1)
RCC_PLLConfig(RCC_PLLSource_HSE,pllm,plln,pllp,pllq);//设置PLL时钟源及倍频系数
RCC_PLLCmd(ENABLE); //使能PLL
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET);//检查指定的RCC标志位设置与否,PLL就绪
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//设置系统时钟
while(RCC_GetSYSCLKSource()!=0x08);//返回用作系统时钟的时钟源,0x08:PLL作为系统时钟
}
}
int main()
{
RCC_HSE_Config(8,336,4,7); //pllp=2改为4,相当于把168M系统时钟改为84M
LED_Init();
while(1)
{
GPIO_ResetBits(GPIOF,GPIO_Pin_9);//复位F9,LED被点亮
delay(6000000);
GPIO_SetBits(GPIOF,GPIO_Pin_9);//置位F9,LED灭
delay(6000000);
}
}
你可以自己修改更改pllm,plln,pllp,pllq这几个参数,但是他们只有范围的,还有就是系统时钟最大不要超过168M