Message ID | 1454010273-21513-3-git-send-email-albeu@free.fr |
---|---|
State | New |
Headers | show |
On Fri, Jan 29, 2016 at 4:44 AM, Alban Bedel <albeu@free.fr> wrote: > As we now allow the driver to be built as a module it should be > removable. > > Signed-off-by: Alban Bedel <albeu@free.fr> > --- > drivers/gpio/gpio-ath79.c | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/drivers/gpio/gpio-ath79.c b/drivers/gpio/gpio-ath79.c > index afb535e..6b15792 100644 > --- a/drivers/gpio/gpio-ath79.c > +++ b/drivers/gpio/gpio-ath79.c > @@ -46,6 +46,7 @@ static int ath79_gpio_probe(struct platform_device *pdev) > ctrl = devm_kzalloc(&pdev->dev, sizeof(*ctrl), GFP_KERNEL); > if (!ctrl) > return -ENOMEM; > + platform_set_drvdata(pdev, ctrl); > > if (np) { > err = of_property_read_u32(np, "ngpios", &ath79_gpio_count); > @@ -97,12 +98,21 @@ static int ath79_gpio_probe(struct platform_device *pdev) > return 0; > } > > +static int ath79_gpio_remove(struct platform_device *pdev) > +{ > + struct ath79_gpio_ctrl *ctrl = platform_get_drvdata(pdev); platform_get_drvdata will return a gpio_chip *. I agree the address will be the same, but for correctness you should use the expected type. Especially since you will not use a member of ath79_gpio_ctrl in this function anyway. > + > + gpiochip_remove(&ctrl->gc); > + return 0; > +} I suspect this removal pattern to be quite common, maybe we should just export bgpio_pdev_remove() to allow other drivers to use it instead of rewriting their own version? -- To unsubscribe from this list: send the line "unsubscribe linux-gpio" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Mon, Feb 8, 2016 at 4:04 AM, Alexandre Courbot <gnurou@gmail.com> wrote: > On Fri, Jan 29, 2016 at 4:44 AM, Alban Bedel <albeu@free.fr> wrote: >> As we now allow the driver to be built as a module it should be >> removable. >> >> Signed-off-by: Alban Bedel <albeu@free.fr> >> --- >> drivers/gpio/gpio-ath79.c | 10 ++++++++++ >> 1 file changed, 10 insertions(+) >> >> diff --git a/drivers/gpio/gpio-ath79.c b/drivers/gpio/gpio-ath79.c >> index afb535e..6b15792 100644 >> --- a/drivers/gpio/gpio-ath79.c >> +++ b/drivers/gpio/gpio-ath79.c >> @@ -46,6 +46,7 @@ static int ath79_gpio_probe(struct platform_device *pdev) >> ctrl = devm_kzalloc(&pdev->dev, sizeof(*ctrl), GFP_KERNEL); >> if (!ctrl) >> return -ENOMEM; >> + platform_set_drvdata(pdev, ctrl); >> >> if (np) { >> err = of_property_read_u32(np, "ngpios", &ath79_gpio_count); >> @@ -97,12 +98,21 @@ static int ath79_gpio_probe(struct platform_device *pdev) >> return 0; >> } >> >> +static int ath79_gpio_remove(struct platform_device *pdev) >> +{ >> + struct ath79_gpio_ctrl *ctrl = platform_get_drvdata(pdev); > > platform_get_drvdata will return a gpio_chip *. No it will return a struct ath79_gpio_ctrl * AFAICT. bgpio will set the driver data to the gc but not when using generic gpio as library like this driver does, only when it is used as a stand-alone device. Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe linux-gpio" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Thu, Jan 28, 2016 at 8:44 PM, Alban Bedel <albeu@free.fr> wrote: > As we now allow the driver to be built as a module it should be > removable. > > Signed-off-by: Alban Bedel <albeu@free.fr> Patch applied. Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe linux-gpio" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/drivers/gpio/gpio-ath79.c b/drivers/gpio/gpio-ath79.c index afb535e..6b15792 100644 --- a/drivers/gpio/gpio-ath79.c +++ b/drivers/gpio/gpio-ath79.c @@ -46,6 +46,7 @@ static int ath79_gpio_probe(struct platform_device *pdev) ctrl = devm_kzalloc(&pdev->dev, sizeof(*ctrl), GFP_KERNEL); if (!ctrl) return -ENOMEM; + platform_set_drvdata(pdev, ctrl); if (np) { err = of_property_read_u32(np, "ngpios", &ath79_gpio_count); @@ -97,12 +98,21 @@ static int ath79_gpio_probe(struct platform_device *pdev) return 0; } +static int ath79_gpio_remove(struct platform_device *pdev) +{ + struct ath79_gpio_ctrl *ctrl = platform_get_drvdata(pdev); + + gpiochip_remove(&ctrl->gc); + return 0; +} + static struct platform_driver ath79_gpio_driver = { .driver = { .name = "ath79-gpio", .of_match_table = ath79_gpio_of_match, }, .probe = ath79_gpio_probe, + .remove = ath79_gpio_remove, }; module_platform_driver(ath79_gpio_driver);
As we now allow the driver to be built as a module it should be removable. Signed-off-by: Alban Bedel <albeu@free.fr> --- drivers/gpio/gpio-ath79.c | 10 ++++++++++ 1 file changed, 10 insertions(+)