<div dir="ltr"><br><br><div class="gmail_quote"><div dir="ltr">On Tue, Jun 30, 2015 at 12:08 AM Daniel Vetter <<a href="mailto:daniel@ffwll.ch">daniel@ffwll.ch</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">On Mon, Jun 29, 2015 at 01:44:46PM -0700, Rodrigo Vivi wrote:<br>
> Now that we have fb user dirty invalidating frontbuffer and we have<br>
> the new fbdev dirty callback let's merge them.<br>
><br>
> So it doesn't matter if fbcon throught fbdev or splash screen throught<br>
> drm_ioctl_dirtyfb, in any case we will have frontbuffer properly<br>
> invalidated and power savings features that rely on frontbuffer tracking<br>
> will be able to work as expected.<br>
><br>
> Signed-off-by: Rodrigo Vivi <<a href="mailto:rodrigo.vivi@intel.com" target="_blank">rodrigo.vivi@intel.com</a>><br>
<br>
Hm, I think we still need these but not sure. There's also fbdev client<br>
from userspace which directly draw into the mmap area. But tbh no idea how<br>
those are supposed to work with manually updating screens (like i915 psr,<br>
udl or qxl).<br></blockquote><div><br></div><div>Oh! Agree... I got the issue after blank so we still need those... </div><div><br></div><div>Let's forget about these fbdev changes and focus on a simple fb user dirty ops that fix the current real remaining issue...</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
-Daniel<br>
<br>
> ---<br>
>Â drivers/gpu/drm/i915/intel_fbdev.c | 86 ++++++--------------------------------<br>
>Â 1 file changed, 13 insertions(+), 73 deletions(-)<br>
><br>
> diff --git a/drivers/gpu/drm/i915/intel_fbdev.c b/drivers/gpu/drm/i915/intel_fbdev.c<br>
> index 2a1724e..f1592c7 100644<br>
> --- a/drivers/gpu/drm/i915/intel_fbdev.c<br>
> +++ b/drivers/gpu/drm/i915/intel_fbdev.c<br>
> @@ -45,92 +45,32 @@<br>
>Â #include <drm/i915_drm.h><br>
>Â #include "i915_drv.h"<br>
><br>
> -static int intel_fbdev_set_par(struct fb_info *info)<br>
> +static void intel_fbdev_dirty(struct fb_info *info, u32 x1, u32 y1,<br>
> +Â Â Â Â Â Â Â Â Â Â Â Â Â Â u32 x2, u32 y2)<br>
>Â {<br>
>Â Â Â Â struct drm_fb_helper *fb_helper = info->par;<br>
>Â Â Â Â struct intel_fbdev *ifbdev =<br>
>Â Â Â Â Â Â Â Â container_of(fb_helper, struct intel_fbdev, helper);<br>
> -Â Â Â int ret;<br>
> -<br>
> -Â Â Â ret = drm_fb_helper_set_par(info);<br>
> -<br>
> -Â Â Â if (ret == 0) {<br>
> -Â Â Â Â Â Â Â /*<br>
> -Â Â Â Â Â Â Â * FIXME: fbdev presumes that all callbacks also work from<br>
> -Â Â Â Â Â Â Â * atomic contexts and relies on that for emergency oops<br>
> -Â Â Â Â Â Â Â * printing. KMS totally doesn't do that and the locking here is<br>
> -       * by far not the only place this goes wrong. Ignore this for<br>
> -Â Â Â Â Â Â Â * now until we solve this for real.<br>
> -Â Â Â Â Â Â Â */<br>
> -Â Â Â Â Â Â Â mutex_lock(&fb_helper->dev->struct_mutex);<br>
> -Â Â Â Â Â Â Â ret = i915_gem_object_set_to_gtt_domain(ifbdev->fb->obj,<br>
> -Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â true);<br>
> -Â Â Â Â Â Â Â mutex_unlock(&fb_helper->dev->struct_mutex);<br>
> -Â Â Â }<br>
> -<br>
> -Â Â Â return ret;<br>
> -}<br>
> -<br>
> -static int intel_fbdev_blank(int blank, struct fb_info *info)<br>
> -{<br>
> -Â Â Â struct drm_fb_helper *fb_helper = info->par;<br>
> -Â Â Â struct intel_fbdev *ifbdev =<br>
> -Â Â Â Â Â Â Â container_of(fb_helper, struct intel_fbdev, helper);<br>
> -Â Â Â int ret;<br>
> -<br>
> -Â Â Â ret = drm_fb_helper_blank(blank, info);<br>
> -<br>
> -Â Â Â if (ret == 0) {<br>
> -Â Â Â Â Â Â Â /*<br>
> -Â Â Â Â Â Â Â * FIXME: fbdev presumes that all callbacks also work from<br>
> -Â Â Â Â Â Â Â * atomic contexts and relies on that for emergency oops<br>
> -Â Â Â Â Â Â Â * printing. KMS totally doesn't do that and the locking here is<br>
> -       * by far not the only place this goes wrong. Ignore this for<br>
> -Â Â Â Â Â Â Â * now until we solve this for real.<br>
> -Â Â Â Â Â Â Â */<br>
> -Â Â Â Â Â Â Â mutex_lock(&fb_helper->dev->struct_mutex);<br>
> -Â Â Â Â Â Â Â intel_fb_obj_invalidate(ifbdev->fb->obj, ORIGIN_GTT);<br>
> -Â Â Â Â Â Â Â mutex_unlock(&fb_helper->dev->struct_mutex);<br>
> -Â Â Â }<br>
> -<br>
> -Â Â Â return ret;<br>
> -}<br>
> -<br>
> -static int intel_fbdev_pan_display(struct fb_var_screeninfo *var,<br>
> -Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â struct fb_info *info)<br>
> -{<br>
> -Â Â Â struct drm_fb_helper *fb_helper = info->par;<br>
> -Â Â Â struct intel_fbdev *ifbdev =<br>
> -Â Â Â Â Â Â Â container_of(fb_helper, struct intel_fbdev, helper);<br>
> -<br>
> -Â Â Â int ret;<br>
> -Â Â Â ret = drm_fb_helper_pan_display(var, info);<br>
> -<br>
> -Â Â Â if (ret == 0) {<br>
> -Â Â Â Â Â Â Â /*<br>
> -Â Â Â Â Â Â Â * FIXME: fbdev presumes that all callbacks also work from<br>
> -Â Â Â Â Â Â Â * atomic contexts and relies on that for emergency oops<br>
> -Â Â Â Â Â Â Â * printing. KMS totally doesn't do that and the locking here is<br>
> -       * by far not the only place this goes wrong. Ignore this for<br>
> -Â Â Â Â Â Â Â * now until we solve this for real.<br>
> -Â Â Â Â Â Â Â */<br>
> -Â Â Â Â Â Â Â mutex_lock(&fb_helper->dev->struct_mutex);<br>
> -Â Â Â Â Â Â Â intel_fb_obj_invalidate(ifbdev->fb->obj, ORIGIN_GTT);<br>
> -Â Â Â Â Â Â Â mutex_unlock(&fb_helper->dev->struct_mutex);<br>
> -Â Â Â }<br>
> +Â Â Â struct intel_framebuffer *intel_fb = ifbdev->fb;<br>
> +Â Â Â struct drm_framebuffer *fb = &intel_fb->base;<br>
><br>
> -Â Â Â return ret;<br>
> +Â Â Â /*<br>
> +Â Â Â * Our fb dirty callback is just used to invalidate frontbuffer<br>
> +Â Â Â * entirely. So just fb reference is needed and rest is ignored.<br>
> +Â Â Â */<br>
> +Â Â Â fb->funcs->dirty(fb, NULL, 0, 0, NULL, 1);<br>
>Â }<br>
><br>
>Â static struct fb_ops intelfb_ops = {<br>
>Â Â Â Â .owner = THIS_MODULE,<br>
>Â Â Â Â .fb_check_var = drm_fb_helper_check_var,<br>
> -Â Â Â .fb_set_par = intel_fbdev_set_par,<br>
> +Â Â Â .fb_set_par = drm_fb_helper_set_par,<br>
>Â Â Â Â .fb_fillrect = cfb_fillrect,<br>
>Â Â Â Â .fb_copyarea = cfb_copyarea,<br>
>Â Â Â Â .fb_imageblit = cfb_imageblit,<br>
> -Â Â Â .fb_pan_display = intel_fbdev_pan_display,<br>
> -Â Â Â .fb_blank = intel_fbdev_blank,<br>
> +Â Â Â .fb_dirty = intel_fbdev_dirty,<br>
> +Â Â Â .fb_pan_display = drm_fb_helper_pan_display,<br>
> +Â Â Â .fb_blank = drm_fb_helper_blank,<br>
>Â Â Â Â .fb_setcmap = drm_fb_helper_setcmap,<br>
>Â Â Â Â .fb_debug_enter = drm_fb_helper_debug_enter,<br>
>Â Â Â Â .fb_debug_leave = drm_fb_helper_debug_leave,<br>
> --<br>
> 2.1.0<br>
><br>
> _______________________________________________<br>
> Intel-gfx mailing list<br>
> <a href="mailto:Intel-gfx@lists.freedesktop.org" target="_blank">Intel-gfx@lists.freedesktop.org</a><br>
> <a href="http://lists.freedesktop.org/mailman/listinfo/intel-gfx" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/intel-gfx</a><br>
<br>
--<br>
Daniel Vetter<br>
Software Engineer, Intel Corporation<br>
<a href="http://blog.ffwll.ch" rel="noreferrer" target="_blank">http://blog.ffwll.ch</a><br>
_______________________________________________<br>
dri-devel mailing list<br>
<a href="mailto:dri-devel@lists.freedesktop.org" target="_blank">dri-devel@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/dri-devel" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/dri-devel</a><br>
</blockquote></div></div>