On Tue, Apr 17, 2018 at 09:37:44AM -0400, Sean Paul wrote: > On Mon, Apr 16, 2018 at 03:22:15PM -0700, Kristian H. Kristensen wrote: > > Blending win0 with the background color doesn't seem to work > > correctly. We only get the background color, no matter the contents of > > the win0 framebuffer. However, blending pre-multiplied color with the > > default opaque black default background color is a no-op, so we can > > just disable blending to get the correct result. > > > > Signed-off-by: Kristian H. Kristensen <hoegsberg@xxxxxxxxxxxx> > > Cc: Sandy Huang <hjc@xxxxxxxxxxxxxx> > > Cc: Sean Paul <seanpaul@xxxxxxxxxxxx> > > Sandy, when you push this, could you please remove the CHROMIUM: prefix from the > subject? > > Reviewed-by: Sean Paul <seanpaul@xxxxxxxxxxxx> Sigh. I should read replies before opening my mouth. Looks like you'll need to rebase on drm-misc-next and fix the compile issue. Sean > > > > --- > > As per Eric's suggestion, we can just disable blending. This replaces > > the previous "Filter out alpha formats for primary plane" patch. > > > > drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 9 ++++++++- > > 1 file changed, 8 insertions(+), 1 deletion(-) > > > > diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > > index fae37b1cd691..1c1dd11d489a 100644 > > --- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > > +++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > > @@ -961,7 +961,14 @@ static void vop_plane_atomic_update(struct drm_plane *plane, > > rb_swap = has_rb_swapped(fb->format->format); > > VOP_WIN_SET(vop, win, rb_swap, rb_swap); > > > > - if (is_alpha_support(fb->format->format)) { > > + /* > > + * Blending win0 with the background color doesn't seem to work > > + * correctly. We only get the background color, no matter the contents > > + * of the win0 framebuffer. However, blending pre-multiplied color > > + * with the default opaque black default background color is a no-op, > > + * so we can just disable blending to get the correct result. > > + */ > > + if (is_alpha_support(fb->format->format) && win_index > 0) { > > VOP_WIN_SET(vop, win, dst_alpha_ctl, > > DST_FACTOR_M0(ALPHA_SRC_INVERSE)); > > val = SRC_ALPHA_EN(1) | SRC_COLOR_M0(ALPHA_SRC_PRE_MUL) | > > -- > > 2.17.0.484.g0c8726318c-goog > > > > -- > Sean Paul, Software Engineer, Google / Chromium OS -- Sean Paul, Software Engineer, Google / Chromium OS _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel