• 一、 尝试在 spi 驱动里边读取 设备树里面 节点的信息

    //  dts  里面的参数配置
503 &spi0 {
504 status = "okay";
505 pinctrl-name = "default";
506 pinctrl-0 = <&spi0_pins>;
507 ti,pindir-d0-out-d1-in;
508
509 wk2124A {
510 compatible = "wk2124A";
511 reg = <0>;
512 name = "chenfulin";
513 // spi-cpha = <1>;
514 // spi-tx-bus-width = <1>;
515 // spi-rx-bus-width = <1>;
516 spi-max-frequency = <10000000>;
517 };
518 };
  • 二、 代码跟踪

    //  drivers/spi/spi.c
1428 #if defined(CONFIG_OF)
1429 static struct spi_device *
1430 of_register_spi_device(struct spi_master *master, struct device_node *nc)·
1431 {
// ...
1454 /* Device address */
1455 rc = of_property_read_u32(nc, "reg", &value); // 看他是怎么找到 reg 的值的
1456 if (rc) {
1457 dev_err(&master->dev, "%s has no valid 'reg' property (%d)\n",
1458 nc->full_name, rc);
1459 goto err_out;
1460 } // include/linux/of.h
857 static inline int of_property_read_u32(const struct device_node *np,
858 const char *propname,
859 u32 *out_value)
860 {
861 return of_property_read_u32_array(np, propname, out_value, 1); // 从函数可以看出,找的是一个 u32的值
862 } // drivers/of/base.c
1252 int of_property_read_u32_array(const struct device_node *np,
1253 const char *propname, u32 *out_values,
1254 size_t sz)
1255 {
1256 const __be32 *val = of_find_property_value_of_size(np, propname, // 然后函数又封了一层
1257 (sz * sizeof(*out_values)));
1258
1259 if (IS_ERR(val))
1260 return PTR_ERR(val);
1261
1262 while (sz--)
1263 *out_values++ = be32_to_cpup(val++);
1264 return 0;
1265 }
1266 EXPORT_SYMBOL_GPL(of_property_read_u32_array); 1125 static void *of_find_property_value_of_size(const struct device_node *np,
1126 const char *propname, u32 len)
1127 {
1128 struct property *prop = of_find_property(np, propname, NULL); // 这里就是找到节点的函数,这个 property 的链表就是设备树节点
1129
q1130 if (!prop)
1131 return ERR_PTR(-EINVAL);
1132 if (!prop->value)
1133 return ERR_PTR(-ENODATA);
1134 if (len > prop->length)
1135 return ERR_PTR(-EOVERFLOW);
1136
1137 return prop->value;
1138 } 232 struct property *of_find_property(const struct device_node *np,
233 const char *name,
234 int *lenp)
235 {
236 struct property *pp;
237 unsigned long flags;
238
239 raw_spin_lock_irqsave(&devtree_lock, flags);
240 pp = __of_find_property(np, name, lenp); // 加一个自旋锁 保证安全,然后继续匹配
241 raw_spin_unlock_irqrestore(&devtree_lock, flags);
242
243 return pp;
244 }
245 EXPORT_SYMBOL(of_find_property); 213 static struct property *__of_find_property(const struct device_node *np,
214 const char *name, int *lenp)
215 {
216 struct property *pp;
217
218 if (!np)
219 return NULL;
220
221 for (pp = np->properties; pp; pp = pp->next) {
222 if (of_prop_cmp(pp->name, name) == 0) { // 如果找到了就直接返回 pp节点。
223 if (lenp)
224 *lenp = pp->length;
225 break;
226 }
227 }
228
229 return pp;
230 } include/linux/of.h
227 #define of_prop_cmp(s1, s2) strcmp((s1), (s2))
  • 三、 关联起来的过程如下

    // driver/spi/spi.c
1428 #if defined(CONFIG_OF)
1429 static struct spi_device *
1430 of_register_spi_device(struct spi_master *master, struct device_node *nc)
1431 {
1432 struct spi_device *spi;
1433 int rc;
1434 u32 value;
// ... ..
1521 /* Store a pointer to the node in the device structure */
1522 of_node_get(nc);
1523 spi->dev.of_node = nc;
// ... ... 这里直接把设备节点挂在了 spi-dev.of_node 下面, 上面的 np 就是节点
// struct property *pp == pp = np->properties np 是一个链表。
1538 }
  • 四、在 spi drrver 里面找出相关参数

    //  probe 函数里面
1521 #if 1
1522 printk("wk2124A debug speed : %d\n", spi->max_speed_hz);
1523
1524 for (pp = spi->dev.of_node->properties; pp; pp = pp->next)
1525 {
1526 printk("%s \n", pp->name);
1527 if (strcmp(pp->name, "name") == 0)
1528 printk("name : %s\n", (char *)pp->value);
1529 }
1530 printk("\n");
1531 #endif

spidev 驱动 probe 获取 dts 节点参数的更多相关文章

  1. iwpriv工具通过ioctl动态获取相应无线网卡驱动的private_args所有扩展参数

    iwpriv工具通过ioctl动态获取相应无线网卡驱动的private_args所有扩展参数 iwpriv是处理下面的wlan_private_args的所有扩展命令,iwpriv的实现上,是这样的, ...

  2. React对比Vue(03 事件的对比,传递参数对比,事件对象,ref获取DOM节点,表单事件,键盘事件,约束非约束组件等)

    import React from 'react'; class Baby extends React.Component { constructor (props) { super(props) t ...

  3. 以太网驱动的流程浅析(四)-以太网驱动probe流程【原创】

    以太网驱动的流程浅析(四)-以太网驱动probe流程 Author:张昺华 Email:920052390@qq.com Time:2019年3月23日星期六 此文也在我的个人公众号以及<Lin ...

  4. JavaScript之怎样获取元素节点

    JavaScript获取元素节点一共有三种方法,分别是通过元素ID.通过标签名字和通过类名字来获取: 1.通过元素ID属性的ID值来获得元素对象-getElementById() DOM提供了一个名为 ...

  5. Jquery学习笔记:利用parent和parents方法获取父节点

    通过选择器一般只能获取指定标识的节点,或者获取子节点. 有些场景下,往往需要根据当前节点找到满足条件的父节点.这个可以通过相应的方法来实现. 1.parent方法 该方法可以获取元素的直接父节点. 我 ...

  6. 遍历DOM树,获取子节点

    获取子节点的方法有:  方法  说明  children()  选取子节点,可以带过滤参数.但只能选择子节点,不能选择孙子节点.  find()  选取子节点,可以带过滤参数.可以选择子节点及孙子节点 ...

  7. ztree获取选中节点时不能进入可视区域出现BUG如何解决

    zTree 是一个依靠 jQuery 实现的多功能 “树插件”.优异的性能.灵活的配置.多种功能的组合是 zTree 最大优点. zTree 的特点编辑 ● zTree v3.0 将核心代码按照功能进 ...

  8. jsTree获取选中节点和选中指定节点

    jstree获取当前选中的checkbox和获取选中节点的所有节点 首先初始化一个带有复选框的 jstree $('#demo_tree').jstree({ "core" : { ...

  9. javascript基础(六): 获取节点实例 jquery获取当前节点的前一个节点

    jquery获取当前节点的前一个节点步骤如下: 1.打开html开发工具,新建一来个html代码页面. 2.在html页面创建三个p标签,然后给这三个p标签设置不同的2113内容. 3.引入jquer ...

随机推荐

  1. C++项目參考解答:求Fibonacci数列

    [项目:求Fibonacci数列] Fibonacci数列在计算科学.经济学等领域中广泛使用,其特点是:第一.二个数是1,从第3个数開始,每一个数是其前两个数之和.据此,这个数列为:1 1 2 3 5 ...

  2. java udp 广播

    原文链接: http://blog.csdn.net/yudajun/article/details/8477149 udp 是一种网络通信协议,不需要客户端和服务器端建立连接即可进行通讯功能.相对于 ...

  3. Java Nashorn--Part 4

    Nashorn 和 javax.script 包 Nashorn 并不是第一个在 Java 平台上运行的脚本语言.在Java 6 就提供了 javax.script java 包,它为脚本语言引擎提供 ...

  4. C# 可选参数 命名参数

    1.可选参数 可选参数是.NET4中新添加的功能,应用可选参数的方法在被调用的时可以选择性的添加需要的参数,而不需要的参数由参数默认值取代. class Program { /// <summa ...

  5. 章节1:SQL语言简易入门

    一.增.删.改.查 1.增(向表格中插入数据): INSERT INTO tb_TableName(ColumnName1,ColumnName2) VALUES(ColumnValue1,Colum ...

  6. Java – How to convert String to Char Array

    Java – How to convert String to Char ArrayIn Java, you can use String.toCharArray() to convert a Str ...

  7. linux分享四:cron系统

    cron相关文件: /etc/cron.monthly/ /etc/cron.weekly/ /etc/cron.daily/ /etc/cron.hourly/ /etc/cron.d/ /etc/ ...

  8. php分享十四:php接口编写

    一:加密协议选择 二:常用url传递函数介绍 urlencode 和 rawurlencode 区别是: urlencode把空格变为+号,而rawurlencode编码为20%: base64_en ...

  9. Ingress 原理及实例

    什么是Ingress 在Kubernetes中,Service和Pod的IP地址只能在集群内部网络中路由,所有到达“边界路由器”(Edge Router)的网络流量要么被丢弃,要么被转发到别处,从概念 ...

  10. 基于Docker的负载均衡和服务发现

    应用的容器化和微服务化带来的问题 在缺省网络模型中,容器每次重启后,IP会发生变动,在一个大的分布式系统保证IP地址不变是比较复杂的事情 IP频繁发生变动,动态应用部署无法预知容器的IP地址,clie ...