我无法理解设备树是如何工作的,或者特别是为什么这个驱动程序不能初始化。这是针对android的版本3.10
的rockchip供应商内核drivers / watchdog / rk29_wdt.c (因可读性而降低)
static const struct of_device_id of_rk29_wdt_match[] = {
{ .compatible = "rockchip,watch dog" }
};
static struct platform_driver rk29_wdt_driver = {
.probe = rk29_wdt_probe,
[..]
.of_match_table = of_rk29_wdt_match,
.name = "rk29-wdt",
},
};
static int __init watchdog_init(void)
{
printk("watchdog_init\n");
return platform_driver_register(&rk29_wdt_driver);
}
这是soc dtsi
拱/臂/引导/ DTS / rk3288.dtsi
watchdog: wdt@2004c000 {
compatible = "rockchip,watch dog";
reg = <0xff800000 0x100>;
clocks = <&pclk_pd_alive>;
clock-names = "pclk_wdt";
interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
rockchip,irq = <0>;
rockchip,timeout = <2>;
rockchip,atboot = <1>;
rockchip,debug = <0>;
status = "okay";
};
但是,从不调用驱动程序的.probe函数。编译它并调用__init函数。我怀疑它有什么可以使设备树条目不匹配?也许空间是一个问题?
或者还有其他什么在.probe之前运行,以确定驱动程序是否应该继续?
此外,我不确定扁平树是如何工作的,所以这可能是相关的:
拱/臂/马赫 - 瑞芯/ RK3288
DT_MACHINE_START(RK3288_DT, "Rockchip RK3288 (Flattened Device Tree)")
.smp = smp_ops(rockchip_smp_ops),
.map_io = rk3288_dt_map_io,
.init_time = rk3288_dt_init_timer,
.dt_compat = rk3288_dt_compat,
.init_late = rk3288_init_late,
.reserve = rk3288_reserve,
.restart = rk3288_restart,
MACHINE_END
答案 0 :(得分:9)
这可能会发生多种可能的方式,而且大多数方法都远离驱动程序代码本身。首先,单独的.dtsi片段并不能说明整个故事 - 设备树语法是分层的,因此属性(特别是status
)可能仍然被板级.dts覆盖,其中包括一个基本的SoC .dtsi文件。其次,编译后的DTB也不是最后一个字,因为引导加载程序可以在将其传递给内核之前对其进行动态修改 - 这通常是针对内存节点和SMP启用方法完成的,但可能会影响任何内容。
这种调试通常最好通过检查启动系统的状态来反过来解决,然后向后工作以弄清楚事情是如何形成的 - 这个特定问题的具体细节已经确定了一些,但对于为了完整起见:
答案 1 :(得分:0)
我注意到,在您的定义中,您在数组中错过了所谓的SENTINEL,空的空结构为空。 看一个例子:
static const struct of_device_id clk_ids[] = {
{ .compatible = "sirf,atlas7-clkc" },
{},
};