linux下的gpio转串口驱动,X-026-KERNEL-Linux gpio driver的移植之gpio range

X-026-KERNEL-Linux gpio driver的移植之gpio range

作者:wowo 发布于:2017-9-27 22:27

分类:X Project

1. 前言

我们在[1][2]中提到过,鉴于gpio的特殊性,pinctrl subsystem特意留了一个后门(gpio range),gpio driver可以通过这个后门直接向pinctrl subsystem申请将某个pin用作gpio功能。本文将根据一个简单的示例,介绍这个后门的使用方法,以加深对相关机制的理解。

注1:本文的测试方法和[3]中的一致,即:通过gpiolib sysfs api控制LED0(GPIOA19)的亮灭,因而不再罗列详细步骤。

2. 移植步骤

由[2]可知,gpio range的主要目的就是将gpio命名空间(gpio)转换为pinctrl命名空间(pin),并由pinctrl subsystem访问硬件实现gpio有关的功能控制。因此gpio range的移植步骤注要包括:

2.1 pinctrl命名空间和gpio命名空间的定义

参考”X-025-KERNEL-Linux gpio driver的移植之基本功能[3]”中有关gpiochip的实现,本例中的GPIOA19的gpio命名空间为:

gpiochip:gpioa

编号:19

同理,按照“X-023-KERNEL-Linux pinctrl driver的移植[4]”中的方法,结合bubblegum-96的原理图,我们可以把GPIOA19所在的管脚编号为"F3",它对应的pinctrl命名空间为:

pin controller:pinctrl@0xe01b0000

编号:52

@@ -68,6 +68,7 @@ static const struct pinctrl_pin_desc s900_pins[] = {

PINCTRL_PIN(15, "B6"),

PINCTRL_PIN(24, "C5"),

PINCTRL_PIN(37, "D8"),

+       PINCTRL_PIN(52, "F3"),

PINCTRL_PIN(60, "G1"),

PINCTRL_PIN(61, "G2"),

};

2.2 将gpio number转换为pin number

命名空间定义完成后,可以按照[2]中的步骤,在dts中定义一个gpio range,将gpio number转换为pin number,如下:

@@ -39,7 +39,7 @@

clock-frequency = <24000000>;

};

-       pinctrl@0xe01b0000 {

+       pinctrl1: pinctrl@0xe01b0000 {

compatible = "actions,s900-pinctrl";

reg = <0 0="" 0xe01b0000="" 0x550="">;

@@ -56,6 +56,7 @@

gpioa: gpio@0xe01b0000 {

compatible = "actions,s900-gpio";

reg = <0 0="" 12="" 0xe01b0000="">;

base = <0>;

+               gpio-ranges = ;

};

其中黄色背景那一行的含义是:将gpioa中的19号gpio,和pinctrl1中的52号pin,对应。

2.3 修改gpio driver和pinctrl driver,二者配合,完成gpio的request、free、direction_input以及direction_output等操作

1)修改pinctrl driver,实现pinmux_ops中gpio_request_enable、gpio_disable_free、gpio_set_direction等回调函数

这三个API的输入参数都是range指针和offset(如下所示),通过它们可以找到这个GPIO所在的gpiochip、GPIO bank、GPIO number、对应pin所在的pin controller、pin number等信息。基于这些信息,可以获得相应的硬件信息(寄存器、bit偏移等)。

int (*gpio_request_enable) (struct pinctrl_dev *pctldev,

struct pinctrl_gpio_range *range,

unsigned offset);

void (*gpio_disable_free) (struct pinctrl_dev *pctldev,

struct pinctrl_gpio_range *range,

unsigned offset);

int (*gpio_set_direction) (struct pinctrl_dev *pctldev,

struct pinctrl_gpio_range *range,

unsigned offset,

bool input);

2)修改gpio chip的.request、.free、.direction_input、.direction_output等回调函数,让它们调用pinctrl subsystem提供的相关API,如下:

int pinctrl_request_gpio(unsigned gpio) ;

void pinctrl_free_gpio(unsigned gpio) ;

int pinctrl_gpio_direction_input(unsigned gpio);

int pinctrl_gpio_direction_output(unsigned gpio);

注2:有些硬件平台,在完成上面步骤1)的时候,可能会遇到一些困扰,例如怎么根据gpio和pin的信息,找到对应的硬件控制信息(寄存器、bit偏移等),这时我们可以灵活处理。例如在本文例子所使用的bubblegum-96平台上,gpio的pinmux功能并没有单独的寄存器控制,而是通过gpio的in或者out功能的使能,覆盖其它的pinmux功能。此时我们可以把硬件配置的操作交给gpio driver,而pinctrl driver只处理管脚的互斥。具体可参考下面patch的改动。

3. 测试步骤

请参考[3]中的测试。测试结果如下(看到s900_gpio_request_enable中的打印,就说明我们的移植成功了):

/ # mkdir /sys

/ # mount -t sysfs /sys /sys

/ # echo 19 > /sys/class/gpio/export

[   55.136218] owl_pinctrl e01b0000.pinctrl: s900_gpio_request_enable, range(19/52/1), offset 52

/ # echo out > /sys/class/gpio/gpio19/direction

[   86.886343] owl_gpio e01b0000.gpio: offset 19, value 0

/ # echo 1 > /sys/class/gpio/gpio19/value

[  100.223812] owl_gpio e01b0000.gpio: offset 19, value 1

/ # echo 0 > /sys/class/gpio/gpio19/value

[  120.467468] owl_gpio e01b0000.gpio: offset 19, value 0

4. 参考文档

[5] Schematics_Bubblegum96.pdf

原创文章,转发请注明出处。蜗窝科技,www.wowotech.net。c6a6308114f401be7df747ae46f2b4db.png

评论:

bigpillow

2017-11-10 10:54

刚写完一套GPIO driver.

当时考虑到不同chip通用性使用了gpiochip_add_pin_range function

现在看看在DTS里面原来这么方便。

发表评论:

昵称

邮件地址 (选填)

个人主页 (选填)

d4e3789769c8ad44c7e403863bfc3822.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/488309.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

长文综述:从大数据中寻找复杂系统的核心变量

文章来源&#xff1a;【集智俱乐部】原文链接&#xff1a;https://mp.weixin.qq.com/s/IIliI5plz2UBUMAzVpxClw导语尽管大数据的收集越来越容易&#xff0c;但随着从微观到宏观的尺度&#xff08;scale&#xff09;变化&#xff0c;系统行为会发生非线性的变化&#xff0c;这让…

android设置主题背景为壁纸_ppt模板防早恋安全教育主题班会课件ppt,两个青春期的孩子画面为背景...

ppt模板--防早恋安全教育主题班会课件ppt这是一套防早恋安全教育主题班会课件ppt&#xff0c;共26页。PPT封面以简约的白色背景&#xff0c;五彩斑斓的地面象征孩子们丰富多彩的学生生活&#xff0c;两个青春期的孩子画面为背景&#xff0c;蓝色正体字突出主题&#xff1a;防早…

Linux下启动程序常见问题,linux系统启动流程及常见故障解决方式

Linux系统中启动的流程:1.加载bios的硬件信息以及进行自我检测 并根据设置取得第一个启动的设备2.若以硬盘方式引导 读取并执行引导扇区 MBR3.加载grub(引导程序)启动菜单(/\)4.加载内核(以只读方式进行挂载)5.挂载根目录系统 启动init进程(所有进程的鼻祖)6.读取/etc/initt…

javascript如何处理很多数据,类似分页切换

需求&#xff1a;一个用户列表数据&#xff0c;如果对应列表数据大于10个&#xff0c;就每10个保存到二维数组&#xff0c;后面不足10个的依然放在二维数组尾部 用处&#xff1a;模拟分页&#xff0c;或者局部刷新 在线DEMO&#xff1a;戳这里 var obj[{"list":[{a:1…

vscode红色波浪不见了_vscode c++ 编译可以通过 但是有红色波浪线的问题

作者&#xff1a;送外卖转行计算机来源&#xff1a;SegmentFault 思否1.command p, 然后输入 >C/C选择 编辑配置(JSON)然后在工作区会出现一个.vscode文件夹, 其中会有一个.json文件的配置2.打开命令行 输入gcc -v -E -x c -会有以下的信息 ignoring nonexistent director…

云计算军事运用有啥特点

来源&#xff1a;军语研究院云计算技术被视为继大型计算机、个人计算机、互联网之后的第四次信息技术产业革命。云计算是一种围绕分布式共享计算资源的创新应用模式&#xff0c;资源提供者可以方便而快速地提供计算资源&#xff0c;而无处不在的资源需求者可以便利地使用共享的…

基于STM32的DS1302实时时钟模块应用

DS1302是一款低功耗的实时时钟芯片&#xff0c;被广泛应用于各种电子产品中。它具有准确计时、多种时间格式表示、定时报警等功能&#xff0c;适用于记录时间、日期和闹钟。在本文中&#xff0c;我们将介绍如何在基于STM32的开发环境中使用DS1302实时时钟模块&#xff0c;并给出…

内存屏障linux,Linux内存屏障

简介现代处理器在执行指令时&#xff0c;使用多种技术&#xff0c;提高指令的执行效率&#xff0c;例如多级cache&#xff0c;流水线&#xff0c;多发射&#xff0c;乱序执行等。这些技术的引入&#xff0c;导致对主存的访问顺序并不一定是编码时的顺序&#xff0c;也就是说&am…

在Windows 7上安装Team Foundation Server(TFS)的代理服务器(Agent)

自2009年微软发布Windows 7以来&#xff0c;经过8年的市场验证&#xff0c;Windows 7已经成为史上应用最为广泛的操作系统。但是面对技术变化的日新月异&#xff0c;2015年微软正式停止了对Windows 7的主流支持&#xff0c;并将于2020年正式结束对Windows 7的所有技术支持。这一…

python中的魔法方法__new___python魔法方法,详解__new__()和__init__()

魔法方法__new__()和__init__()真是困扰了我好久。其实就是对__new__()一直不是很理解。今天做一个小小的总结吧&#xff0c;在这个知识点上真是花了太久的时间了。首先回顾一下类与对象python中一切皆为对象&#xff0c;python类本身也是一种对象&#xff0c;我们可以称其为类…

王喜文:图解新基建,细说新机遇(100图)

来源&#xff1a;智造智库去年8月22日&#xff0c;华为创始人任正非签发总裁办邮件&#xff0c;大力推荐技术大神王喜文博士的5G科普PPT《认识5G&#xff0c;发展5G》&#xff0c;并报送董事会成员、监事会成员&#xff0c;主送全体员工&#xff0c;要求华为全员学习。任正非的…

基于OpenGL编写一个简易的2D渲染框架-07 鼠标事件和键盘事件

这次为程序添加鼠标事件和键盘事件 当检测到鼠标事件和键盘事件的信息时&#xff0c;捕获其信息并将信息传送到需要信息的对象处理。为此&#xff0c;需要一个可以分派信息的对象&#xff0c;这个对象能够正确的把信息交到正确的对象。 实现思路&#xff1a; 要实现以上的功能&…

重新定义Wi-Fi功能,Wi-Fi 6为什么要分两步?

来源&#xff1a;传感器技术Wi-Fi 6重新定义Wi-Fi&#xff0c;先是双频并发&#xff0c;然后才是6GHz下的160MHz。Wi-Fi是什么&#xff1f;它是一个基于IEEE 802.11标准的无线局域网技术。如今&#xff0c;Wi-Fi已经覆盖了绝大部分的室内场景&#xff0c;你的手机、电脑、智能音…

python爬虫系统实验报告问题的分析_Python爬虫总结——常见的报错、问题及解决方案...

在爬虫开发时&#xff0c;我们时常会遇到各种BUG各种问题&#xff0c;下面是我初步汇总的一些报错和解决方案。在以后的学习中&#xff0c;如果遇到其他问题&#xff0c;我也会在这里进行更新。各位如有什么补充&#xff0c;欢迎评论区留言~~~问题&#xff1a;IP被封&#xff0…

linux qt检测u盘热插拔,【QT】动态监测U盘插拔

前言在项目中&#xff0c;遇到一个需求&#xff1a;需要动态监测U盘插入&#xff0c;自动读取U盘文件并打开。为了实现这个功能&#xff0c;我们可以使用RegisterDeviceNotification注册设备事件的通知&#xff0c;然后在程序中处理WM_DEVICECHANGE消息来实现步骤RegisterDevic…

童年乐趣

每个人在童年的时候&#xff0c;都无比天真~那时候的我们感情丰富&#xff0c;热血无敌&#xff0c;想跟着四驱兄弟去赛车&#xff1b;想陪着海尔兄弟去冒险&#xff1b;会在孙悟空被误会时流下热泪&#xff1b;也会在哪吒被冤枉时义愤填膺…… 虽然现在看起来有点智障&#xf…

《科学》:中德解析新冠主要蛋白酶晶体结构,有助抑制剂研发

来源&#xff1a;澎湃新闻自新型冠状病毒引起的疫情暴发以来&#xff0c;科学家们一直在努力寻找有效的病毒抑制剂。当地时间3月20日&#xff0c;顶级学术期刊《科学》在线发表了一篇题为“Crystal structure of SARS-CoV-2 main protease provides a basis for design of impr…

render_notebook()结果没有图_来自百度的良心产品!百度iOS截长图App

我们知道百度是国内最大的搜索引擎&#xff0c;但你知道它也会出品一些和搜索无关的精品工具&#xff1f;例如在最近&#xff0c;百度就推出了一款iOS平台上的滚动截长图App&#xff0c;要知道iOS系统一直以来就不支持系统级别的截长图&#xff0c;百度这工具可谓是非常实用了&…

linux emmc vfs错误,Hi3519a EMMC挂载EXT4文件系统失败

环境&#xff1a;hi3519AV100 Hi3519A V100R001C02SPC010问题&#xff1a;使用Hitool5.0.46烧写EMMC&#xff0c;成功烧写uboot、Image和EXT4文件系统&#xff0c;uboot和内核都可以正常启动&#xff0c;报错加载不了文件系统参考文档启动参数设置如下&#xff1a;setenv boota…

2017前端资源汇总

来源于:https://zhuanlan.zhihu.com/p/25229274 Any software that can be written in JavaScript will eventually be written in JavaScript. 下面的项目都列出了github的星数和npmjs上最近一个月的下载数例如 github 106.5k/stars npmjs 93.3k/lm 指有10万6千个github星&…