Linux系统内核问题


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函数获取设备对象的指针,进而获取设备的其他信息和资源,完成设备的初始化和注册。