if (pdata && pdata->gpio_base)
                gpio->gp.base = pdata->gpio_base;
 
-       ret = gpiochip_add_data(&gpio->gp, gpio);
+       ret = devm_gpiochip_add_data(&pdev->dev, &gpio->gp, gpio);
        if (ret < 0) {
                dev_err(&pdev->dev, "Could not register gpiochip, %d\n", ret);
                return ret;
        return 0;
 }
 
-static int da9052_gpio_remove(struct platform_device *pdev)
-{
-       struct da9052_gpio *gpio = platform_get_drvdata(pdev);
-
-       gpiochip_remove(&gpio->gp);
-       return 0;
-}
-
 static struct platform_driver da9052_gpio_driver = {
        .probe = da9052_gpio_probe,
-       .remove = da9052_gpio_remove,
        .driver = {
                .name   = "da9052-gpio",
        },