imx6设备树pinctrl解析【转】

转自:http://blog.csdn.net/michaelcao1980/article/details/50730421

版权声明:本文为博主原创文章,未经博主允许不得转载。

最近在移植linux,用到kernel版本为3.14.28,在高版本的内核源码中用到了设备树(device-tree),设备树中用到pinctrl的配置,记录一下。

1、普通设置

在配置串口时,pinctrl的配置信息如下所示:

 

 

&uart2 {  

  •     pinctrl-names = ;  
  • ;  
  • //。。。。。。。。 };  

这里的MX6QDL_PAD_SD4_DAT7__UART2_TX_DATA在imx6dl-pinfunc.h文件中有如下定义:

 

 

 

MX6QDL_PAD_SD4_DAT7__UART2_TX_DATA          0x35c 0x744 0x000 0x2 0x0  

 

将管脚的配置展开即: 0x35c 0x744 0x000 0x2 0x00x1b0b1 

想知道这六个值都是什么意思,可以从两个路出发:①查找解读dts的文件,即看内核源码;②在网上查找相关知识。

1.1 查看源码对设备树文件的解读

首先在imx6dl-pinfunc.h文件中有对前5个变量的解释,如下图:

为了验证这5个变量,并查找第6个变量的含义,我们打开读取设备树文件的代码。

读取dts文件的文件为:drivers/pinctrl/freescale/pinctrl-imx.c,实现函数名为:static int imx_pinctrl_parse_groups(。。。),如下:

 

 

static imx_pinctrl_parse_groups( device_node *np,  

  •                      imx_pin_group *grp,  
  •  imx_pinctrl_soc_info *info,  
  •                     u32 index)  
  •  size, pin_size;  
  •  __be32 *list;  
  •      i;  
  •  (info->flags & SHARE_MUX_CONF_REG)  
  •         pin_size = SHARE_FSL_PIN_SIZE;  
  •   
  •         pin_size = FSL_PIN_SIZE;  
  •   
  •     grp->name = np->name;  
  •      * the binding format is fsl,pins = <PIN_FUNC_ID CONFIG ...>, 
  •      */
    , &size);  
  •  (!list) {  
  •         dev_err(info->dev, 
     -EINVAL;  
  •     }  
  •   
  •  (!size || size % pin_size) {  
  •         dev_err(info->dev, 
     -EINVAL;  
  •     }  
  • ( imx_pin),  
  •                 GFP_KERNEL);  
  • (unsigned ),  
  •                 GFP_KERNEL);  
  •  (!grp->pins || ! grp->pin_ids)  
  •          -ENOMEM;  
  •  (i = 0; i < grp->npins; i++) {  
  •  pin_id;  
  •          imx_pin_reg *pin_reg;  
  •  imx_pin *pin = &grp->pins[i];  
  •   
  •  (info->flags & SHARE_MUX_CONF_REG)  
  •             conf_reg = mux_reg;  
  •   
  •             conf_reg = be32_to_cpu(*list++);  
  •   
  •  (config & IMX_PAD_SION)  
  •  0;  
  • 这段代码中list = of_get_property(np, "fsl,pins",
    &size);实现了读取dts文件中的fsl,pin属性值,并保存在了list指针变量中。紧接着,分别将list中的值mux_reg、conf_reg、input_reg、mux_mode、input_val、config六个变量中,由名字可以猜测个大概,前5个得以验证,第六个表示config,config的值说白了就是对寄存器配置(上拉电阻、频率等等)的值,就是pad_ctrl的值。

     

    因此对应关系如下:

          0x35c     |     0x744      |     0x000        |      0x2        |      0x0     | 0x1b0b1
    ---------------------------------------------------------------------------------------------------------
    mux_ctrl_ofs  |  pad_ctrl_ofs |  sel_input_ofs |  mux_mode   | sel_input   |  pad_ctrl

    以上参数在参考手册怎么确定的呢?由于是对复用管脚的配置,于是在管脚复用的章节(IOMUXC)中查找。但是现确定pad name才方便,于是定义在External Signals and Pin Multiplexing章节,搜索MX6QDL_PAD_SD4_DAT7__UART2_TX_DATA的中间部分:SD4_DAT7,如下图

    可知UART2_TX_DATA是属于SD4_DAT7的ALT2,于是mux_mode=0x2即可。上图表格中最后一列SW_PAD_CTL_PAD_SD4_DATA7是config配置需要查找的名称,跳到管脚复用的章节(IOMUXC)中,找到SW_PAD_CTL_PAD_SD4_DATA7,如下所示:

    如果直接取默认值的话结果是config=0x1b0b0,这里可以根据自己的需要(硬件)更改为与自己的板子匹配的值,我把最后SRE的值设置为1,即Fast Slew Rate,如下图说明:

    OK,接下来是mux_ctrl_ofs、pad_ctrl_ofs、sel_input_ofs三个偏移值,这些值都是在复用管脚的章节确定的。因为pad name为SD4_DATA7,所以在找的时候可以拿它当关键字。

    首先是mux_ctrl_ofs,找到IOMUXC_SW_MUX_CTL_PAD*开头的部分,结尾选择SD4_DATA7即可,如下图,

    由”Address: 20E_0000h base + 35Ch offset = 20E_035Ch“中可知offset=35C,即mux_ctrl_oft=0x35c

    其他的查找方法类似。pad_ctrl_ofs,查找IOMUXC_SW_PAD_CTL_PAD_SD4_DATA7一节,可知偏移值pad_ctrl_ofs=0x744

    sel_input_ofs查找IOMUXC章节以SELECT_INPUT结尾的部分,中间选择UART2_TX,如果没有这里sel_input_ofs=0x000即可,对应的sel_input为0即可。如果有例如IOMUXC_UART2_UART_RX_DATA_SELECT_INPUT,即uart的rx管脚配置,如下图,所以RX的sel_input_ofs=0x904,这里选择对应的值“110
    SD4_DATA4_ALT2 — Selecting ALT2 mode of pad SD4_DAT4 for UART2_RX_DATA..“所以RX(MX6QDL_PAD_SD4_DAT4__UART2_RX_DATA)的sel_input=0x6。

     

    首先还是先看代码,看看到底特殊到哪里。

     

            pinctrl_gpio_leds: gpioledsgrp {  

  •             fsl,pins = <  
  •         };
  • 可以看出来特殊的配置就是后面的值也就是上一篇讲的config(pad_ctrl)的值改变了,变为0x80000000和0x4001b8b1了,当我们查找相应的pad值时是这样的:

    这明显不和常理,在上图中显示高15位全部置0,取值也没啥用,那么为什么设置为0x80000000和0x4001b8b1呢?在网上搜罗一番没有任何有帮助的文档,只能靠自己了。还是老思路,查找设备树文件的读取源码,drivers/pinctrl/freescale/pinctrl-imx.c中,找到了惊喜!!!代码如下

     

     

    /* The bits in CONFIG cell defined in binding doc*/
    #define IMX_NO_PAD_CTL  0x80000000  /* no pin config need */
    #define IMX_PAD_SION 0x40000000     /* set SION */</span>  

    再将IMX_NO_PAD_CTL使用部分的代码贴上(随便找一处)

     

     

     

         (i = j = 0; i < grp->npins; i++) {  

  •          (!(grp->pins[i].config & IMX_NO_PAD_CTL)) {  
  •     }
  • 可以看出来确实如注释(/* no pin config need */)所述,表示该管脚的配置config(pad_ctrl)无效,或者说不需要。

     

    同理0x40000000表示设置了SION。但是0x4001b8b1表示什么意思呢,从上一个注释(/* The bits in CONFIG
    cell defined in binding doc*/)可以找到方向,即取binding
    doc中找,所以打开Documentation/devicetree/bindings/pinctrl目录下的fsl,imx6dl-pinctrl.txt文件,里面有关于SION的介绍,如下:

    再从芯片的参考手册中查阅可知,SION就相当于一个标志为(第30位),去掉这一位后config=0x1b8b1,这个值就是从pad_ctrl一节找到的,具体可以参见第6个参数的确定方法。

 

时间: 2024-09-20 19:44:50

imx6设备树pinctrl解析【转】的相关文章

linux 设备树【转】

转自:http://blog.csdn.net/chenqianleo/article/details/77779439 [-] linux 设备树 为什么要使用设备树Device Tree 设备树的的组成和结构 1设备树的组成 11 DTS和DTSI 12 DTC 13 DTB 14 绑定bingding 15 Bootloader 使用dtb 2设备树框架 设备树语法 下面这个是rk3399-fpgadts 1根节点兼容性 2节点名 3引用 KEY 1compatible 2address

linux设备树笔记__dts基本概念及语法【转】

转自:http://www.360doc.com/content/15/1113/11/15700426_512794532.shtml   设备树手册(Device Tree Usage)原文地址:http://www.devicetree.org/Device_Tree_Usage 有关device tree数据格式的更完整技术说明,读者可以参考ePAPR规范(http://www.power.org/resources/downloads/Power_ePAPR_APPROVED_v1.0

Linux 获取设备树源文件(DTS)里描述的资源【转】

转自:http://www.linuxidc.com/Linux/2013-07/86839.htm 转自:http://blog.sina.com.cn/s/blog_636a55070101mced.html 在linux使用platform_driver_register() 注册  platform_driver 时, 需要在 platform_driver 的probe() 里面知道设备的中断号, 内存地址等资源. 这些资源的描述信息存放在 resource 数据结构中, 相同的资源存

设备树网址【原创笔记】

  设备树学习网址 DTS: http://blog.csdn.net/21cnbao/article/details/8457546 http://www.wowotech.net/device_model/why-dt.html   IRQ_DOMIAN: http://www.wowotech.net/linux_kenrel/irq-domain.html   PINCTRL: http://blog.csdn.net/mike8825/article/details/51475985

代码-菜鸟提问:关于网站建立的树系统解析

问题描述 菜鸟提问:关于网站建立的树系统解析 菜鸟一名,想请大师概念式系统的描述下网站制作需要的软件(如果知道相同功能的软件最好指出软件之间的不同之处),以及需要学习的代码和代码所实现的功能.谢谢 比如 首选要学习html,它在网页中充当什么角色,实现什么功能,编辑软件常用的是哪些,各自有什么不同之处 其次要学习------ 不胜感激 解决方案 cmcc c++ 解决方案二: 首选要学习 html 它是目前网络上应用最为广泛的语言,也是构成网页文档的主要语言.HTML文件是由HTML命令组成的描

设备树概述【转】

转自:http://docs.oracle.com/cd/E38902_01/html/E38873/kernelovr-64300.html 设备树概述 Oracle Solaris OS 中的设备表示为互连的设备信息节点树.设备树描述特定计算机的已装入设备的配置. 设备树组件 系统将会生成树结构,其中包含有关引导时连接到计算机的设备的信息.此外,系统正常运行时也可以动态重新配置设备树.设备树从表示平台的根设备节点开始. 根节点下面是设备树的分支.分支由一个或多个总线结点设备和一个终止叶设备组

ARM Linux 3.x的设备树(Device Tree)【转】

转自:http://blog.csdn.net/21cnbao/article/details/8457546 版权声明:本文为博主原创文章,未经博主允许不得转载.   目录(?)[-] ARM Device Tree起源 Device Tree组成和结构 DTS device tree source DTC device tree compiler Device Tree Blob dtb Binding Bootloader Device Tree引发的BSP和驱动变更 常用OF API 总

DOM树节点解析

DOM是解析XML文件的官方标准,它与平台和语言无关.DOM解析将整个XML文件载入并组装成一棵DOM节点树,然后通过遍历.查找节点以读取XML文件中定义的数据.由于DOM解析中把所有节点都载入到内存中,因而它比较耗资源,而且它需要把整棵节点树构建完成后开始读取数据,因而它相对性能也不好:不过由于它在内存中保存了DOM节点树,因而它可以多次读取,并且它的节点树定义比较容易理解,因而操作起来比较简单.关于性能,有人对一些常用的解析方法做了比较: 单位:s(秒)转自:http://www.cnblo

金山发表移动设备电池白皮书 解析手机电池爆炸三大原因

据美国科技资讯网站CNET报道,3月22日早间,美国科罗拉多州一名iPhone用户反映,其iPhone 4手机周三早上在充电时发生爆炸.这名科罗拉多州女子表示,她在美国当地时间周三早上6点30分醒来,发现自己的iPhone 4在宾馆床上冒烟,并发出嗞嗞声.报道称这可能是美国第一起iPhone爆炸事故,但这不是iPhone第一次发生爆炸事故. 去年,澳大利亚和巴西都发生了iPhone起火事件.不过此前也有用户反映微博摩托罗拉Droid 2通话时在耳边爆炸. 我国也曾发生手机电池爆炸事件,据金山电池