mirror of
https://github.com/torvalds/linux.git
synced 2024-11-15 08:31:55 +00:00
drm/i915: Properly track domain of the fbcon fb
X could end up putting the fbcon fb into other domains, e.g. for smooth take-overs. Also we want this for accurate frontbuffer tracking: The set_config is an implicit flush and will re-enable psr and similar features, so we need to bring the bo back into the gtt domain. v2: Add FIXME comment about fbcon locking fun in atomic context, requested by Chris. Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
d5a81ef187
commit
e991077ec6
@ -43,10 +43,36 @@
|
|||||||
#include <drm/i915_drm.h>
|
#include <drm/i915_drm.h>
|
||||||
#include "i915_drv.h"
|
#include "i915_drv.h"
|
||||||
|
|
||||||
|
static int intel_fbdev_set_par(struct fb_info *info)
|
||||||
|
{
|
||||||
|
struct drm_fb_helper *fb_helper = info->par;
|
||||||
|
struct intel_fbdev *ifbdev =
|
||||||
|
container_of(fb_helper, struct intel_fbdev, helper);
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = drm_fb_helper_set_par(info);
|
||||||
|
|
||||||
|
if (ret == 0) {
|
||||||
|
/*
|
||||||
|
* FIXME: fbdev presumes that all callbacks also work from
|
||||||
|
* atomic contexts and relies on that for emergency oops
|
||||||
|
* printing. KMS totally doesn't do that and the locking here is
|
||||||
|
* by far not the only place this goes wrong. Ignore this for
|
||||||
|
* now until we solve this for real.
|
||||||
|
*/
|
||||||
|
mutex_lock(&fb_helper->dev->struct_mutex);
|
||||||
|
ret = i915_gem_object_set_to_gtt_domain(ifbdev->fb->obj,
|
||||||
|
true);
|
||||||
|
mutex_unlock(&fb_helper->dev->struct_mutex);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static struct fb_ops intelfb_ops = {
|
static struct fb_ops intelfb_ops = {
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.fb_check_var = drm_fb_helper_check_var,
|
.fb_check_var = drm_fb_helper_check_var,
|
||||||
.fb_set_par = drm_fb_helper_set_par,
|
.fb_set_par = intel_fbdev_set_par,
|
||||||
.fb_fillrect = cfb_fillrect,
|
.fb_fillrect = cfb_fillrect,
|
||||||
.fb_copyarea = cfb_copyarea,
|
.fb_copyarea = cfb_copyarea,
|
||||||
.fb_imageblit = cfb_imageblit,
|
.fb_imageblit = cfb_imageblit,
|
||||||
|
Loading…
Reference in New Issue
Block a user