STM32 HAL常用库函数(持续更新)

1.设置GPIO引脚函数
函数名称:void HAL_GPIO_WritePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState);
第一个参数:GPIOA,B,C,D…(取决于单片机型号)
第二个参数:可以取GPIO_PIN_0~GPIO_PIN_15
第三个参数:GPIO_PIN_SET(置高电平),GPIO_PIN_RESET(置低电平)
例:

HAL_GPIO_WritePin(GPIOA, GPIO_PIN_0, GPIO_PIN_SET);//将PA0置高电平
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_0, GPIO_PIN_RESET);//将PA0置低电平

2.读取GPIO引脚函数
函数名称:GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
第一个参数:GPIOA,B,C,D…(取决于单片机型号)
第二个参数:可以取GPIO_PIN_0~GPIO_PIN_15
返回值:返回"0",对应引脚为低电平,返回"1",对应引脚为高电平。
例:

uint8_t pinstate = 0;
pinstate = HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0);

3.GPIO引脚翻转函数
函数名称:void HAL_GPIO_TogglePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
函数功能:若引脚为低电平,则变为高电平;若为高电平,则变为低电平。
第一个参数:GPIOA,B,C,D…(取决于单片机型号)
第二个参数:可以取GPIO_PIN_0~GPIO_PIN_15
4.串口发送函数
函数名称:HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout);
函数功能:向串口发送数据(字符串)
第一个参数:哪一个串口
第二个参数:数据指针,指针类型为uint8_t *
第三个参数:数据长度
第四个参数:超时时间,单位是ms
返回值:HAL状态。有四种状态,分别是HAL_OK,HAL_ERROR,HAL_BUSY,HAL_TIMEOUT。
例:

HAL_UART_Transmit(&huart1, "Hello World!!", 13, 100);//向串口1发送Hello World!!

5.printf串口发送函数(重写fputc)
我用过两个版本的fputc,分别对应不同的stm32单片机型号,因为它们的USART寄存器不一样。
版本一:

int fputc(int ch, FILE *f)
{      
    while((USART1->SR&0X40)==0);//循环发送,直到发送完毕   
    USART1->DR = (uint8_t) ch;      
    return ch;
}

版本二:

int fputc(int ch,FILE *f)
{
	while(!((USART1->ISR)&(1<<7)));
	USART1->TDR = ch;
	return ch;
}

6.延时函数
函数名称:void HAL_Delay(uint32_t Delay);
函数功能:毫秒延时函数
参数:延时时间,单位ms
7.定时器中断函数
需要重写HAL_TIM_PeriodElapsedCallback函数,直接看例子:

void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
    static unsigned char ledState = 0;
    if (htim == (&htim2))//TIM2的中断服务函数
    {
        if (ledState == 0)
            HAL_GPIO_WritePin(GPIOE,GPIO_PIN_15,GPIO_PIN_RESET);
        else
            HAL_GPIO_WritePin(GPIOE,GPIO_PIN_15,GPIO_PIN_SET);
        ledState = !ledState;
    }
}

若使用定时器中断,还需先打开定时器中断,相关函数如下:

HAL_TIM_Base_Start_IT(&htim2);//开定时器中断函数
HAL_TIM_Base_Stop_IT(&htim2);//关闭时器中断函数

8.PWM相关函数
函数名称:HAL_StatusTypeDef HAL_TIM_PWM_Start(TIM_HandleTypeDef *htim, uint32_t Channel);
第一个参数:哪个定时器
第二个参数:哪个通道
返回值:HAL状态,与第四个串口发送函数返回只相同。
例:

HAL_TIM_PWM_Start(&htim5, TIM_CHANNEL_2);//开启定时器5,第二个通道的PWM

pwm修改占空比:__HAL_TIM_SetCompare

__HAL_TIM_SetCompare(&htim5, TIM_CHANNEL_2, 100);//即TIM5,第二个通道的比较值改为100,通过修改比较值修改占空比

也可以使用寄存器修改,同样很方便:

TIM5->CCR2 = 100;
  • 81
    点赞
  • 504
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
以下是STM32G单片机HAL库函数HAL_FLASHEx_Erase的代码实现及解析: ```c HAL_StatusTypeDef HAL_FLASHEx_Erase(FLASH_EraseInitTypeDef *pEraseInit, uint32_t *SectorError) { uint32_t nbSectorsToErase = 0U; uint32_t sectorErrorTmp; uint32_t sectorErrorMask; HAL_StatusTypeDef status = HAL_OK; /* Check the parameters */ assert_param(IS_FLASH_TYPEERASE(pEraseInit->TypeErase)); assert_param(IS_FLASH_BANK_EXCLUSIVE(pEraseInit->Banks)); assert_param(IS_FLASH_NBSECTORS(pEraseInit->NbSectors)); /* Wait for last operation to be completed */ status = FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE); if (status != HAL_OK) { return status; } /* Clear OPTVERR bit set on virgin samples */ __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_OPTVERR); /* Get the number of sectors to erase from 1st sector*/ nbSectorsToErase = pEraseInit->NbSectors; /* Check if there are any sectors to erase */ if (nbSectorsToErase == 0U) { return HAL_ERROR; } /* Initialize sectorErrorMask to 0 */ sectorErrorMask = 0U; /* Erase by sector by sector to have a higher granularity than the page erase */ while (nbSectorsToErase > 0U) { /* Fill EraseInit structure*/ pEraseInit->TypeErase = FLASH_TYPEERASE_SECTORS; /* Select the bank to erase */ if (pEraseInit->Banks == FLASH_BANK_1) { pEraseInit->Bank = FLASH_BANK_1; } #if defined(FLASH_BANK_2) else if (pEraseInit->Banks == FLASH_BANK_2) { pEraseInit->Bank = FLASH_BANK_2; } #endif /* FLASH_BANK_2 */ /* Get the sector to erase */ uint32_t sectorNb = FLASH_SECTOR_0; for (uint32_t i = 0; i < FLASH_SECTOR_NUMBER; i++) { if (pEraseInit->Sector & (1UL << i)) { sectorNb = i; break; } } pEraseInit->Sector = sectorNb; /* Call the erase module */ HAL_FLASHEx_Erase_IT(pEraseInit); /* Wait for last operation to be completed */ status = FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE); /* If the erase operation is completed, disable the SER Bit */ CLEAR_BIT(FLASH->CR, FLASH_CR_SER); if (status != HAL_OK) { /* In case of error, stop erase procedure and return the faulty sector */ sectorErrorMask |= (1UL << sectorNb); /* Save the error code */ sectorErrorTmp |= status; } else { /* No error occurred in sector erase operation sectorErrorMask is reset */ sectorErrorMask = 0U; } /* Decrement number of sectors to erase */ nbSectorsToErase--; /* Point on next sector */ pEraseInit->Sector = (uint32_t)(pEraseInit->Sector << 1U); } /* Return the erase status */ if (SectorError != NULL) { *SectorError = sectorErrorTmp; } if (sectorErrorMask != 0U) { status = HAL_ERROR; } return status; } ``` HAL_FLASHEx_Erase函数的实现过程如下: 1. 检查输入参数pEraseInit是否合法。该结构体包含了要擦除的Flash扇区的相关信息,如起始地址、扇区数量和擦除方式等。 2. 等待上一次Flash操作(如写入或擦除)完成,并且清除OPTVERR标志位。如果等待超时,则返回错误。 3. 计算需要擦除的Flash扇区数量,并且检查是否有扇区需要擦除。如果扇区数量为0,则直接返回错误。 4. 循环执行Flash扇区擦除操作,直到所有需要擦除的扇区都被擦除。具体的操作包括: - 将需要擦除的扇区信息填入FLASH_EraseInitTypeDef结构体中,并且调用HAL_FLASHEx_Erase_IT函数执行擦除操作。 - 等待Flash擦除操作完成,并且检查是否有错误发生。如果发生了错误,则保存错误信息,但是继续执行擦除操作直到所有需要擦除的扇区都被擦除。 - 将擦除完成的扇区数量减1,继续执行下一个扇区的擦除操作。 5. 返回擦除操作的结果。如果有错误发生,则返回错误代码;否则,返回HAL_OK表示操作成功。 需要注意的是,该函数执行期间会禁止中断,并且解锁Flash,并且在函数执行完毕之后会恢复中断,并且重新锁定Flash。因此,在调用该函数之前,需要确保中断不会影响到Flash的操作,并且需要适当地设置Flash的保护等级以避免意外修改Flash。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值