Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp767577imu; Sat, 17 Nov 2018 09:07:03 -0800 (PST) X-Google-Smtp-Source: AJdET5d4vfzzyQ4zvCpfaEa2cErh+lMAjEN6mWRBITYNXtzXSY2eg0K+DcqmFCA2KLzBdOTN2TN0 X-Received: by 2002:a63:65c7:: with SMTP id z190mr14231093pgb.249.1542474423197; Sat, 17 Nov 2018 09:07:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542474423; cv=none; d=google.com; s=arc-20160816; b=QRbavVvuUffvirjd4D97uN7Tow5kDMbHcZbYxwC+niqrGYvPgV7/mXAkZJRzf6QYxy aqnwoOgGEmx0gUmrGPfrvf7OCrtozC5EDHgs2ZZtOUjit0dQ+tE8Yd4/YL9OI5eELzLc boBTLhjAIA32k/4myZ5HHyCqOKpgffu5z7zXhIsKjM+itY8LrDkQsilxRHLsFOQAAbUD F8iHmNrXgmIXzu6+lGMuZK2VuSrtIsHplBIAJsbNHc1s6goMj29NwqZfViduNd2eOSoj 1Owz8THpAEqgSjBlVATpl0nQ5mtSi0qRPQtsHd3aT2sSij4L2DrzdaEMV2zUvhcF8q9q A4Gw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=qd3A6Sx1NtkJqX9Ristd1F5+tTs7ul5QO0Wc4pd/Q9c=; b=iHjtsXXlp6o3kBnJHHMSKs+06gCIar0tsT9AWq/vJQLq3yY7uUeAIwnrQebSDPDwUV rmVjiMaNRNRQpfPA5ah0PSyFe85DIRoS0A2pOFs6AQKhQEQj+a599aR1QaBzGhfbyyiQ gmYIVS2aKpkv1iDDWkZIfk68cZZZt9qJCpv7MGdTIIgSuxIMh00/A4u1D9QpWSS1Fp7H iMXItsQ6rqprwI9dNY0+x14jO8p+i6OdBxyC9oNbKjFl8kYVvDh6hfbgpq9Xizfz/hqg VROE0rQ6i1wKMBFjuS+Q/fAXg05/rdCMkPnngQtBKNSj8Ro7m5EJC1Vta/qK2HndYHuD CI5A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a5-v6si31135399plh.157.2018.11.17.09.06.48; Sat, 17 Nov 2018 09:07:03 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726808AbeKRDWJ (ORCPT + 99 others); Sat, 17 Nov 2018 22:22:09 -0500 Received: from kozue.soulik.info ([108.61.200.231]:45126 "EHLO kozue.soulik.info" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726311AbeKRDWJ (ORCPT ); Sat, 17 Nov 2018 22:22:09 -0500 Received: from misaki.sumomo.pri (unknown [192.168.0.134]) by kozue.soulik.info (Postfix) with ESMTPA id 6A4B81018EA; Sun, 18 Nov 2018 01:59:00 +0900 (JST) From: Randy Li To: dri-devel@lists.freedesktop.org Cc: linux-kernel@vger.kernel.org, hjc@rock-chips.com, heiko@sntech.de, airlied@linux.ie, linux-rockchip@lists.infradead.org, ayaka Subject: [PATCH] drm/rockchip: support hwc layer Date: Sun, 18 Nov 2018 00:58:16 +0800 Message-Id: <20181117165816.26152-1-ayaka@soulik.info> X-Mailer: git-send-email 2.14.5 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: ayaka The Windows 2/3 or a RGB UI layer is a high performance flexibly plane. It is too waste to use it as a cursor plane. I have verified this patch with weston git version, I am not sure whether X would meet with this patch. As the previous author is gone, I can't confirm this problem with him. Signed-off-by: Randy Li --- drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 30 +++++++++++++++++++++ drivers/gpu/drm/rockchip/rockchip_vop_reg.c | 42 ++++++++++++++++++++++++++--- 2 files changed, 68 insertions(+), 4 deletions(-) diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c index 9301006329e8..1103049da91f 100644 --- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c +++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c @@ -223,6 +223,16 @@ static bool has_rb_swapped(uint32_t format) } } +static bool is_yuv_10bit (uint32_t format) +{ + switch (format) { + case DRM_FORMAT_NV12_10LE40: + return true; + default: + return false; + }; +} + static enum vop_data_format vop_convert_format(uint32_t format) { switch (format) { @@ -755,6 +765,26 @@ static void vop_plane_atomic_update(struct drm_plane *plane, dsp_info = (drm_rect_height(dest) - 1) << 16; dsp_info |= (drm_rect_width(dest) - 1) & 0xffff; + /* HWC layer only supports various of square icon */ + if (plane->type == DRM_PLANE_TYPE_CURSOR) { + switch (actual_w) { + case 32: + dsp_info = 0; + break; + case 64: + dsp_info = 0x1; + break; + case 94: + dsp_info = 0x10; + break; + case 128: + dsp_info = 0x11; + break; + /* Unsupported pixel resolution */ + default: + return; + } + } dsp_stx = dest->x1 + crtc->mode.htotal - crtc->mode.hsync_start; dsp_sty = dest->y1 + crtc->mode.vtotal - crtc->mode.vsync_start; diff --git a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c index 6370f7d33273..0f7809511388 100644 --- a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c +++ b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c @@ -64,6 +64,15 @@ static const uint32_t formats_win_lite[] = { DRM_FORMAT_BGR565, }; +static const uint32_t formats_win_hwc[] = { + DRM_FORMAT_ARGB8888, + DRM_FORMAT_ABGR8888, + DRM_FORMAT_RGB888, + DRM_FORMAT_BGR888, + DRM_FORMAT_RGB565, + DRM_FORMAT_BGR565, +}; + static const struct vop_scl_regs rk3036_win_scl = { .scale_yrgb_x = VOP_REG(RK3036_WIN0_SCL_FACTOR_YRGB, 0xffff, 0x0), .scale_yrgb_y = VOP_REG(RK3036_WIN0_SCL_FACTOR_YRGB, 0xffff, 16), @@ -458,6 +467,19 @@ static const struct vop_win_phy rk3288_win23_data = { .dst_alpha_ctl = VOP_REG(RK3288_WIN2_DST_ALPHA_CTRL, 0xff, 0), }; +static const struct vop_win_phy rk3288_winhwc_data = { + .data_formats = formats_win_hwc, + .nformats = ARRAY_SIZE(formats_win_hwc), + .enable = VOP_REG(RK3288_HWC_CTRL0, 0x1, 0), + .format = VOP_REG(RK3288_HWC_CTRL0, 0x7, 1), + .rb_swap = VOP_REG(RK3288_HWC_CTRL0, 0x1, 12), + .dsp_info = VOP_REG(RK3288_HWC_CTRL0, 0x3, 5), + .dsp_st = VOP_REG(RK3288_HWC_DSP_ST, 0x1fff1fff, 0), + .yrgb_mst = VOP_REG(RK3288_HWC_MST, 0xffffffff, 0), + .src_alpha_ctl = VOP_REG(RK3288_HWC_SRC_ALPHA_CTRL, 0xffff, 0), + .dst_alpha_ctl = VOP_REG(RK3288_HWC_DST_ALPHA_CTRL, 0xffffffff, 0), +}; + static const struct vop_modeset rk3288_modeset = { .htotal_pw = VOP_REG(RK3288_DSP_HTOTAL_HS_END, 0x1fff1fff, 0), .hact_st_end = VOP_REG(RK3288_DSP_HACT_ST_END, 0x1fff1fff, 0), @@ -502,7 +524,10 @@ static const struct vop_win_data rk3288_vop_win_data[] = { { .base = 0x00, .phy = &rk3288_win23_data, .type = DRM_PLANE_TYPE_OVERLAY }, { .base = 0x50, .phy = &rk3288_win23_data, - .type = DRM_PLANE_TYPE_CURSOR }, + .type = DRM_PLANE_TYPE_OVERLAY }, + { .base = 0x00, .phy = &rk3288_winhwc_data, + .type = DRM_PLANE_TYPE_CURSOR, + }, }; static const int rk3288_vop_intrs[] = { @@ -575,7 +600,10 @@ static const struct vop_win_data rk3368_vop_win_data[] = { { .base = 0x00, .phy = &rk3368_win23_data, .type = DRM_PLANE_TYPE_OVERLAY }, { .base = 0x50, .phy = &rk3368_win23_data, - .type = DRM_PLANE_TYPE_CURSOR }, + .type = DRM_PLANE_TYPE_OVERLAY }, + { .base = 0x00, .phy = &rk3288_winhwc_data, + .type = DRM_PLANE_TYPE_CURSOR, + }, }; static const struct vop_output rk3368_output = { @@ -655,7 +683,10 @@ static const struct vop_win_data rk3399_vop_lit_win_data[] = { { .base = 0x00, .phy = &rk3288_win01_data, .type = DRM_PLANE_TYPE_PRIMARY }, { .base = 0x00, .phy = &rk3368_win23_data, - .type = DRM_PLANE_TYPE_CURSOR}, + .type = DRM_PLANE_TYPE_OVERLAY}, + { .base = 0x00, .phy = &rk3288_winhwc_data, + .type = DRM_PLANE_TYPE_CURSOR, + }, }; static const struct vop_data rk3399_vop_lit = { @@ -737,7 +768,10 @@ static const struct vop_win_data rk3328_vop_win_data[] = { { .base = 0x1d0, .phy = &rk3288_win01_data, .type = DRM_PLANE_TYPE_OVERLAY }, { .base = 0x2d0, .phy = &rk3288_win01_data, - .type = DRM_PLANE_TYPE_CURSOR }, + .type = DRM_PLANE_TYPE_OVERLAY }, + { .base = 0x00, .phy = &rk3288_winhwc_data, + .type = DRM_PLANE_TYPE_CURSOR, + }, }; static const struct vop_data rk3328_vop = { -- 2.14.5