news 2026/4/16 4:30:01

外设与接口:按键输入 (libgpiod)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
外设与接口:按键输入 (libgpiod)

1 API 介绍

以下是处理 GPIO 中断事件的核心 API。

1.1 事件请求与监听
intgpiod_line_request_both_edges_events(structgpiod_line*line,constchar*consumer);
  • 参数
    • linegpiod_line对象指针。
    • consumer:消费者名称(如"button-listener")。
  • 作用:将引脚配置为输入模式,同时监听 上升沿(Rising Edge)和 下降沿(Falling Edge)。
  • 返回:成功返回0,失败返回-1
1.2 等待事件(阻塞)
intgpiod_line_event_wait(structgpiod_line*line,conststructtimespec*timeout);
  • 参数
    • line:已请求事件的gpiod_line对象指针。
    • timeout:超时时间。传NULL表示无限等待(直到事件发生才唤醒,CPU 占用率为 0)。
  • 作用:阻塞当前进程,等待中断事件。这是实现低功耗按键检测的核心。
  • 返回0表示超时,1表示有事件发生,-1表示发生错误。
1.3 读取事件详情

事件数据结构

structgpiod_line_event{structtimespects;// 事件发生的时间戳(纳秒级精度)intevent_type;// 事件类型};
  • event_type 常用值
    • GPIOD_LINE_EVENT_RISING_EDGE:上升沿。
    • GPIOD_LINE_EVENT_FALLING_EDGE:下降沿。
intgpiod_line_event_read(structgpiod_line*line,structgpiod_line_event*event);
  • 参数
    • linegpiod_line对象指针。
    • event:指向struct gpiod_line_event的指针,用于接收事件数据。
  • 返回:成功返回0,失败返回-1

2 两种实现方案

2.1 轮询模式

代码如下:

#include<gpiod.h>#include<stdio.h>#include<time.h>// for nanosleep#defineCHIP_NAME"gpiochip3"#defineLINE_OFFSET5// GPIO3_A5#defineDEBOUNCE_MS20// 消抖时间窗口// 辅助函数:毫秒级延时voidmsleep(longms){structtimespects={.tv_sec=ms/1000,.tv_nsec=(ms%1000)*1000000};nanosleep(&ts,NULL);}intmain(){structgpiod_chip*chip=gpiod_chip_open_by_name(CHIP_NAME);structgpiod_line*line=gpiod_chip_get_line(chip,LINE_OFFSET);intval,last_val=1;// 假设初始状态为高(松开)// 1. 仅配置为输入模式 (不使用中断)if(gpiod_line_request_input(line,"debounce-worker")<0){perror("Request input failed");return-1;}while(1){// 2. 主动轮询当前值val=gpiod_line_get_value(line);// 3. 发现电平变化if(val!=last_val){// 4. 暂停 20ms,让信号飞一会儿(过滤噪声)msleep(DEBOUNCE_MS);// 5. 再次读取进行确认 (Double Check)intstable_val=gpiod_line_get_value(line);if(stable_val==val){// 如果20ms后电平依然没变,认为是有效按键if(stable_val==0)printf(">>> Button PRESSED (Stable)\n");elseprintf(" Button RELEASED (Stable)\n");last_val=stable_val;// 更新状态机}}// 6. 降低轮询频率,保护 CPU (至关重要)msleep(10);}gpiod_line_release(line);gpiod_chip_close(chip);return0;}
2.1 中断模式

利用内核中断机制,程序不需要时刻盯着引脚,而是挂起等待内核唤醒。

代码如下 :

#include<gpiod.h>#include<stdio.h>#include<stdlib.h>// for system()#defineCHIP_NAME"gpiochip0"#defineLINE_OFFSET14// GPIO0_B6 (Group 1 * 8 + 6 = 14)intmain(){structgpiod_chip*chip;structgpiod_line*line;structgpiod_line_eventevent;// 1. 基础初始化chip=gpiod_chip_open_by_name(CHIP_NAME);line=gpiod_chip_get_line(chip,LINE_OFFSET);// 2. 请求监测双边沿事件 (关键 API)if(gpiod_line_request_both_edges_events(line,"button-listener")<0){perror("Request events failed");return-1;}printf("Waiting for events on %s line %d...\n",CHIP_NAME,LINE_OFFSET);while(1){// 3. 阻塞等待事件,无超时 (NULL),CPU 占用 0%if(gpiod_line_event_wait(line,NULL)>0){// 4. 读取具体事件gpiod_line_event_read(line,&event);// 5. 区分按下还是松开if(event.event_type==GPIOD_LINE_EVENT_FALLING_EDGE){printf("[Timestamp: %ld] Button PRESSED\n",event.ts.tv_sec);// 业务逻辑:例如 system("/usr/bin/restart_app.sh &");}else{printf("[Timestamp: %ld] Button RELEASED\n",event.ts.tv_sec);}}}gpiod_line_release(line);gpiod_chip_close(chip);return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 10:46:43

飞书文档批量处理终极方案:700文档25分钟自动化导出

飞书文档批量处理终极方案&#xff1a;700文档25分钟自动化导出 【免费下载链接】feishu-doc-export 项目地址: https://gitcode.com/gh_mirrors/fe/feishu-doc-export 在当今数字化办公环境中&#xff0c;文档批量处理已成为企业迁移和备份的常见需求。feishu-doc-exp…

作者头像 李华
网站建设 2026/4/16 10:42:29

微信小程序大文件上传技术深度解析与实战指南

微信小程序大文件上传技术深度解析与实战指南 【免费下载链接】miniprogram-file-uploader 项目地址: https://gitcode.com/gh_mirrors/mi/miniprogram-file-uploader 在移动应用开发领域&#xff0c;微信小程序凭借其轻量级、易传播的特点已成为企业数字化转型的重要载…

作者头像 李华
网站建设 2026/4/15 20:30:54

高效视频下载工具yt-dlp-gui深度解析与实战指南

在多媒体内容爆炸式增长的时代&#xff0c;如何快速获取优质视频资源成为众多用户关注的重点。yt-dlp-gui作为一款基于知名命令行工具yt-dlp开发的图形界面应用程序&#xff0c;为Windows平台用户带来了直观便捷的视频下载体验。本文将从技术架构、功能特性到实际操作进行全面剖…

作者头像 李华
网站建设 2026/4/16 14:00:23

终极网盘直链解析:一键解锁高速下载新体验

还在为网盘下载速度慢而烦恼吗&#xff1f;LinkSwift网盘直链解析工具是你的终极解决方案&#xff01;这款基于JavaScript开发的神器能够轻松获取百度网盘、阿里云盘、天翼云盘、迅雷云盘、夸克网盘、移动云盘等八大主流平台的真实下载地址&#xff0c;让你彻底告别网盘限速和繁…

作者头像 李华
网站建设 2026/4/16 10:40:47

终极指南:5分钟学会用stl-thumb实现STL文件快速预览

终极指南&#xff1a;5分钟学会用stl-thumb实现STL文件快速预览 【免费下载链接】stl-thumb Thumbnail generator for STL files 项目地址: https://gitcode.com/gh_mirrors/st/stl-thumb 在3D打印和CAD设计工作中&#xff0c;STL文件预览一直是个令人头疼的问题。传统的…

作者头像 李华