• L
    drm/i915: Tear down fbdev if initialization fails · 366e39b4
    Lukas Wunner 提交于
    Currently if intelfb_create() errors out, it unrefs the bo even though
    the fb now owns that reference. (Spotted by Ville Syrjälä.) We should
    unref the fb instead of the bo.
    
    However the fb was not necessarily allocated by intelfb_create(),
    it could be inherited from BIOS (the fb struct was then allocated by
    dev_priv->display.get_initial_plane_config()) and be in active use by
    a crtc. In this case we should call drm_framebuffer_remove() instead
    of _unreference() to also disable the crtc.
    
    Daniel Vetter suggested that "fbdev teardown code will take care of it.
    The correct approach is probably to not unref anything at all".
    
    But if fbdev initialization fails, the fbdev isn't torn down and
    occupies memory even though it's unusable. Therefore clobber it in
    intel_fbdev_initial_config(). (Currently we ignore a negative return
    value there.) The idea is that if fbdev initialization fails, the driver
    behaves as if CONFIG_DRM_FBDEV_EMULATION wasn't set. Should X11 manage
    to start up without errors, it will at least be able to use the memory
    that would otherwise be hogged by the unusable fbdev.
    
    Also, log errors in intelfb_create().
    
    Don't call async_synchronize_full() in intel_fbdev_fini() when called
    from intel_fbdev_initial_config() to avoid deadlock.
    
    v2: Instead of calling drm_framebuffer_unreference() (if fb was not
        inherited from BIOS), call intel_fbdev_fini().
    
    v3: Rebase on e00bf696 (drm/i915: Move the fbdev async_schedule()
        into intel_fbdev.c), call async_synchronize_full() conditionally
        instead of moving it into i915_driver_unload().
    
    Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
    Signed-off-by: NLukas Wunner <lukas@wunner.de>
    Link: http://patchwork.freedesktop.org/patch/msgid/49ce5f0daead24b7598ec78591731046c333c18d.1447938059.git.lukas@wunner.deSigned-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
    366e39b4
intel_fbdev.c 23.0 KB