GPIO相关寄存器

本文详细介绍了STM32和HHD32F107VCH微控制器中GPIO(通用输入输出)的配置和操作。在STM32中,GPIO的配置涉及CRH和CRL寄存器来设置输入输出方向,BSRR和BRR寄存器用于置位和复位,LCKR寄存器用于锁定IO。而在HHD中,IOCON寄存器用于配置管脚功能,DIR寄存器控制输入输出,并提供了设置输出值和读取输入值的方法。此外,还展示了如何在HHD中启用IOCON的默认模式。

1. STM32的GPIO相关寄存器

GPIOx_BRR
GPIOx_BSRR
GPIOx_CRH
GPIOx_CRL
GPIOx_IDR
GPIOx_LCKR
GPIOx_ODR

1.1 输入输出方向的设置

涉及到两个32位的配置寄存器(Configuration Register),CRH,CRL。

GPIOB->CRL &= 0x0FFFFFFF;GPIOB->CRL|=0x30000000;//3<<28;//配置PB7为输出
GPIOB->CRL &= 0x0FFFFFFF;GPIOB->CRL|=0x80000000;//8<<28;//配置PB7为输入

GPIOB->CRH &= 0xFFFFFFF0;GPIOB->CRH|=3<<0; //配置PB8为输出
GPIOB->CRH &= 0xFFFFFFF0;GPIOB->CRH|=8<<0; //配置PB8为输入

CRH,CRL

    /* Check if the current bit belongs to first half or last half of the pin count number
       in order to address CRH or CRL register*/
      configregister = (iocurrent < GPIO_PIN_8) ? &GPIOx->CRL     : &GPIOx->CRH;
      registeroffset = (iocurrent < GPIO_PIN_8) ? (position << 2u) : ((position - 8u) << 2u);

      /* Apply the new configuration of the pin to the register */
      MODIFY_REG((*configregister), ((GPIO_CRL_MODE0 | GPIO_CRL_CNF0) << registeroffset), (config << registeroffset));

1.2 读取引脚高低电平值

涉及到两个32位数据寄存器(Data Register),IDR,ODR。

#define I2C_SDA_READ()  (GPIO_PORT_I2C->IDR & I2C_SDA_PIN)						// 读取SDA电平

IDR,ODR

void HAL_GPIO_TogglePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin)
{
  uint32_t odr = GPIOx->ODR;
  /* Set selected pins that were at low level, and reset ones that were high */
  GPIOx->BSRR = ((odr & GPIO_Pin) << GPIO_NUMBER) | (~odr & GPIO_Pin);
}

GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin)
{
  GPIO_PinState bitstatus;
  if ((GPIOx->IDR & GPIO_Pin) != (uint32_t)GPIO_PIN_RESET)
  {
    bitstatus = GPIO_PIN_SET;
  }
  else
  {
    bitstatus = GPIO_PIN_RESET;
  }
  return bitstatus;
}

1.3 置位和复位的设置

涉及到一个32位置位/复位寄存器(Bit Set/Reset Register),BSRR;一个32位复位寄存器(Bit Reset Register),BRR。

GPIOB->BSRR = GPIO_PIN_7;						// PB7 Set
GPIOB->BSRR = (uint32_t)GPIO_PIN_7<< 16U  		// PB7 Reset
GPIOB->BRR  = GPIO_PIN_7;                      // PB7 Reset

BSRR,BRR

void HAL_GPIO_WritePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState)
{
  if (PinState != GPIO_PIN_RESET)
  {
    GPIOx->BSRR = GPIO_Pin;
  }
  else
  {
    GPIOx->BSRR = (uint32_t)GPIO_Pin << 16u;
  }
}

1.4 锁定IO

TTL施密特触发器有开/关,相应的一个32位锁定寄存器(GPIOx_LCKR)可以控制开关让输入数据寄存器保持当前的状态,达到一个锁定的效果,在某些应用场合很有效果。
要使用该寄存器,需要先激活“锁定”功能。

LCKR

HAL_StatusTypeDef HAL_GPIO_LockPin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin)
{
  __IO uint32_t tmp = GPIO_LCKR_LCKK;
  /* Apply lock key write sequence */
  SET_BIT(tmp, GPIO_Pin);
  /* Set LCKx bit(s): LCKK='1' + LCK[15-0] */
  GPIOx->LCKR = tmp;
  /* Reset LCKx bit(s): LCKK='0' + LCK[15-0] */
  GPIOx->LCKR = GPIO_Pin;
  /* Set LCKx bit(s): LCKK='1' + LCK[15-0] */
  GPIOx->LCKR = tmp;
  /* Read LCKK register. This read is mandatory to complete key lock sequence */
  tmp = GPIOx->LCKR;

  /* read again in order to confirm lock is active */
  if ((uint32_t)(GPIOx->LCKR & GPIO_LCKR_LCKK))
  {
    return HAL_OK;
  }
  else
  {
    return HAL_ERROR;
  }
}

2. HHD

  • HHD32F107VCH 为每一个管脚设计了一个 IOCON 配置寄存器用于对管脚功能定义。
    IO

2.1 操作代码

2.1.1 输出
//引脚初始化,配置为输出
	IOCON->PE5.bit.FUNC = 0;             //默认IO功能 0
	IOCON->PE5.all |=  GPIO_Mode_DEF;
	GPIOE->DIR.all |= PIN5;             //输出       //GPIO_ConfigPinsAsOutput(GPIOE, PIN5);	
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE, ENABLE);//时钟
//操作,设置输出值
	GPIOE->SET.all |= PIN5;             //置位高电平 //GPIO_SetPin(GPIOE, PIN5);

2.1.2 输入
//引脚初始化,配置为输入
   IOCON->PE6.bit.FUNC = 0;
   IOCON->PE6.all |=  GPIO_Mode_DEF;
   GPIOE->DIR.all &= ~PIN6;             //输入     //GPIO_ConfigPinsAsInput

   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE, ENABLE);//时钟
//操作,读取输入值
  (GPIOE->PIN.all & PIN6);         //GPIO_GetPinState
  

2.2 其他操作

在使用IO进行一些特殊操作时,需要对IOCON寄存器进行一些特殊配置。

2.2.1 默认模式

GPIO_Mode_DEF = 0x00000230 //0010 0011 0000

  • 下拉电阻,关闭
  • 上拉电阻,使能
  • 施密特功能,关闭
  • 输入取反,关闭
  • 信号斜率,快速
  • 驱动能力,低
  • 开路模式,关闭(默认推拉)
  • 输入滤波,关闭
### 高通芯片中GPIO状态寄存器相关信息 在高通芯片的嵌入式开发环境中,GPIO(通用输入输出)的状态寄存器用于控制和监控引脚的行为。这些寄存器通常位于设备树中的特定节点下,例如 `platform/1000000.pinctrl` 表示的是与 GPIO 和 pin 控制相关的硬件抽象层配置[^1]。 #### 设备树中的 GPIO 节点定义 设备树文件中会定义 GPIO 的具体功能映射关系以及默认状态。例如,在高通平台上,可以通过如下方式初始化并设置 GPIO 的工作模式: ```c struct pinctrl *pinctrl = devm_pinctrl_get(device); if (IS_ERR(pinctrl)) { pr_err("Failed to get pinctrl\n"); } struct pinctrl_state *state = pinctrl_lookup_state(pinctrl, "gpio_active"); if (IS_ERR(state)) { pr_err("Failed to lookup state gpio_active\n"); } int ret = pinctrl_select_state(pinctrl, state); if (ret < 0) { pr_err("Failed to select state gpio_active\n"); } devm_pinctrl_put(pinctrl); ``` 上述代码片段展示了如何通过 Linux 内核接口获取、查询和切换 GPIO 的状态[^3]。这一步骤对于正确配置 GPIO 寄存器至关重要。 #### GPIO 状态寄存器的功能描述 GPIO 状态寄存器主要用于以下几个方面: - **方向控制**:决定某个引脚是作为输入还是输出。 - **电平检测**:读取当前引脚上的逻辑电平值。 - **中断触发条件**:设定哪些事件可以触发中断请求。 - **上拉/下拉电阻配置**:启用或禁用内部上拉或下拉电阻。 具体的寄存器地址及其位字段含义可以在高通官方发布的数据手册和技术参考资料中找到。例如,某些型号可能提供专门章节来解释 SPMI 或 PMIC 中涉及的 GPIO 控制机制。 #### 错误处理案例分析 当尝试分配指定编号的 GPIO 引脚失败时,Linux 内核日志可能会打印错误消息:“request GPIO %d for LED failed, ret = %d”。这种情况下需要检查是否存在冲突或者权限不足等问题[^2]。 ### 总结 为了深入理解高通芯片内的 GPIO 状态寄存器运作原理,建议查阅对应的硬件规格书,并结合实际项目需求编写相应的驱动程序实现精确操控。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值