【转】Linux內核驅動之GPIO子系統(一)GPIO的使用 _蝸牛
原文网址:http://tc.chinawin.net/it/os/article-2512b.html
一 概述
Linux內核中gpio是最簡單,最常用的資源(和interrupt ,dma,timer一樣)驅動程序,應用程序都能夠通過相應的接口使用gpio,gpio使用0~MAX_INT之間的整數標識,不能使用負數,gpio與硬件體系密切相關的,不過linux有一個框架處理gpio,能夠使用統一的接口來操作gpio.在講gpio核心(gpiolib.c)之前先來看看gpio是怎麼使用的
二 內核中gpio的使用
1測試gpio端口是否合法int gpio_is_valid(int number);
2申請某個gpio端口當然在申請之前需要顯示的配置該gpio端口的pinmux
int gpio_request(unsigned gpio, const char *label)
3標記gpio的使用方向包括輸入還是輸出
/*成功返回零失敗返回負的錯誤值*/
int gpio_direction_input(unsigned gpio);
int gpio_direction_output(unsigned gpio, int value);
4獲得gpio引腳的值和設置gpio引腳的值(對於輸出)
int gpio_get_value(unsigned gpio);
void gpio_set_value(unsigned gpio, int value);
5 gpio當作中斷口使用
int gpio_to_irq(unsigned gpio);
返回的值即中斷編號可以傳給request_irq()和free_irq()
內核通過調用該函數將gpio端口轉換爲中斷,在用戶空間也有類似方法
6導出gpio端口到用戶空間
int gpio_export(unsigned gpio, bool direction_may_change);
內核可以對已經被gpio_request()申請的gpio端口的導出進行明確的管理,
參數direction_may_change表示用戶程序是否允許修改gpio的方向,假如可以
則參數direction_may_change爲真
void gpio_unexport();
三 用戶空間gpio的調用
用戶空間訪問gpio,即通過sysfs接口訪問gpio,下面是/sys/class/gpio目錄下的三種文件:
--export/unexport文件
--gpioN指代具體的gpio引腳
--gpio_chipN指代gpio控制器
必須知道以上接口沒有標準device文件和它們的鏈接。
(1) export/unexport文件接口:
/sys/class/gpio/export,該接口只能寫不能讀
用戶程序通過寫入gpio的編號來向內核申請將某個gpio的控制權導出到用戶空間當然前提是沒有內核代碼申請這個gpio端口
比如 echo 19 > export
上述操作會爲19號gpio創建一個節點gpio19,此時/sys/class/gpio目錄下邊生成一個gpio19的目錄
/sys/class/gpio/unexport和導出的效果相反。
比如 echo 19 > unexport
上述操作將會移除gpio19這個節點。
(2) /sys/class/gpio/gpioN
指代某個具體的gpio端口,裏邊有如下屬性文件
direction 表示gpio端口的方向,讀取結果是in或out。該文件也可以寫,寫入out時該gpio設爲輸出同時電平默認爲低。寫入low或high則不僅可以
設置爲輸出還可以設置輸出的電平。 當然如果內核不支持或者內核代碼不願意,將不會存在這個屬性,比如內核調用了gpio_export(N,0)就
表示內核不願意修改gpio端口方向屬性
value表示gpio引腳的電平,0(低電平)1(高電平),如果gpio被配置爲輸出,這個值是可寫的,記住任何非零的值都將輸出高電平, 如果某個引腳
能並且已經被配置爲中斷,則可以調用poll(2)函數監聽該中斷,中斷觸發後poll(2)函數就會返回。
edge 表示中斷的觸發方式,edge文件有如下四個值:"none", "rising", "falling","both"。
none表示引腳爲輸入,不是中斷引腳
rising表示引腳爲中斷輸入,上升沿觸發
falling表示引腳爲中斷輸入,下降沿觸發
both表示引腳爲中斷輸入,邊沿觸發
這個文件節點只有在引腳被配置爲輸入引腳的時候才存在。 當值是none時可以通過如下方法將變爲中斷引腳
echo "both" > edge;對於是both,falling還是rising依賴具體硬件的中斷的觸發方式。此方法即用戶態gpio轉換爲中斷引腳的方式
active_low不怎麼明白,也木有用過
(3)/sys/class/gpio/gpiochipN
gpiochipN表示的就是一個gpio_chip,用來管理和控制一組gpio端口的控制器,該目錄下存在一下屬性文件:
base和N相同,表示控制器管理的最小的端口編號。
lable診斷使用的標誌(並不總是唯一的)
ngpio 表示控制器管理的gpio端口數量(端口範圍是:N ~ N+ngpio-1)
四 用戶態使用gpio監聽中斷
首先需要將該gpio配置爲中斷
echo "rising" > /sys/class/gpio/gpio12/edge
以下是僞代碼
int gpio_id;
struct pollfd fds[1];
gpio_fd = open("/sys/class/gpio/gpio12/value",O_RDONLY);
if( gpio_fd == -1 )
err_print("gpio open");
fds[0].fd = gpio_fd;
fds[0].events = POLLPRI;
ret = read(gpio_fd,buff,10);
if( ret == -1 )
err_print("read");
while(1){
ret = poll(fds,1,-1);
if( ret == -1 )
err_print("poll");
if( fds[0].revents & POLLPRI){
ret = lseek(gpio_fd,0,SEEK_SET);
if( ret == -1 )
err_print("lseek");
ret = read(gpio_fd,buff,10);
if( ret == -1 )
err_print("read");
...............
記住使用poll()函數,設置事件監聽類型爲POLLPRI和POLLERR在poll()返回後,使用lseek()移動到文件開頭讀取新的值或者關閉它再重新打開讀取新值。必須這樣做否則poll函數會總是返回。
【转】Linux內核驅動之GPIO子系統(一)GPIO的使用 _蝸牛的更多相关文章
- 第一章 Linux內核簡介
1. Linux是類Unix系統,但他不是Unix. 儘管Linux借鑑了Unix的許多設計並且實現了Unix的API(由Posix標準和其他Single Unix Specification定義的) ...
- Linux內核中常用的一些延時方法
Linux內核中常用的一些延時方法 這些方法在以下路徑下定義:kernel/include/linux/delay.h #ifndef _LINUX_DELAY_H #define _LINUX_DE ...
- Linux驱动之GPIO子系统和pinctrl子系统
前期知识 1.如何编写一个简单的Linux驱动(一)--驱动的基本框架 2.如何编写一个简单的Linux驱动(二)--设备操作集file_operations 3.如何编写一个简单的Lin ...
- gpio子系统和pinctrl子系统(上)
前言 随着内核的发展,linux驱动框架在不断的变化.很早很早以前,出现了gpio子系统,后来又出现了pinctrl子系统.在网上很难看到一篇讲解这类子系统的文章.就拿gpio操作来说吧,很多时候都是 ...
- gpio子系统和pinctrl子系统(下)
情景分析 打算从两个角度来情景分析,先从bsp驱动工程师的角度,然后是驱动工程师的角度,下面以三星s3c6410 Pinctrl-samsung.c为例看看pinctrl输入参数的初始化过程(最开始的 ...
- linux內核輸出soft lockup
創建的內核線程長期佔用cpu,一直內核認為線程soft lockup,如無法獲取自旋鎖等:因此線程可適度調用schdule(),以進行進程的調度:因為kwatchdog的執行級別低,一直得不到執行 [ ...
- CVE-2016-8655,af_packet Linux 內核通殺提權漏洞淺析
簡單寫一下思路 這個東西需要namespace方面的支援, 首先open socket , 一連串路徑(packet_set_ring()->init_prb_bdqc()->prb_se ...
- gpio子系统和pinctrl子系统(中)
pinctrl子系统核心实现分析 pinctrl子系统的内容在drivers/pinctrl文件夹下,主要文件有(建议先看看pinctrl内核文档Documentation/pinctrl.txt): ...
- 基於tiny4412的Linux內核移植--- 中斷和GPIO學習(1)
作者 彭東林 pengdonglin137@163.com 平臺 tiny4412 ADK Linux-4.4.4 u-boot使用的U-Boot 2010.12,是友善自帶的,爲支持設備樹和uIma ...
随机推荐
- Design Tic-Tac-Toe 解答
Question Design a Tic-tac-toe game that is played between two players on a n x n grid. You may assum ...
- 素数与素性测试(Miller-Rabin测试)
转载自Matrix大牛的博客 把代码翻译成C++ http://www.matrix67.com/blog/archives/234 题目链接: http://hihocoder.com/proble ...
- sql列转行
1.需要实现一个单行的统计报表 思路先用一个union查出单列,然后再把单列转成单行 2.实现 SELECT MAX(CASE WHEN type = 1 THEN num ELSE 0 END) A ...
- 详解C++ friend关键字
1. 为什么要使用友元? 通常对于普通函数来说,要访问类的保护成员是不可能的,如果想这么做那么必须把类的成员都生命成为 public( 共用的) ,然而这做带来的问题遍是任何外部函数都可以毫无约束的访 ...
- DataTables 配置和使用
WEB后台开发,如果用的是Bootstrap框架,那这个表格神器你一定不要错过. 官方地址:https://datatables.net/ What?英文不好,没关系咱有中文的 http://data ...
- WPF控件---Border应用
内容模型:Border 只能具有一个子元素.若要显示多个子元素, 需要将一个容器元素放置在父元素Border中. <Grid> <Border BorderBrush="B ...
- new的原理
先来个构造函数的例子: function Prince(name,age){ this.name=name; this.age=age; } var prince=new Prince("c ...
- (转)ASP.NET 伪静态
1.伪静态:http://www.cnblogs.com/Default.html 目的就是为了赢得更多的收入,至于真否,待SEOer 解答,正如文字所说,伪静态就是假的静态. 2.准备工作:下载Ur ...
- ADB命令与monkey
adb devices查看已连接的设备 adb install package.apk adb shell monkey 1000 随机操作1000次当次操作可能会 adb无法使用,提示error: ...
- channel c3 disabled, job failed on it will be run on another channel
今天执行备份时,报错: allocated channel: c3 channel c3: sid=131 instance=orcl2 devtype=DISK RMAN-03009: fail ...