GPIO端口引脚(位域)打包技巧笔记

1. 结构体定义:位域打包

c

复制代码
typedef struct
{
    uint8_t num:4,   /*!< 引脚号 (0~15) */
            port:4;  /*!< 端口号 (0~15) */
} gpio_port_pin_t;
  • 使用位域将两个4位信息压缩到一个字节中。
  • 内存布局:低位4位存放 num,高位4位存放 port(取决于编译器,通常如此)。
  • 结构体大小 = 1字节。

2. 典型用法:从 uint8_t 解析出端口和引脚

c

复制代码
void gpio_ana_func1_init(uint8_t pin)
{
    // 将 pin 的地址强制转换为结构体指针
    gpio_port_pin_t *x = (gpio_port_pin_t *)&pin;

    // 使用 x->port 和 x->num 访问对应字段
    SYSC_AWO->IO[x->port].AE |= 1 << (16 + x->num);
}

关键点

  • &pin 取得变量 pin 的地址(uint8_t*)。
  • 强制转换为 gpio_port_pin_t*,将同一个字节重新解释为结构体。
  • 之后通过 x->portx->num 即可获得编码时存入的高4位和低4位。

3. 调用约定

通常调用者将端口和引脚编码为一个字节:

c

复制代码
// 假设端口=2, 引脚=5 → 编码为 (2<<4) | 5 = 0x25
gpio_ana_func1_init(0x25);

函数内部通过上述转换自然拆解出 port=2, num=5

4. 注意事项

  • 必须使用 **&**取地址(gpio_port_pin_t *)pin 是错误的,它会将 pin 的数值当作内存地址,导致非法访问。
  • 内存布局一致性:位域的内存分布可能因编译器而异,但在大多数嵌入式环境中此用法稳定。
  • 对齐安全uint8_t 与结构体大小均为1字节,对齐无问题。
  • 此技巧适用于函数内临时解析,不应用于长期存储或跨模块传递。

5. 优点

  • 代码简洁,无需手动移位和掩码。
  • 提高可读性,直接使用 x->portx->num 表达意图。
相关推荐
ElfBoard2 小时前
飞凌精灵(ElfBoard)技术贴|如何在RK3506开发板上实现UART功能复用
大数据·linux·人工智能·驱动开发·单片机·嵌入式硬件·物联网
踏着七彩祥云的小丑3 小时前
嵌入式——认识电子元器件——二极管系列
单片机·嵌入式硬件
Jack_02203 小时前
基于51单片机的智能电动窗帘控制OLED显示设计
单片机·嵌入式硬件·51单片机·智能家居·oled显示·电动窗帘
摘星台3 小时前
linux环境对stm32单片机进行程序烧录
linux·stm32·单片机
森G4 小时前
STM32F103C8T6工程---标准库版usart2写回显
stm32·单片机
EVERSPIN5 小时前
基于MCU CH32X035 Type-C PD显示器方案
单片机·mcu·计算机外设
Z文的博客6 小时前
FLASHDB实战详解 - 嵌入式KV/TSD数据库开发全攻略
stm32·单片机·嵌入式·flash·flashdb·w25q256
SUNNYSPY0016 小时前
120R016-ASEMI解锁电力电子的效率革命
单片机
芯希望6 小时前
芯伯乐XOPA340/XOPA2340/XOPA4340系列11MHz低噪声CMOS运放,高性能与低功耗的理想平衡
单片机·嵌入式硬件·dc-dc·工业控制·国产替代·电源管理·xblw芯伯乐
LCMICRO-133108477466 小时前
长芯微LCMDC8588完全P2P替代ADS8588,是一款16位、8通道同步采样的逐次逼近型(SAR)模数转换器
stm32·单片机·嵌入式硬件·fpga开发·硬件工程·模数转换器