Эх сурвалжийг харах

fbdev: sh_mobile_lcdcfb: fix notifier callback return codes

Notifier callbacks have to return either one of NOTIFY_* codes or a negative
errno, converted to a suitable value by the notifier_from_errno() inline, if
the notifier chain shall not be continued.

Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Guennadi Liakhovetski 15 жил өмнө
parent
commit
baf1637499

+ 8 - 6
drivers/video/sh_mobile_lcdcfb.c

@@ -964,7 +964,7 @@ static int sh_mobile_lcdc_notify(struct notifier_block *nb,
 	struct fb_var_screeninfo *var;
 	struct fb_var_screeninfo *var;
 
 
 	if (&ch->lcdc->notifier != nb)
 	if (&ch->lcdc->notifier != nb)
-		return 0;
+		return NOTIFY_DONE;
 
 
 	dev_dbg(info->dev, "%s(): action = %lu, data = %p\n",
 	dev_dbg(info->dev, "%s(): action = %lu, data = %p\n",
 		__func__, action, event->data);
 		__func__, action, event->data);
@@ -991,23 +991,25 @@ static int sh_mobile_lcdc_notify(struct notifier_block *nb,
 			/* Can we handle this display? */
 			/* Can we handle this display? */
 			if (var->xres > ch->cfg.lcd_cfg[0].xres ||
 			if (var->xres > ch->cfg.lcd_cfg[0].xres ||
 			    var->yres > ch->cfg.lcd_cfg[0].yres)
 			    var->yres > ch->cfg.lcd_cfg[0].yres)
-				return -ENOMEM;
+				/*
+				 * LCDC resume failed, no need to continue with
+				 * the notifier chain
+				 */
+				return notifier_from_errno(-ENOMEM);
 
 
 			/* Add to the modelist */
 			/* Add to the modelist */
 			fb_var_to_videomode(&mode, var);
 			fb_var_to_videomode(&mode, var);
 			ret = fb_add_videomode(&mode, &ch->info->modelist);
 			ret = fb_add_videomode(&mode, &ch->info->modelist);
 			if (ret < 0)
 			if (ret < 0)
-				return ret;
+				return notifier_from_errno(ret);
 		}
 		}
 
 
 		pm_runtime_get_sync(info->device);
 		pm_runtime_get_sync(info->device);
 
 
 		sh_mobile_lcdc_geometry(ch);
 		sh_mobile_lcdc_geometry(ch);
-
-		break;
 	}
 	}
 
 
-	return 0;
+	return NOTIFY_OK;
 }
 }
 
 
 static int sh_mobile_lcdc_remove(struct platform_device *pdev);
 static int sh_mobile_lcdc_remove(struct platform_device *pdev);