STM32通过调用库函数进行编程

1、调用库函数编程和直接配置寄存器编程的区别:


2、CMSIS标准:



3、STM32库函数的组织:



4、程序例举:

调用库函数实现通过USART发送数据(26个大写的英文字母)


首先:在主函数部分先要(调用自己编写的函数)对USART要用到的I/O端口进行配置、打开系统时钟配置和对USART1进行参数配置




下图是通过调用库函数对USART1的参数进行配置,将其配置成异步收发模式、波特率用户可以自定的串口:



/**************************************************************************************************
 *	硬件平台:STM32F103VC
 *	学习重点:调用库函数来实现对USART的操作
 *	实现功能:软件仿真,实现STM32通过USART1发送数据
 *	作    者:赵小龙
 **************************************************************************************************/


/* Includes ------------------------------------------------------------------*/
#include "stm32f10x_lib.h"	  //包含了所有的头文件 它是唯一一个用户需要包括在自己应用中的文件,起到应用和库之间界面的作用。
#include "stm32f10x_map.h"


/*----------------函数声明部分---------------*/
void delay1ms(int t) ;
void RCC_Configuration(void) ;
void GPIO_Configuration(void) ;
void USART_Configuration(u32 BaudRate) ;


/* Private functions -----------------------------------------------------------------------------*/ 
/**************************************************************************************************
* Function Name  : main
* Description    : 软件仿真,从USART1发送26个大写的英文字母
* Input          : None
* Output         : None
* Return         : None
****************************************************************************************************/
int main(void)
{

	u8 i,data;	
/*--------配置开启系统时钟、配置USART1发送/接收使用的两个I/O口、配置USART1---------------------------------------------*/
	RCC_Configuration();
	GPIO_Configuration();
	USART_Configuration(19600);

/*--------发送一串字符‘A’--‘Z’到USART1的DR-----------------------------------------------------------------------------*/
	data='A';
	for(i=0;i<26;i++)
	{
		USART_SendData(USART1, data) ;
		data++ ;
		while(USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET) ;//发送完成标志位为1时便是数据发送完毕,若为0时则应让程序等待(等待数据发送发送完成)
		/*注意:这里最好不要按照以下形式书写,否则会出错,具体原因我暂且还不知道
			u8 status ; 
			status = USART_GetFlagStatus(USART1, USART_FLAG_TC) ;  //将查看状态寄存器的函数的返回值赋值给变量status 
			while(status == RESET) ;
		*/
	}

}

/*******************************************************************************
* Function Name  : Delay_Ms
* Description    : delay 1 ms.
* Input          : dly (ms)
* Output         : None
* Return         : None
*******************************************************************************/
void delay1ms(int t)
{
	//机器周期T = 1/(72000000/12)s = 1/6000000 s = 1/6 us
	int temp = 6000/4 ;
	while(t--)
	{
		while(temp--)
		{ ; }	
	}

}


/*******************************************************************************
* Function Name  : RCC_Configuration
* Description    : Configures the different system clocks.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void RCC_Configuration(void)
{
	//----------使用外部RC晶振-----------
	RCC_DeInit();			//初始化为缺省值
	RCC_HSEConfig(RCC_HSE_ON);	//使能外部的高速时钟 
	while(RCC_GetFlagStatus(RCC_FLAG_HSERDY) == RESET);	//等待外部高速时钟使能就绪
	
	//FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);	//Enable Prefetch Buffer
	//FLASH_SetLatency(FLASH_Latency_2);		//Flash 2 wait state
	
	RCC_HCLKConfig(RCC_SYSCLK_Div1);		//HCLK = SYSCLK
	RCC_PCLK2Config(RCC_HCLK_Div1);			//PCLK2 =  HCLK
	RCC_PCLK1Config(RCC_HCLK_Div2);			//PCLK1 = HCLK/2
	RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);	//PLLCLK = 8MHZ * 9 =72MHZ
	RCC_PLLCmd(ENABLE);			//Enable PLLCLK

	while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);	//Wait till PLLCLK is ready
    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);	//Select PLL as system clock
	while(RCC_GetSYSCLKSource()!=0x08);		//Wait till PLL is used as system clock source
	
	//---------打开相应外设时钟--------------------
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);	//使能APB2外设的GPIOA的时钟	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC,ENABLE);	//使能APB2外设的GPIOC的时钟
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
	
	//GPIO_PinRemapConfig(GPIO_Remap_USART1,ENABLE);	 
		 
}

/*******************************************************************************
* Function Name  : GPIO_Configuration
* Description    : 初始化GPIO外设
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/ 
void GPIO_Configuration(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;

  /* Configure USARTx_Tx as alternate function push-pull */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  GPIO_Init(GPIOA, &GPIO_InitStructure);

  /* Configure USARTx_Rx as input floating */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  GPIO_Init(GPIOA, &GPIO_InitStructure);

}

/*******************************************************************************
* Function Name  : USART_Configuration
* Description    : 初始化串口USART1(异步收发模式)
* Input          : BaudRate (要设置的波特率)
* Output         : None
* Return         : None
*******************************************************************************/ 
void USART_Configuration(u32 BaudRate)
{
//1、定义一个用于初始化USART的结构体
	USART_InitTypeDef USART_InitStructure;
	 
//2、给结构体元素赋值,设置 波特率、数据帧的位数、停止位的位数、奇偶校验位、硬件流控制位、USART模式(发送、接收)
	USART_InitStructure.USART_BaudRate = BaudRate; 
	USART_InitStructure.USART_WordLength = USART_WordLength_8b; 
	USART_InitStructure.USART_StopBits = USART_StopBits_1; 
	USART_InitStructure.USART_Parity = USART_Parity_No; 
	USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; 
	USART_InitStructure.USART_Mode = USART_Mode_Tx | USART_Mode_Rx;  

//3、调用函数USART_Init();用上面的结构体值作为参数对USART1进行初始化
	USART_Init(USART1, &USART_InitStructure);

//4、调用函数USART_Cmd();对USART1进行使能
	USART_Cmd(USART1, ENABLE);

}


程序运行前:


程序运行后:


  • 6
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: STM32L051函数是指用于开发和编程STM32L051微控制器的一系列函数STM32L051是STMicroelectronics公司推出的一款低功耗、高性能的32位微控制器。 这些函数包括了各种功能和模块的操作函数,如GPIO控制、定时器配置、UART通信、SPI通信、I2C通信、ADC采样、PWM输出等。通过调用这些函数,开发者可以方便地使用这些功能,并进行自定义配置。 STM32L051函数简化了开发者的编程过程。相比于直接编写底层寄存器操作,使用函数可以更加简洁和易读,同时也提高了开发的效率。函数封装了底层的硬件操作,隐藏了底层细节,使开发者可以更专注于业务逻辑的实现。 除了基本的硬件功能操作外,STM32L051函数还提供了一些高级功能的封装,如电源管理、时钟配置、低功耗模式等。这些功能可以帮助开发者更好地利用STM32L051的低功耗特性,以达到节能和延长电池寿命的目的。 总之,STM32L051函数是一套用于开发和编程STM32L051微控制器的函数,它提供了丰富的功能操作接口,简化了开发者的编程过程,并帮助实现更高效、低功耗的应用。 ### 回答2: STM32L051是一款低功耗的ARM Cortex-M0+微控制器,包含了丰富的内置外设和功能模块。STM32L051函数是由STMicroelectronics提供的专门为该系列微控制器编写的一套函数,用于简化开发人员在STM32L051上的软件开发过程。 STM32L051函数提供了一系列API接口,涵盖了片上外设的配置和控制,包括GPIO、定时器、串口、I2C、SPI、ADC等常用外设。通过调用这些函数,开发人员能够快速地配置和使用相关外设,加快软件开发周期。 使用STM32L051函数,开发人员只需关注具体的外设配置和数据处理,不需要深入了解底层的硬件驱动、寄存器操作等复杂细节,大大提高了开发效率和可靠性。另外,函数还提供了一些实用的功能函数,如延时函数、中断处理函数等,可以方便地进行软件设计和调试。 此外,STM32L051函数还集成了一些低功耗控制相关的功能,如待机模式、休眠模式、唤醒源选择等。通过调用相应的函数,开发人员可以轻松地优化系统功耗,延长电池续航时间。 总之,STM32L051函数为开发人员提供了一种简单、快速、高效的开发方式,使得在STM32L051上开发应用变得更加容易和便捷。通过利用函数,开发人员能够更专注于应用层的功能实现,快速推动产品的开发和上市。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值