[PATCH 1/1] staging: vchiq: Replace global state with per device state
Stefan Wahren
stefan.wahren at i2se.com
Mon Nov 1 05:19:17 PDT 2021
Hi Ojaswin,
Am 01.11.21 um 12:09 schrieb Ojaswin Mujoo:
> Currently, the driver has a global g_state variable which is initialised
> during probe and directly used all over the driver code. However, this
> prevents the driver to support multiple VideoCore VPUs at the same time.
>
> Replace this global state with a per device state which is initialised
> and allocated during probing.
>
> Signed-off-by: Ojaswin Mujoo <ojaswin98 at gmail.com>
...
>
> /*
> @@ -1763,6 +1795,7 @@ static int vchiq_probe(struct platform_device *pdev)
> struct device_node *fw_node;
> const struct of_device_id *of_id;
> struct vchiq_drvdata *drvdata;
> + struct vchiq_device *vchiq_dev;
> int err;
>
> of_id = of_match_node(vchiq_of_match, pdev->dev.of_node);
> @@ -1784,7 +1817,18 @@ static int vchiq_probe(struct platform_device *pdev)
>
> platform_set_drvdata(pdev, drvdata);
>
> - err = vchiq_platform_init(pdev, &g_state);
> + vchiq_dev = kzalloc(sizeof(struct vchiq_device), GFP_KERNEL);
> + vchiq_dev->state = kzalloc(sizeof(struct vchiq_state), GFP_KERNEL);
> + vchiq_dev->vchiq_pdev = *pdev;
> +
> + g_state = vchiq_dev->state;
> +
just a quick idea: how about storing the global state within vchiq_drvdata?
So there is no need to reinvent somekind of vchiq device which is the
"same" as the platform device. After that you are able to access the
private driver data via platform_get_drvdata().
Best regards
More information about the linux-arm-kernel
mailing list