不要修改dtsi,修改自己板子的dts,通过 &label 语句修改子文件里已经存在的节点
2017-03-12 18:58
351 查看
dts里的of_device节点的属性都是分开写的,这样是降低耦合,把比如imx6q的i2c的节点,它的compatible 属性是在最经常被包含的imx6qdl.dtsi文件中,如:
i2c1: i2c@021a0000 {
#address-cells = <1>;
#size-cells = <0>;
compatible = "fsl,imx6q-i2c", "fsl,imx21-i2c";
reg = <0x021a0000 0x4000>;
interrupts = <0 36 0x04>;
clocks = <&clks 125>;
status = "disabled";
};
而自己的板子上挂了i2c slave芯片,那么针对自己的板子的dts文件里添加这个子节点,而不是在最初的imx6qdl.dtsi文件中。
在自己板子的dts文件中添加方法是:
&i2c1 {
clock-frequency = <100000>;
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_i2c1_2>;
status = "okay";
eeprom0:qom,eeprom@2b{
.....
.....
}
};
这样,原来经常被包含的文件dtsi就不用被改动了。
1,如果有相同的属性,根据语句的先后顺序,则后者会把前者的属性覆盖掉。
2,其中 i2c1 是一个标签,&i2c1 操作就表示设备节点 i2c@021a0000 的地址,表示的是对 i2c@021a0000 的操作。
i2c1: i2c@021a0000 {
#address-cells = <1>;
#size-cells = <0>;
compatible = "fsl,imx6q-i2c", "fsl,imx21-i2c";
reg = <0x021a0000 0x4000>;
interrupts = <0 36 0x04>;
clocks = <&clks 125>;
status = "disabled";
};
而自己的板子上挂了i2c slave芯片,那么针对自己的板子的dts文件里添加这个子节点,而不是在最初的imx6qdl.dtsi文件中。
在自己板子的dts文件中添加方法是:
&i2c1 {
clock-frequency = <100000>;
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_i2c1_2>;
status = "okay";
eeprom0:qom,eeprom@2b{
.....
.....
}
};
这样,原来经常被包含的文件dtsi就不用被改动了。
1,如果有相同的属性,根据语句的先后顺序,则后者会把前者的属性覆盖掉。
2,其中 i2c1 是一个标签,&i2c1 操作就表示设备节点 i2c@021a0000 的地址,表示的是对 i2c@021a0000 的操作。
相关文章推荐
- 不要修改dtsi,修改自己板子的dts,通过 &label 语句修改子文件里已经存在的节点
- HOWTO:如何通过ServiceAddService修改已经存在的服务启动参数
- 通过debugfs_rename 修改已经存在的debugfs的目录的name
- &quot;不要自己发明轮子&quot;与&quot;了解轮子是如何发明的&quot;
- MS SQL Server错误21002:[SQL-DMO]用户"xxx"已经存在 解决方法
- 即使自己有99%是好的,忘掉它们,因为他们已经是存在的了
- 通过SQL语句修改服务器时间
- [导入]PJblog插入已经存在的Tag修改
- 通过程序修改web.config/app.config文件中的节点(appSettings,connectionStrings,system.web/caching/outputCacheSettings)
- [原创]通过动态Sql语句,一次性彻底删除或者修改SBO的某个字段对应内容的信息
- 求二叉树叶子节点数目的中序遍历递归算法(已经在visual c++ 6.0中调试通过)
- 如何判断数据库中1个表已经存在,这样不会重复创建一个新表(用sql语句)
- MS SQL Server错误21002:[SQL-DMO]用户"xxx"已经存在
- C#的画图板!(源代码已经贴出,blog中其他帖子,自己找找,不要跪求了,汗!)
- 在本地数据库目录或系统数据库目录中已经存在数据库别名""的解决办法
- 【转】c# 注册表操作,创建,删除,修改,判断节点是否存在
- 在本地数据库目录或系统数据库目录中已经存在数据库别名""的解决办法
- 中国人自己的开发语言HB++<语句介绍>
- 如何通过SQL语句修改系统日期和时间
- MS SQL Server错误21002:[SQL-DMO]用户"xxx"已经存在 解决方法