staging: fbtft: Make fbtft_remove_common() return void
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Tue, 12 Oct 2021 15:39:44 +0000 (17:39 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 13 Oct 2021 12:30:38 +0000 (14:30 +0200)
fbtft_remove_common() is only called with a non-NULL fb_info. (All
callers are in remove callbacks and the matching probe callbacks set
driver data accordingly.) So fbtft_remove_common() always returns zero.
Make it return void instead which makes it easier to see in the callers
that there is no error to handle.

Also the return value of platform and spi remove callbacks is ignored
anyway and not freeing resources in .remove() is a bad idea.

Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Link: https://lore.kernel.org/r/20211012153945.2651412-20-u.kleine-koenig@pengutronix.de
Acked-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/fbtft/fbtft-core.c
drivers/staging/fbtft/fbtft.h

index 65de1c02e7dce6c91b4f26b172a38821defdd3fa..ecb5f75f6dd56858c33df9184f2804058e7d2827 100644 (file)
@@ -1319,23 +1319,17 @@ EXPORT_SYMBOL(fbtft_probe_common);
  * @info: Framebuffer
  *
  * Unregisters and releases the framebuffer
- *
- * Return: 0 if successful, negative if error
  */
-int fbtft_remove_common(struct device *dev, struct fb_info *info)
+void fbtft_remove_common(struct device *dev, struct fb_info *info)
 {
        struct fbtft_par *par;
 
-       if (!info)
-               return -EINVAL;
        par = info->par;
        if (par)
                fbtft_par_dbg(DEBUG_DRIVER_INIT_FUNCTIONS, par,
                              "%s()\n", __func__);
        fbtft_unregister_framebuffer(info);
        fbtft_framebuffer_release(info);
-
-       return 0;
 }
 EXPORT_SYMBOL(fbtft_remove_common);
 
index 76f8c090a83702b56b2399194898d002b1151af1..6869f3603b0e6c4bf35149402ea7af06553ef736 100644 (file)
@@ -252,7 +252,7 @@ void fbtft_unregister_backlight(struct fbtft_par *par);
 int fbtft_init_display(struct fbtft_par *par);
 int fbtft_probe_common(struct fbtft_display *display, struct spi_device *sdev,
                       struct platform_device *pdev);
-int fbtft_remove_common(struct device *dev, struct fb_info *info);
+void fbtft_remove_common(struct device *dev, struct fb_info *info);
 
 /* fbtft-io.c */
 int fbtft_write_spi(struct fbtft_par *par, void *buf, size_t len);
@@ -283,7 +283,8 @@ static int fbtft_driver_remove_spi(struct spi_device *spi)                 \
 {                                                                          \
        struct fb_info *info = spi_get_drvdata(spi);                       \
                                                                           \
-       return fbtft_remove_common(&spi->dev, info);                       \
+       fbtft_remove_common(&spi->dev, info);                              \
+       return 0;                                                          \
 }                                                                          \
                                                                           \
 static int fbtft_driver_probe_pdev(struct platform_device *pdev)           \
@@ -295,7 +296,8 @@ static int fbtft_driver_remove_pdev(struct platform_device *pdev)          \
 {                                                                          \
        struct fb_info *info = platform_get_drvdata(pdev);                 \
                                                                           \
-       return fbtft_remove_common(&pdev->dev, info);                      \
+       fbtft_remove_common(&pdev->dev, info);                             \
+       return 0;                                                          \
 }                                                                          \
                                                                           \
 static const struct of_device_id dt_ids[] = {                              \