Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp6703124imm; Tue, 24 Jul 2018 01:19:31 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcddcz3cKDLPP/LQoQXZ08N2tU5ZZSeok8etHkMhF9W7TW95mGjQEDPa2FHxGuO63DlHKiD X-Received: by 2002:a17:902:6ac7:: with SMTP id i7-v6mr16386242plt.288.1532420371360; Tue, 24 Jul 2018 01:19:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532420371; cv=none; d=google.com; s=arc-20160816; b=CtfhXlghvOfcB4HTvftq/lxptiK8cWVYi2DQYezF1C5oQaaMgZhJZivClIdfhQp/ue 8jAyZOmdCM6T+02yLMgIuoYhPimbHf/RZ/v7OcptnxkfGgBodE6fHE+u1jq+D8ieeWUB hNEhfL6J+zSfTDbgonOBbKUUNqEvxbzkB/cyxUOy10UOcoSIb6xFoAV4zBBCZSJ7277u LdHAJB06RckHQ2/zK7SfdDE9Y+I2Rr2V8FUKBsEkI/dDXsI5TCh8FuMHbrSIibIi5IR3 0VURgiLc6QMe+/H6blY7WCv64Ol0FIpcgc8tiweFjQWlPBeBIDwf3tpZX/I1ZWFmkuP2 Hyrw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:arc-authentication-results; bh=r1TcLwDjlep8xOT+jVwg6pfcVMic5r+QfSehBl+iANM=; b=joDtxmfe+Qsg+1zncZTg29mxuzSTVIaIOYD0rxQoLjugry5rOXYqXXvLvuseWkxJXg RvsQerRA5sfg8e9StSay3VzAkgcJPAqkjjXCidUE7qb9kD7uTI4q/ffBupSdNTk/Xlyn P/XxyZlOSkecdXKykzoJj5JWrpr+5YCZ9qZm2liBsngWIXfP/rEe0SZkggvvG1PMCLD+ hnhRdQC3Wx01eXywYD1TRRqKtKMX1dV7fKFLHu1VxuoMzLOQIv/q3t6TZxJ5QKwra5WF 7zbqzzUxPZ62S2VjgFLThBtIoo0EZoioTC2DtPcqabrahL3Pn5dUksq1WzrT4VjzVtpF MxBA== 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 t66-v6si10848751pfg.292.2018.07.24.01.19.16; Tue, 24 Jul 2018 01:19:31 -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; 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 S2388717AbeGXJWs (ORCPT + 99 others); Tue, 24 Jul 2018 05:22:48 -0400 Received: from mailgw02.mediatek.com ([210.61.82.184]:11920 "EHLO mailgw02.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S2388673AbeGXJWr (ORCPT ); Tue, 24 Jul 2018 05:22:47 -0400 X-UUID: 9b0e6666a3e84016ae7c9b564f143add-20180724 Received: from mtkcas06.mediatek.inc [(172.21.101.30)] by mailgw02.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 584516807; Tue, 24 Jul 2018 16:17:25 +0800 Received: from mtkcas07.mediatek.inc (172.21.101.84) by mtkmbs01n1.mediatek.inc (172.21.101.68) with Microsoft SMTP Server (TLS) id 15.0.1210.3; Tue, 24 Jul 2018 16:17:21 +0800 Received: from mtksdccf07.mediatek.inc (172.21.84.99) by mtkcas07.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1210.3 via Frontend Transport; Tue, 24 Jul 2018 16:17:20 +0800 From: Stu Hsieh To: CK Hu , Philipp Zabel CC: David Airlie , Matthias Brugger , , , , , , Stu Hsieh Subject: [PATCH v1 05/15] drm/mediatek: add RDMA memory mode for crtc created Date: Tue, 24 Jul 2018 16:17:05 +0800 Message-ID: <1532420235-22268-6-git-send-email-stu.hsieh@mediatek.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1532420235-22268-1-git-send-email-stu.hsieh@mediatek.com> References: <1532420235-22268-1-git-send-email-stu.hsieh@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch add RDMA memory mode for crtc created For mt2712, the third ddp use RDMA engine to read data from dram. Therefore, when crtc created, crtc need to decide using OVL or RDMA by ddp to read data from dram. If this ddp use RDMA, the crtc should set this RDMA which in the crtc using memory mode. Signed-off-by: Stu Hsieh --- drivers/gpu/drm/mediatek/mtk_disp_rdma.c | 5 ++++- drivers/gpu/drm/mediatek/mtk_drm_crtc.c | 8 ++++++++ drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h | 1 + 3 files changed, 13 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/mediatek/mtk_disp_rdma.c b/drivers/gpu/drm/mediatek/mtk_disp_rdma.c index 585943c81e1f..60851bb2dd63 100644 --- a/drivers/gpu/drm/mediatek/mtk_disp_rdma.c +++ b/drivers/gpu/drm/mediatek/mtk_disp_rdma.c @@ -150,6 +150,7 @@ static int mtk_disp_rdma_bind(struct device *dev, struct device *master, void *data) { struct mtk_disp_rdma *priv = dev_get_drvdata(dev); + struct mtk_ddp_comp *comp = &priv->ddp_comp; struct drm_device *drm_dev = data; int ret; @@ -160,8 +161,10 @@ static int mtk_disp_rdma_bind(struct device *dev, struct device *master, return ret; } - return 0; + comp->comp_mode = &priv->rdma_memory_mode; + + return 0; } static void mtk_disp_rdma_unbind(struct device *dev, struct device *master, diff --git a/drivers/gpu/drm/mediatek/mtk_drm_crtc.c b/drivers/gpu/drm/mediatek/mtk_drm_crtc.c index 2d6aa150a9ff..4bf636e466f2 100644 --- a/drivers/gpu/drm/mediatek/mtk_drm_crtc.c +++ b/drivers/gpu/drm/mediatek/mtk_drm_crtc.c @@ -578,6 +578,7 @@ int mtk_drm_crtc_create(struct drm_device *drm_dev, enum mtk_ddp_comp_id comp_id = path[i]; struct mtk_ddp_comp *comp; struct device_node *node; + bool *rdma_memory_mode; node = priv->comp_node[comp_id]; comp = priv->ddp_comp[comp_id]; @@ -595,6 +596,13 @@ int mtk_drm_crtc_create(struct drm_device *drm_dev, goto unprepare; } + if (i == 0 && (comp_id == DDP_COMPONENT_RDMA0 || + comp_id == DDP_COMPONENT_RDMA1 || + comp_id == DDP_COMPONENT_RDMA2)) { + rdma_memory_mode = comp->comp_mode; + *rdma_memory_mode = true; + } + mtk_crtc->ddp_comp[i] = comp; } diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h index 7413ffeb3c9d..a1988ce15141 100644 --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h @@ -93,6 +93,7 @@ struct mtk_ddp_comp { struct device *larb_dev; enum mtk_ddp_comp_id id; const struct mtk_ddp_comp_funcs *funcs; + void *comp_mode; }; static inline void mtk_ddp_comp_config(struct mtk_ddp_comp *comp, -- 2.12.5