Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp348890ybt; Wed, 17 Jun 2020 02:32:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxzYRtfgs6qk5w+R38N/nFF7VhSmmGqB+WR2kyo6S0rc471QTP3rtBmmsfo+ajC8yMe+bhl X-Received: by 2002:a50:b2a1:: with SMTP id p30mr6649442edd.199.1592386348881; Wed, 17 Jun 2020 02:32:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592386348; cv=none; d=google.com; s=arc-20160816; b=WFwqFwb/cI/6WnG9dTzOjDiqQlYOyZ03dZwzRXJ0chp2FzAhuj3N+65vULb0D7Z62O fW4G0oDShq2JbIu7qdPGD09BnhKLTlopWbuql/YsCIGKTo5uH9NC0Kd7TXS9htHk0PU3 jslZoQcPHWA+EkeupgUGVZzAOLUhNh3WoqpXZMYDmBtV2eO4IYFu3EgE0Agd8VsJYv1R NNhlZMMnQiUcHwSu0wy79y4msh+TgfOgusPilVh4f4q8/Wf+qIgC84NLknn2XyJt9Wyd 4nT6VCRH8sku3u7SnKYWltxCFcNKezmBTkY2wvy8BcGkRivpf+5EZFDIKUH5jT0g6i9i GFcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=P/XoJ/ZSZC1LLE5N8TaRhJM50Nvpe8woO7LbowCbuME=; b=yryGkiCyQcjyhYOq+1CzrUnQAlur4zQdONJ9CpEgUx5JZsWja3N4W1vZHXWd+cGjZ1 Hl+/0HjyDkt4WGC4n0O/EzIppty8ttuRjgG/gBwqFntSwDDUVCdbYkpWG9XtBW+97ao9 2BR+2vlW1yPpqsx1zfY1Fz4SasTui690R2d1+XYKg8cCZRnjUMLfUnxHo7N5ZgnPFMoK J0iXvp3GociZsTMk71jUWqs8RHhk1kyV/8IzPs/41eaaygp6k9Qji/8Wx0c7wepz0xjL j2EGx1o6XK10Cj3EEYxCnOf7JMgN6KKSFZ3Xjs9v0b6pqS02fPmye2MdG1XwvOcp0Xhz TnUw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h12si12148159eji.721.2020.06.17.02.32.05; Wed, 17 Jun 2020 02:32:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726303AbgFQJ2H (ORCPT + 99 others); Wed, 17 Jun 2020 05:28:07 -0400 Received: from gloria.sntech.de ([185.11.138.130]:43622 "EHLO gloria.sntech.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725554AbgFQJ2F (ORCPT ); Wed, 17 Jun 2020 05:28:05 -0400 Received: from ip5f5aa64a.dynamic.kabel-deutschland.de ([95.90.166.74] helo=diego.localnet) by gloria.sntech.de with esmtpsa (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1jlUMF-0006WM-DR; Wed, 17 Jun 2020 11:27:47 +0200 From: Heiko =?ISO-8859-1?Q?St=FCbner?= To: Jonas Karlman Cc: Sandy Huang , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Ben Davis , Brian Starkey , dri-devel@lists.freedesktop.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 2/2] drm: rockchip: add NV15 and NV20 support Date: Wed, 17 Jun 2020 11:27:46 +0200 Message-ID: <19910776.xcDMAuBTMJ@diego> In-Reply-To: <20200607202521.18438-3-jonas@kwiboo.se> References: <20200607202521.18438-1-jonas@kwiboo.se> <20200607202521.18438-3-jonas@kwiboo.se> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am Sonntag, 7. Juni 2020, 22:25:26 CEST schrieb Jonas Karlman: > Add support for displaying 10-bit 4:2:0 and 4:2:2 formats produced by the > Rockchip Video Decoder on RK322X, RK3288, RK3328, RK3368 and RK3399. > > Signed-off-by: Jonas Karlman Reviewed-by: Heiko Stuebner > --- > drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 27 ++++++++++++++++-- > drivers/gpu/drm/rockchip/rockchip_drm_vop.h | 1 + > drivers/gpu/drm/rockchip/rockchip_vop_reg.c | 31 +++++++++++++++++---- > 3 files changed, 51 insertions(+), 8 deletions(-) > > diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > index 33463b79a37b..13a0682d438b 100644 > --- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > +++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > @@ -261,6 +261,17 @@ static bool has_rb_swapped(uint32_t format) > } > } > > +static bool is_fmt_10(uint32_t format) > +{ > + switch (format) { > + case DRM_FORMAT_NV15: > + case DRM_FORMAT_NV20: > + return true; > + default: > + return false; > + } > +} > + > static enum vop_data_format vop_convert_format(uint32_t format) > { > switch (format) { > @@ -276,8 +287,10 @@ static enum vop_data_format vop_convert_format(uint32_t format) > case DRM_FORMAT_BGR565: > return VOP_FMT_RGB565; > case DRM_FORMAT_NV12: > + case DRM_FORMAT_NV15: > return VOP_FMT_YUV420SP; > case DRM_FORMAT_NV16: > + case DRM_FORMAT_NV20: > return VOP_FMT_YUV422SP; > case DRM_FORMAT_NV24: > return VOP_FMT_YUV444SP; > @@ -922,7 +935,12 @@ static void vop_plane_atomic_update(struct drm_plane *plane, > dsp_sty = dest->y1 + crtc->mode.vtotal - crtc->mode.vsync_start; > dsp_st = dsp_sty << 16 | (dsp_stx & 0xffff); > > - offset = (src->x1 >> 16) * fb->format->cpp[0]; > + if (fb->format->block_w[0]) > + offset = (src->x1 >> 16) * fb->format->char_per_block[0] / > + fb->format->block_w[0]; > + else > + offset = (src->x1 >> 16) * fb->format->cpp[0]; > + > offset += (src->y1 >> 16) * fb->pitches[0]; > dma_addr = rk_obj->dma_addr + offset + fb->offsets[0]; > > @@ -948,6 +966,7 @@ static void vop_plane_atomic_update(struct drm_plane *plane, > } > > VOP_WIN_SET(vop, win, format, format); > + VOP_WIN_SET(vop, win, fmt_10, is_fmt_10(fb->format->format)); > VOP_WIN_SET(vop, win, yrgb_vir, DIV_ROUND_UP(fb->pitches[0], 4)); > VOP_WIN_SET(vop, win, yrgb_mst, dma_addr); > VOP_WIN_YUV2YUV_SET(vop, win_yuv2yuv, y2r_en, is_yuv); > @@ -964,7 +983,11 @@ static void vop_plane_atomic_update(struct drm_plane *plane, > uv_obj = fb->obj[1]; > rk_uv_obj = to_rockchip_obj(uv_obj); > > - offset = (src->x1 >> 16) * bpp / hsub; > + if (fb->format->block_w[1]) > + offset = (src->x1 >> 16) * bpp / > + fb->format->block_w[1] / hsub; > + else > + offset = (src->x1 >> 16) * bpp / hsub; > offset += (src->y1 >> 16) * fb->pitches[1] / vsub; > > dma_addr = rk_uv_obj->dma_addr + offset + fb->offsets[1]; > diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.h b/drivers/gpu/drm/rockchip/rockchip_drm_vop.h > index d03bdb531ef2..db1138da2bd4 100644 > --- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.h > +++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.h > @@ -154,6 +154,7 @@ struct vop_win_phy { > struct vop_reg enable; > struct vop_reg gate; > struct vop_reg format; > + struct vop_reg fmt_10; > struct vop_reg rb_swap; > struct vop_reg act_info; > struct vop_reg dsp_info; > diff --git a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c > index 2413deded22c..503736c8b6c4 100644 > --- a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c > +++ b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c > @@ -50,6 +50,22 @@ static const uint32_t formats_win_full[] = { > DRM_FORMAT_NV24, > }; > > +static const uint32_t formats_win_full_10[] = { > + DRM_FORMAT_XRGB8888, > + DRM_FORMAT_ARGB8888, > + DRM_FORMAT_XBGR8888, > + DRM_FORMAT_ABGR8888, > + DRM_FORMAT_RGB888, > + DRM_FORMAT_BGR888, > + DRM_FORMAT_RGB565, > + DRM_FORMAT_BGR565, > + DRM_FORMAT_NV12, > + DRM_FORMAT_NV16, > + DRM_FORMAT_NV24, > + DRM_FORMAT_NV15, > + DRM_FORMAT_NV20, > +}; > + > static const uint64_t format_modifiers_win_full[] = { > DRM_FORMAT_MOD_LINEAR, > DRM_FORMAT_MOD_INVALID, > @@ -570,11 +586,12 @@ static const struct vop_scl_regs rk3288_win_full_scl = { > > static const struct vop_win_phy rk3288_win01_data = { > .scl = &rk3288_win_full_scl, > - .data_formats = formats_win_full, > - .nformats = ARRAY_SIZE(formats_win_full), > + .data_formats = formats_win_full_10, > + .nformats = ARRAY_SIZE(formats_win_full_10), > .format_modifiers = format_modifiers_win_full, > .enable = VOP_REG(RK3288_WIN0_CTRL0, 0x1, 0), > .format = VOP_REG(RK3288_WIN0_CTRL0, 0x7, 1), > + .fmt_10 = VOP_REG(RK3288_WIN0_CTRL0, 0x1, 4), > .rb_swap = VOP_REG(RK3288_WIN0_CTRL0, 0x1, 12), > .act_info = VOP_REG(RK3288_WIN0_ACT_INFO, 0x1fff1fff, 0), > .dsp_info = VOP_REG(RK3288_WIN0_DSP_INFO, 0x0fff0fff, 0), > @@ -704,11 +721,12 @@ static const struct vop_intr rk3368_vop_intr = { > > static const struct vop_win_phy rk3368_win01_data = { > .scl = &rk3288_win_full_scl, > - .data_formats = formats_win_full, > - .nformats = ARRAY_SIZE(formats_win_full), > + .data_formats = formats_win_full_10, > + .nformats = ARRAY_SIZE(formats_win_full_10), > .format_modifiers = format_modifiers_win_full, > .enable = VOP_REG(RK3368_WIN0_CTRL0, 0x1, 0), > .format = VOP_REG(RK3368_WIN0_CTRL0, 0x7, 1), > + .fmt_10 = VOP_REG(RK3368_WIN0_CTRL0, 0x1, 4), > .rb_swap = VOP_REG(RK3368_WIN0_CTRL0, 0x1, 12), > .x_mir_en = VOP_REG(RK3368_WIN0_CTRL0, 0x1, 21), > .y_mir_en = VOP_REG(RK3368_WIN0_CTRL0, 0x1, 22), > @@ -853,11 +871,12 @@ static const struct vop_win_yuv2yuv_data rk3399_vop_big_win_yuv2yuv_data[] = { > > static const struct vop_win_phy rk3399_win01_data = { > .scl = &rk3288_win_full_scl, > - .data_formats = formats_win_full, > - .nformats = ARRAY_SIZE(formats_win_full), > + .data_formats = formats_win_full_10, > + .nformats = ARRAY_SIZE(formats_win_full_10), > .format_modifiers = format_modifiers_win_full_afbc, > .enable = VOP_REG(RK3288_WIN0_CTRL0, 0x1, 0), > .format = VOP_REG(RK3288_WIN0_CTRL0, 0x7, 1), > + .fmt_10 = VOP_REG(RK3288_WIN0_CTRL0, 0x1, 4), > .rb_swap = VOP_REG(RK3288_WIN0_CTRL0, 0x1, 12), > .y_mir_en = VOP_REG(RK3288_WIN0_CTRL0, 0x1, 22), > .act_info = VOP_REG(RK3288_WIN0_ACT_INFO, 0x1fff1fff, 0), >