STM32F4xx_GPIO常用设置

1、初始化时钟:

  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA | RCC_AHB1Periph_GPIOB | RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_GPIOD | RCC_AHB1Periph_GPIOE, ENABLE);

2、输出设置:

  

  GPIO_InitTypeDef  GPIO_InitStructure;
  GPIO_StructInit(&GPIO_InitStructure);
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_9;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_25MHz;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  GPIO_Init(GPIOB, &GPIO_InitStructure);

 

3、输入设置:

  

  GPIO_InitTypeDef   GPIO_InitStructure;
  GPIO_StructInit(&GPIO_InitStructure);
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_25MHz;
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  GPIO_Init(GPIOC, &GPIO_InitStructure);

4、模拟输入:

  

    GPIO_InitTypeDef GPIO_InitStructure;

    GPIO_StructInit(&GPIO_InitStructure);
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;
    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL ;
    GPIO_Init(GPIOA, &GPIO_InitStructure);

5、管脚复用:

  

    GPIO_InitTypeDef GPIO_InitStruct;

    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);

    GPIO_PinAFConfig(GPIOA, GPIO_PinSource6, GPIO_AF_TIM3);
    GPIO_PinAFConfig(GPIOA, GPIO_PinSource7, GPIO_AF_TIM3);

    GPIO_InitStruct.GPIO_Pin =  GPIO_Pin_6 | GPIO_Pin_7;
    GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF;
    GPIO_InitStruct.GPIO_OType = GPIO_OType_PP;
    GPIO_InitStruct.GPIO_Speed = GPIO_Speed_25MHz;
    GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_NOPULL;
    GPIO_Init(GPIOA, &GPIO_InitStruct);

 

  

转载于:https://www.cnblogs.com/longxi/p/10607547.html

### STM32F4 GPIO 头文件 `stm32f4xx_gpio.h` 使用说明 #### 功能定义概述 头文件 `stm32f4xx_gpio.h` 定义了用于配置和操作STM32F4系列微控制器上的通用输入/输出端口(GPIO)所需的数据结构、宏定义以及函数原型[^1]。 #### 主要数据结构 该头文件中声明了一个重要的枚举类型 `GPIOMode_TypeDef` 和多个结构体来描述GPIO的不同模式及其初始化参数。例如: ```c typedef enum { GPIO_Mode_IN = 0x00, /*!< GPIO Input Mode */ GPIO_Mode_OUT = 0x01, /*!< GPIO Output Mode */ GPIO_Mode_AF = 0x02, /*!< GPIO Alternate function Mode */ GPIO_Mode_AN = 0x03 /*!< GPIO Analog Mode */ } GPIOMode_TypeDef; ``` 这些枚举成员指定了不同的工作模式,允许开发者根据需求设置引脚功能[^1]。 #### 初始化结构体 为了简化外设的初始化过程,提供了如下所示的一个典型初始化结构体 `GPIO_InitTypeDef`: ```c typedef struct { uint16_t GPIO_Pin; /*!< Specifies the GPIO pins to be configured. This parameter can be any value of @ref GPIO_Pins */ GPIOMode_TypeDef GPIO_Mode; /*!< Specifies the operating mode for the selected pins. This parameter can be a value of @ref GPIOMode_TypeDef */ // ... 更多字段 ... } GPIO_InitTypeDef; ``` 此结构体包含了所有必要的属性以完成一次完整的GPIO配置,包括但不限于指定哪些具体引脚被影响(`GPIO_Pin`)以及它们的工作方式(`GPIO_Mode`)[^1]。 #### 常见API列表 除了上述提到的内容之外,还提供了一系列实用程序接口(APIs),使得能够轻松执行诸如读取状态、写入电平值等基本任务。部分常用的API列举如下: - **void GPIO_Init(GPIO_TypeDef\* GPIOx, GPIO_InitTypeDef\* GPIO_InitStruct)**: 根据给定的参数初始化特定的GPIO端口。 - **uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef\* GPIOx, uint16_t GPIO_Pin)**: 返回单个输入位的状态。 - **void GPIO_SetBits(GPIO_TypeDef\* GPIOx, uint16_t GPIO_Pin)**: 设置选定的一组或单一输出位为高电平。 - **void GPIO_ResetBits(GPIO_TypeDef\* GPIOx, uint16_t GPIO_Pin)**: 将选定的一组或单一输出位置低电平。 通过调用以上提供的API可以实现对硬件资源的有效控制并构建复杂的应用逻辑[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值