Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3652575yba; Tue, 9 Apr 2019 01:44:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqw7B/LHFMDkQZQBtCNEdAPDFb0CrV+apsoOfKW+AYklCbg33e7l8Ekqd06oNgfYtvgFixTI X-Received: by 2002:a65:5941:: with SMTP id g1mr34138207pgu.51.1554799487682; Tue, 09 Apr 2019 01:44:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554799487; cv=none; d=google.com; s=arc-20160816; b=HhX13F/BRA34bUHqQwyJTw5T7b44eoxzeksoKUlaI0t2fQYR0/MmJRHmY2ur8wT8F3 XfKWcIfF9xjBgWM0qxRSzQpmR1EpNLodgiZ8ZpWqc+cX6qFo+FUrKwPqOIKO/f8lnfLd yYSDdd298ScFyW+iF0K+ajm0ItMcy+ryiU15wrqb1DaXqyLifM2qgWeigHKkLy4E6d+2 wPEzAjmDWI6O52dLbGHa3sKqC6o3Mg/1PCW/6DqTS7zlrXYlY8TkIYCrVpd42fkKfozm DcOe6x0aBe3DshNSvAZeqF0M8Tz2ze2k9OTqMpzkFcDdH+CjsT05BKJKnzmpXVKpGteU avDA== 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 :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=6yU1beVTiZA5Y8E6RSvLWzVxPUhIRK2bpkl1ZM5/TbQ=; b=OYPNDbqXxmOxLSD9/Y/cIabA3adqspJ8aaJ5RnS6GxEzhh/4/d7R2vXBBs6cPjH/V5 Bx9wcnx7afCT+z5bvOb/DiFUJE68TBODSjTtUY8gvpEb8CyY3C/oKJI0so3/JAfRbZBN RDi2JGq0GV8MqxzH+1zFOgN6BI2gNcV4W4lWDMe9MWWUtYMMQ5HlfLWSgbO1Sjau8vCf xIctS8p9N0BciFQkD6I7Ub4+bY1KImHFBzlRgGRZmXa5qYsi7wzxQiUZ4gYaQ6WuhCCs l2JrXTaSnOcb8pZxWbxTVmFvZ5SfaRLfTTOIa6nWrCKyQfHqGWxpfio4QP6FtWVHPXYQ kiIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b="n/RO6lKS"; 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 r8si10900365pls.16.2019.04.09.01.44.32; Tue, 09 Apr 2019 01:44:47 -0700 (PDT) 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; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b="n/RO6lKS"; 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 S1726860AbfDIInZ (ORCPT + 99 others); Tue, 9 Apr 2019 04:43:25 -0400 Received: from mail-wm1-f67.google.com ([209.85.128.67]:51608 "EHLO mail-wm1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726062AbfDIInZ (ORCPT ); Tue, 9 Apr 2019 04:43:25 -0400 Received: by mail-wm1-f67.google.com with SMTP id 4so2439013wmf.1 for ; Tue, 09 Apr 2019 01:43:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=message-id:subject:from:to:cc:date:in-reply-to:references :user-agent:mime-version:content-transfer-encoding; bh=6yU1beVTiZA5Y8E6RSvLWzVxPUhIRK2bpkl1ZM5/TbQ=; b=n/RO6lKSQz7gNw/MRpM2eEf4VyuUZYoTxgmC6Hd/YbcMR9B7srAcW3Z37t4IqeHJWx kX7QaBVsYkcaPgmG0KGPdYXHm9ksp4R60Zk1ZULcLFglGNvBNpHWSgVbg+4GMKVNqitv dcYntqyEvA8PBzj0x0p9bOjKgF7rfqkpS0qM6rWU1m0GAXsHptiCvcCMPx4mhWZCIE1J uxrRqw5lgmfUvvqi/C4DBL6kgrd/V5ACVPYFwz2Gz4FZBZBV/PimW5Crq663elh+Cis/ Xl+ZQz3iy6Vp+1y6KI5UF2VWRArTx0l1f8wnsOWkObzVMCU/HRGjAgDEMUEmyZTFCWF3 ZTEg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:message-id:subject:from:to:cc:date:in-reply-to :references:user-agent:mime-version:content-transfer-encoding; bh=6yU1beVTiZA5Y8E6RSvLWzVxPUhIRK2bpkl1ZM5/TbQ=; b=mxl3WGflGythonWpZ02OAJZBfL3tjdk9L+kEQKQ27sxM+ARf6vsrDF0X62Qw29z842 Vb78VSswuzaOyvL+WvBM87RBttNa5Q2JDfxBITBtSsmd8k5OBXhHjB/uP5tBwIXmo4Cn 9qdTrfNE8EJI3I0+WzrR6V/UPWVoLrXhhzrqD/7nlqhg4JWlJUOPi1+0VM5yMdyfLqHz 2EeQJH1kM906U+fyOVvPWqyMpThe7riN0pBGqW5G+f69JfWGQB1oMgYYERVckQcpQjgp JVYinHNHdISZIR0KvuVrmTVeOu+X70CjiXThqeKj56H9f0XYBaV0zZqQFwXRixWZqMb8 rA5g== X-Gm-Message-State: APjAAAXv61n20RUWTegMDWehAYQ4UZM1yW9TcGgmZnZspkcGhqgNvsSK fuc3m5sXmVvEwfFg/LVD0YBcFQ== X-Received: by 2002:a1c:2b41:: with SMTP id r62mr21681999wmr.94.1554799402717; Tue, 09 Apr 2019 01:43:22 -0700 (PDT) Received: from boomer.baylibre.com ([2a01:e34:eeb6:4690:106b:bae3:31ed:7561]) by smtp.gmail.com with ESMTPSA id z140sm22267423wmc.27.2019.04.09.01.43.21 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Tue, 09 Apr 2019 01:43:21 -0700 (PDT) Message-ID: <783a13d05378fb29738933572b80ca15b375c565.camel@baylibre.com> Subject: Re: [PATCH 07/11] drm/meson: Add G12A support for plane handling in CRTC driver From: Jerome Brunet To: Neil Armstrong , dri-devel@lists.freedesktop.org Cc: linux-amlogic@lists.infradead.org, linux-kernel@vger.kernel.org Date: Tue, 09 Apr 2019 10:43:20 +0200 In-Reply-To: <20190325141824.21259-8-narmstrong@baylibre.com> References: <20190325141824.21259-1-narmstrong@baylibre.com> <20190325141824.21259-8-narmstrong@baylibre.com> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.30.5 (3.30.5-1.fc29) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2019-03-25 at 15:18 +0100, Neil Armstrong wrote: > This patch adds support for the new OSD+VD Plane blending module > in the CRTC code by adding the G12A code to manage the blending > module and setting the right OSD1 & VD1 plane registers. > > Signed-off-by: Neil Armstrong > --- > drivers/gpu/drm/meson/meson_crtc.c | 269 +++++++++++++++++++++++------ > drivers/gpu/drm/meson/meson_drv.h | 4 + > 2 files changed, 221 insertions(+), 52 deletions(-) > > diff --git a/drivers/gpu/drm/meson/meson_crtc.c b/drivers/gpu/drm/meson/meson_crtc.c > index 6d9311e254ef..5579f8ac3e3f 100644 > --- a/drivers/gpu/drm/meson/meson_crtc.c > +++ b/drivers/gpu/drm/meson/meson_crtc.c > @@ -39,12 +39,17 @@ > #include "meson_viu.h" > #include "meson_registers.h" > > +#define MESON_G12A_VIU_OFFSET 0x5ec0 > + > /* CRTC definition */ > > struct meson_crtc { > struct drm_crtc base; > struct drm_pending_vblank_event *event; > struct meson_drm *priv; > + void (*enable_osd1)(struct meson_drm *priv); > + void (*enable_vd1)(struct meson_drm *priv); > + unsigned int viu_offset; > }; > #define to_meson_crtc(x) container_of(x, struct meson_crtc, base) > > @@ -80,6 +85,44 @@ static const struct drm_crtc_funcs meson_crtc_funcs = { > > }; > > +static void meson_g12a_crtc_atomic_enable(struct drm_crtc *crtc, > + struct drm_crtc_state *old_state) > +{ > + struct meson_crtc *meson_crtc = to_meson_crtc(crtc); > + struct drm_crtc_state *crtc_state = crtc->state; > + struct meson_drm *priv = meson_crtc->priv; > + > + DRM_DEBUG_DRIVER("\n"); > + > + if (!crtc_state) { > + DRM_ERROR("Invalid crtc_state\n"); > + return; > + } > + > + /* VD1 Preblend vertical start/end */ > + writel(FIELD_PREP(GENMASK(11, 0), 2303), Could could define this mask somewhere I don't know if the 2303 can be explained. I'd nice if it could > + priv->io_base + _REG(VPP_PREBLEND_VD1_V_START_END)); > + > + /* Setup Blender */ > + writel(crtc_state->mode.hdisplay | > + crtc_state->mode.vdisplay << 16, > + priv->io_base + _REG(VPP_POSTBLEND_H_SIZE)); > + > + writel_relaxed(0 << 16 | this 16 shift seems to be used for hdisplay or something. Could define/document it a bit > + (crtc_state->mode.hdisplay - 1), > + priv->io_base + _REG(VPP_OSD1_BLD_H_SCOPE)); > + writel_relaxed(0 << 16 | > + (crtc_state->mode.vdisplay - 1), > + priv->io_base + _REG(VPP_OSD1_BLD_V_SCOPE)); > + writel_relaxed(crtc_state->mode.hdisplay << 16 | > + crtc_state->mode.vdisplay, > + priv->io_base + _REG(VPP_OUT_H_V_SIZE)); > + > + drm_crtc_vblank_on(crtc); > + > + priv->viu.osd1_enabled = true; > +} > + > static void meson_crtc_atomic_enable(struct drm_crtc *crtc, > struct drm_crtc_state *old_state) > { > @@ -110,6 +153,31 @@ static void meson_crtc_atomic_enable(struct drm_crtc *crtc, > priv->viu.osd1_enabled = true; > } > > +static void meson_g12a_crtc_atomic_disable(struct drm_crtc *crtc, > + struct drm_crtc_state *old_state) > +{ > + struct meson_crtc *meson_crtc = to_meson_crtc(crtc); > + struct meson_drm *priv = meson_crtc->priv; > + > + DRM_DEBUG_DRIVER("\n"); > + > + drm_crtc_vblank_off(crtc); > + > + priv->viu.osd1_enabled = false; > + priv->viu.osd1_commit = false; > + > + priv->viu.vd1_enabled = false; > + priv->viu.vd1_commit = false; > + > + if (crtc->state->event && !crtc->state->active) { > + spin_lock_irq(&crtc->dev->event_lock); > + drm_crtc_send_vblank_event(crtc, crtc->state->event); > + spin_unlock_irq(&crtc->dev->event_lock); > + > + crtc->state->event = NULL; > + } > +} > + > static void meson_crtc_atomic_disable(struct drm_crtc *crtc, > struct drm_crtc_state *old_state) > { > @@ -173,6 +241,53 @@ static const struct drm_crtc_helper_funcs meson_crtc_helper_funcs = { > .atomic_disable = meson_crtc_atomic_disable, > }; > > +static const struct drm_crtc_helper_funcs meson_g12a_crtc_helper_funcs = { > + .atomic_begin = meson_crtc_atomic_begin, > + .atomic_flush = meson_crtc_atomic_flush, > + .atomic_enable = meson_g12a_crtc_atomic_enable, > + .atomic_disable = meson_g12a_crtc_atomic_disable, > +}; > + > +static void meson_crtc_enable_osd1(struct meson_drm *priv) > +{ > + writel_bits_relaxed(VPP_OSD1_POSTBLEND, VPP_OSD1_POSTBLEND, > + priv->io_base + _REG(VPP_MISC)); > +} > + > +static void meson_g12a_crtc_enable_osd1(struct meson_drm *priv) > +{ > + writel_relaxed(priv->viu.osd_blend_din0_scope_h, > + priv->io_base + > + _REG(VIU_OSD_BLEND_DIN0_SCOPE_H)); > + writel_relaxed(priv->viu.osd_blend_din0_scope_v, > + priv->io_base + > + _REG(VIU_OSD_BLEND_DIN0_SCOPE_V)); > + writel_relaxed(priv->viu.osb_blend0_size, > + priv->io_base + > + _REG(VIU_OSD_BLEND_BLEND0_SIZE)); > + writel_relaxed(priv->viu.osb_blend1_size, > + priv->io_base + > + _REG(VIU_OSD_BLEND_BLEND1_SIZE)); > +} > + > +static void meson_crtc_enable_vd1(struct meson_drm *priv) > +{ > + writel_bits_relaxed(VPP_VD1_PREBLEND | VPP_VD1_POSTBLEND | > + VPP_COLOR_MNG_ENABLE, > + VPP_VD1_PREBLEND | VPP_VD1_POSTBLEND | > + VPP_COLOR_MNG_ENABLE, > + priv->io_base + _REG(VPP_MISC)); > +} > + > +static void meson_g12a_crtc_enable_vd1(struct meson_drm *priv) > +{ > + writel_relaxed(((1 << 16) | /* post bld premult*/ > + (1 << 8) | /* post src */ > + (1 << 4) | /* pre bld premult*/ > + (1 << 0)), Could you use the BIT() macro here and possibly some defines ? > + priv->io_base + _REG(VD1_BLEND_SRC_CTRL)); > +} > + > void meson_crtc_irq(struct meson_drm *priv) > { > struct meson_crtc *meson_crtc = to_meson_crtc(priv->crtc); > @@ -219,8 +334,8 @@ void meson_crtc_irq(struct meson_drm *priv) > MESON_CANVAS_BLKMODE_LINEAR, 0); > > /* Enable OSD1 */ > - writel_bits_relaxed(VPP_OSD1_POSTBLEND, VPP_OSD1_POSTBLEND, > - priv->io_base + _REG(VPP_MISC)); > + if (meson_crtc->enable_osd1) > + meson_crtc->enable_osd1(priv); > > priv->viu.osd1_commit = false; > } > @@ -261,89 +376,133 @@ void meson_crtc_irq(struct meson_drm *priv) > }; > > writel_relaxed(priv->viu.vd1_if0_gen_reg, > - priv->io_base + _REG(VD1_IF0_GEN_REG)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_GEN_REG)); Could you make a local variable for priv->io_base + meson_crtc->viu_offset ? It would be a little easier to read > writel_relaxed(priv->viu.vd1_if0_gen_reg, > - priv->io_base + _REG(VD2_IF0_GEN_REG)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_GEN_REG)); > writel_relaxed(priv->viu.vd1_if0_gen_reg2, > - priv->io_base + _REG(VD1_IF0_GEN_REG2)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_GEN_REG2)); > writel_relaxed(priv->viu.viu_vd1_fmt_ctrl, > - priv->io_base + _REG(VIU_VD1_FMT_CTRL)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VIU_VD1_FMT_CTRL)); > writel_relaxed(priv->viu.viu_vd1_fmt_ctrl, > - priv->io_base + _REG(VIU_VD2_FMT_CTRL)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VIU_VD2_FMT_CTRL)); > writel_relaxed(priv->viu.viu_vd1_fmt_w, > - priv->io_base + _REG(VIU_VD1_FMT_W)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VIU_VD1_FMT_W)); > writel_relaxed(priv->viu.viu_vd1_fmt_w, > - priv->io_base + _REG(VIU_VD2_FMT_W)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VIU_VD2_FMT_W)); > writel_relaxed(priv->viu.vd1_if0_canvas0, > - priv->io_base + _REG(VD1_IF0_CANVAS0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CANVAS0)); > writel_relaxed(priv->viu.vd1_if0_canvas0, > - priv->io_base + _REG(VD1_IF0_CANVAS1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CANVAS1)); > writel_relaxed(priv->viu.vd1_if0_canvas0, > - priv->io_base + _REG(VD2_IF0_CANVAS0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CANVAS0)); > writel_relaxed(priv->viu.vd1_if0_canvas0, > - priv->io_base + _REG(VD2_IF0_CANVAS1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CANVAS1)); > writel_relaxed(priv->viu.vd1_if0_luma_x0, > - priv->io_base + _REG(VD1_IF0_LUMA_X0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_LUMA_X0)); > writel_relaxed(priv->viu.vd1_if0_luma_x0, > - priv->io_base + _REG(VD1_IF0_LUMA_X1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_LUMA_X1)); > writel_relaxed(priv->viu.vd1_if0_luma_x0, > - priv->io_base + _REG(VD2_IF0_LUMA_X0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_LUMA_X0)); > writel_relaxed(priv->viu.vd1_if0_luma_x0, > - priv->io_base + _REG(VD2_IF0_LUMA_X1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_LUMA_X1)); > writel_relaxed(priv->viu.vd1_if0_luma_y0, > - priv->io_base + _REG(VD1_IF0_LUMA_Y0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_LUMA_Y0)); > writel_relaxed(priv->viu.vd1_if0_luma_y0, > - priv->io_base + _REG(VD1_IF0_LUMA_Y1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_LUMA_Y1)); > writel_relaxed(priv->viu.vd1_if0_luma_y0, > - priv->io_base + _REG(VD2_IF0_LUMA_Y0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_LUMA_Y0)); > writel_relaxed(priv->viu.vd1_if0_luma_y0, > - priv->io_base + _REG(VD2_IF0_LUMA_Y1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_LUMA_Y1)); > writel_relaxed(priv->viu.vd1_if0_chroma_x0, > - priv->io_base + _REG(VD1_IF0_CHROMA_X0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CHROMA_X0)); > writel_relaxed(priv->viu.vd1_if0_chroma_x0, > - priv->io_base + _REG(VD1_IF0_CHROMA_X1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CHROMA_X1)); > writel_relaxed(priv->viu.vd1_if0_chroma_x0, > - priv->io_base + _REG(VD2_IF0_CHROMA_X0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CHROMA_X0)); > writel_relaxed(priv->viu.vd1_if0_chroma_x0, > - priv->io_base + _REG(VD2_IF0_CHROMA_X1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CHROMA_X1)); > writel_relaxed(priv->viu.vd1_if0_chroma_y0, > - priv->io_base + _REG(VD1_IF0_CHROMA_Y0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CHROMA_Y0)); > writel_relaxed(priv->viu.vd1_if0_chroma_y0, > - priv->io_base + _REG(VD1_IF0_CHROMA_Y1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CHROMA_Y1)); > writel_relaxed(priv->viu.vd1_if0_chroma_y0, > - priv->io_base + _REG(VD2_IF0_CHROMA_Y0)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CHROMA_Y0)); > writel_relaxed(priv->viu.vd1_if0_chroma_y0, > - priv->io_base + _REG(VD2_IF0_CHROMA_Y1)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CHROMA_Y1)); > writel_relaxed(priv->viu.vd1_if0_repeat_loop, > - priv->io_base + _REG(VD1_IF0_RPT_LOOP)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_RPT_LOOP)); > writel_relaxed(priv->viu.vd1_if0_repeat_loop, > - priv->io_base + _REG(VD2_IF0_RPT_LOOP)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_RPT_LOOP)); > writel_relaxed(priv->viu.vd1_if0_luma0_rpt_pat, > - priv->io_base + _REG(VD1_IF0_LUMA0_RPT_PAT)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_LUMA0_RPT_PAT)); > writel_relaxed(priv->viu.vd1_if0_luma0_rpt_pat, > - priv->io_base + _REG(VD2_IF0_LUMA0_RPT_PAT)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_LUMA0_RPT_PAT)); > writel_relaxed(priv->viu.vd1_if0_luma0_rpt_pat, > - priv->io_base + _REG(VD1_IF0_LUMA1_RPT_PAT)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_LUMA1_RPT_PAT)); > writel_relaxed(priv->viu.vd1_if0_luma0_rpt_pat, > - priv->io_base + _REG(VD2_IF0_LUMA1_RPT_PAT)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_LUMA1_RPT_PAT)); > writel_relaxed(priv->viu.vd1_if0_chroma0_rpt_pat, > - priv->io_base + _REG(VD1_IF0_CHROMA0_RPT_PAT)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CHROMA0_RPT_PAT)); > writel_relaxed(priv->viu.vd1_if0_chroma0_rpt_pat, > - priv->io_base + _REG(VD2_IF0_CHROMA0_RPT_PAT)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CHROMA0_RPT_PAT)); > writel_relaxed(priv->viu.vd1_if0_chroma0_rpt_pat, > - priv->io_base + _REG(VD1_IF0_CHROMA1_RPT_PAT)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CHROMA1_RPT_PAT)); > writel_relaxed(priv->viu.vd1_if0_chroma0_rpt_pat, > - priv->io_base + _REG(VD2_IF0_CHROMA1_RPT_PAT)); > - writel_relaxed(0, priv->io_base + _REG(VD1_IF0_LUMA_PSEL)); > - writel_relaxed(0, priv->io_base + _REG(VD1_IF0_CHROMA_PSEL)); > - writel_relaxed(0, priv->io_base + _REG(VD2_IF0_LUMA_PSEL)); > - writel_relaxed(0, priv->io_base + _REG(VD2_IF0_CHROMA_PSEL)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CHROMA1_RPT_PAT)); > + writel_relaxed(0, priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_LUMA_PSEL)); > + writel_relaxed(0, priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_CHROMA_PSEL)); > + writel_relaxed(0, priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_LUMA_PSEL)); > + writel_relaxed(0, priv->io_base + meson_crtc->viu_offset + > + _REG(VD2_IF0_CHROMA_PSEL)); > writel_relaxed(priv->viu.vd1_range_map_y, > - priv->io_base + _REG(VD1_IF0_RANGE_MAP_Y)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_RANGE_MAP_Y)); > writel_relaxed(priv->viu.vd1_range_map_cb, > - priv->io_base + _REG(VD1_IF0_RANGE_MAP_CB)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_RANGE_MAP_CB)); > writel_relaxed(priv->viu.vd1_range_map_cr, > - priv->io_base + _REG(VD1_IF0_RANGE_MAP_CR)); > + priv->io_base + meson_crtc->viu_offset + > + _REG(VD1_IF0_RANGE_MAP_CR)); > writel_relaxed(0x78404, > priv->io_base + _REG(VPP_SC_MISC)); > writel_relaxed(priv->viu.vpp_pic_in_height, > @@ -389,11 +548,8 @@ void meson_crtc_irq(struct meson_drm *priv) > writel_relaxed(0x42, priv->io_base + _REG(VPP_SCALE_COEF_IDX)); > > /* Enable VD1 */ > - writel_bits_relaxed(VPP_VD1_PREBLEND | VPP_VD1_POSTBLEND | > - VPP_COLOR_MNG_ENABLE, > - VPP_VD1_PREBLEND | VPP_VD1_POSTBLEND | > - VPP_COLOR_MNG_ENABLE, > - priv->io_base + _REG(VPP_MISC)); > + if (meson_crtc->enable_vd1) > + meson_crtc->enable_vd1(priv); > > priv->viu.vd1_commit = false; > } > @@ -430,7 +586,16 @@ int meson_crtc_create(struct meson_drm *priv) > return ret; > } > > - drm_crtc_helper_add(crtc, &meson_crtc_helper_funcs); > + if (meson_vpu_is_compatible(priv, "amlogic,meson-g12a-vpu")) { > + meson_crtc->enable_osd1 = meson_g12a_crtc_enable_osd1; > + meson_crtc->enable_vd1 = meson_g12a_crtc_enable_vd1; > + meson_crtc->viu_offset = MESON_G12A_VIU_OFFSET; > + drm_crtc_helper_add(crtc, &meson_g12a_crtc_helper_funcs); > + } else { > + meson_crtc->enable_osd1 = meson_crtc_enable_osd1; > + meson_crtc->enable_vd1 = meson_crtc_enable_vd1; > + drm_crtc_helper_add(crtc, &meson_crtc_helper_funcs); > + } > > priv->crtc = crtc; > > diff --git a/drivers/gpu/drm/meson/meson_drv.h b/drivers/gpu/drm/meson/meson_drv.h > index 214a7cb18ce2..9614baa836b9 100644 > --- a/drivers/gpu/drm/meson/meson_drv.h > +++ b/drivers/gpu/drm/meson/meson_drv.h > @@ -62,6 +62,10 @@ struct meson_drm { > uint32_t osd_sc_h_phase_step; > uint32_t osd_sc_h_ctrl0; > uint32_t osd_sc_v_ctrl0; > + uint32_t osd_blend_din0_scope_h; > + uint32_t osd_blend_din0_scope_v; > + uint32_t osb_blend0_size; > + uint32_t osb_blend1_size; > > bool vd1_enabled; > bool vd1_commit;