static int iproc_adc_probe(struct platform_device *pdev)
{
struct iproc_adc_priv *adc_priv;
struct iio_dev *indio_dev = NULL;
int ret;
indio_dev = devm_iio_device_alloc(&pdev->dev,
sizeof(*adc_priv));
if (!indio_dev) {
dev_err(&pdev->dev, "failed to allocate iio device\n");
return -ENOMEM;
}
adc_priv = iio_priv(indio_dev);
platform_set_drvdata(pdev, indio_dev);
mutex_init(&adc_priv->mutex);
init_completion(&adc_priv->completion);
adc_priv->regmap = syscon_regmap_lookup_by_phandle(pdev->dev.of_node,
"adc-syscon");
if (IS_ERR(adc_priv->regmap)) {
dev_err(&pdev->dev, "failed to get handle for tsc syscon\n");
ret = PTR_ERR(adc_priv->regmap);
return ret;
}
请问Linux内核驱动文件里的probe探针函数的 平台设备参数 pdev是如何传进来的?有内核开发方面的同行能指点一下吗?谢谢!
该回答引用GPTᴼᴾᴱᴺᴬᴵ
在Linux内核中,设备驱动程序通常使用平台设备(platform_device)结构来描述硬件设备。当内核启动时,设备树中描述的硬件设备会被解析,并根据设备树中的信息创建平台设备结构。然后,平台设备结构会作为参数传递给驱动程序中的probe函数。
在驱动程序中,可以使用platform_driver结构来注册probe函数,如下所示:
static struct platform_driver my_driver = {
.driver = {
.name = "my_device",
.of_match_table = of_match_ptr(my_device_of_match),
},
.probe = my_probe,
.remove = my_remove,
};
module_platform_driver(my_driver);
在这个例子中,my_probe函数被注册为probe函数,当匹配到名为“my_device”的设备时会自动调用my_probe函数,同时把对应的平台设备结构作为参数传递给my_probe函数。
Linux内核中平台设备的probe函数被调用时,会将平台设备的指针传递给该函数,即平台设备参数pdev是由内核框架自动传递给probe函数的。具体来说,当平台设备被注册到内核时,内核会先调用platform_driver中的probe函数,然后再调用probe函数来完成设备驱动的初始化和注册。
在设备注册过程中,驱动程序需要先注册platform_driver结构体,然后在probe函数中使用platform_device结构体创建一个设备对象,内核会将该对象的指针传递给probe函数。通常,platform_device结构体包含了设备的名称、资源、设备树节点等信息,驱动程序可以在probe函数中使用这些信息初始化设备驱动。
在probe函数中,可以使用platform_set_drvdata函数将设备对象的指针保存到驱动程序的私有数据结构中,这样在后续的操作中就可以通过iio_priv函数获取设备对象的指针,进而获取设备的其他信息和资源,完成设备的初始化和注册。