On Tue, Dec 17, 2013 at 09:33:08AM +0200, Jani Nikula wrote: > On Mon, 16 Dec 2013, Chris Wilson <chris@xxxxxxxxxxxxxxxxxx> wrote: > > If we fail to remove a conflicting fb driver, we need to abort the > > loading of the second driver to avoid likely kernel panics. > > > > Signed-off-by: Chris Wilson <chris@xxxxxxxxxxxxxxxxxx> > > Cc: Jean-Christophe Plagniol-Villard <plagnioj@xxxxxxxxxxxx> > > Cc: Tomi Valkeinen <tomi.valkeinen@xxxxxx> > > Cc: linux-fbdev@xxxxxxxxxxxxxxx > > Cc: dri-devel@xxxxxxxxxxxxxxxxxxxxx > > --- > > drivers/video/fbmem.c | 31 +++++++++++++++++++++---------- > > include/linux/fb.h | 4 ++-- > > 2 files changed, 23 insertions(+), 12 deletions(-) > > > > diff --git a/drivers/video/fbmem.c b/drivers/video/fbmem.c > > index 010d19105ebc..e296967a3abb 100644 > > --- a/drivers/video/fbmem.c > > +++ b/drivers/video/fbmem.c > > @@ -1577,10 +1577,10 @@ static bool fb_do_apertures_overlap(struct apertures_struct *gena, > > static int do_unregister_framebuffer(struct fb_info *fb_info); > > > > #define VGA_FB_PHYS 0xA0000 > > -static void do_remove_conflicting_framebuffers(struct apertures_struct *a, > > - const char *name, bool primary) > > +static int do_remove_conflicting_framebuffers(struct apertures_struct *a, > > + const char *name, bool primary) > > { > > - int i; > > + int i, ret; > > > > /* check all firmware fbs and kick off if the base addr overlaps */ > > for (i = 0 ; i < FB_MAX; i++) { > > @@ -1599,22 +1599,29 @@ static void do_remove_conflicting_framebuffers(struct apertures_struct *a, > > printk(KERN_INFO "fb: conflicting fb hw usage " > > "%s vs %s - removing generic driver\n", > > name, registered_fb[i]->fix.id); > > - do_unregister_framebuffer(registered_fb[i]); > > + ret = do_unregister_framebuffer(registered_fb[i]); > > + if (ret) > > + return ret; > > An observation, this bails out early instead of trying to unregister all > the conflicting framebuffers regardless of errors like before. We're > probably doomed either way? Indeed. Early exit hopefully leaves the machine usable for bug reporting. -Chris -- Chris Wilson, Intel Open Source Technology Centre -- To unsubscribe from this list: send the line "unsubscribe linux-fbdev" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html