Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp642727ybl; Wed, 14 Aug 2019 03:50:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqyLMneRBit7EWVRukYcEC5Q0G3glu/KTW/11I87y6Y5D41vzGO2ZYz1OV/5GOcICPi3S+Jp X-Received: by 2002:aa7:8e10:: with SMTP id c16mr44725854pfr.124.1565779816530; Wed, 14 Aug 2019 03:50:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565779816; cv=none; d=google.com; s=arc-20160816; b=y9jhLjSQCOFxCs7GdezKbkoKOhQnOJnKekFzu6Bd31iUtq73EvW/y1MV5q8KsdR2cO VhtlB7ZgRGjSJ9PbqgI69J+VSAz0rWW+hywm/adKkvrig/YZtVV9Uu7YaAxfTg1j3ZEB Jl+w2LtYp+4IuLTF1bZcKIt3IcuXyJYrBgnZ4Pc4HbOe/mN5DM7wDuD2JtzmkfbhPEhn HxAG3Du/DnVCLGlyiuDh06LV3D0oDvHZ6PM7rZkdXOKNg8kVhpEb8gQkwE13o410X7zc vhBvxLnq4EgBYXruEurddO+neHxUUIHu0mbq8jWgk7qxzPaui0jqYlyvNyO1O2G+kZTE o1fg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=tOM0XWB5dD8aR7FWrM+g6vjivenzLyu/xfDHBXPd094=; b=joMiSMgtU9VRwL7H2qBjLc6jy1xmBLVKvPN56fSNs8hPtk5qEKqJ+9owmhH0+g/yFX 9PpndqZ3iE9yuO3WPj7LHzuFZjS3b7Q/545WzcFuVf80MBZicE6xmnAzEsf0hQKlf7BZ H8aKvpHzUG5xR6yV7me5ZtbXxbZqyEi0zh+GpRcY9rAVdMKTvG7FsWB/RmtZn/RWUJvO OZEIWfOvABnO2e4JwLj2mHv859I2jdlC59lb5NOd2Y5ed0GBjyl8Fr05MITeZ65CzmdO mD0V2Db3A+QzfQrVsv2Ux8D+iXJtgLDEBCgys7I+B+/ftB9rgvg6VgZIsNe0XssTarRB nvJA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j191si68197846pgd.88.2019.08.14.03.50.01; Wed, 14 Aug 2019 03:50:16 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728018AbfHNKtM (ORCPT + 99 others); Wed, 14 Aug 2019 06:49:12 -0400 Received: from inva020.nxp.com ([92.121.34.13]:55340 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727883AbfHNKtK (ORCPT ); Wed, 14 Aug 2019 06:49:10 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 4AE281A039B; Wed, 14 Aug 2019 12:49:08 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 3E6821A039F; Wed, 14 Aug 2019 12:49:08 +0200 (CEST) Received: from fsr-ub1664-120.ea.freescale.net (fsr-ub1664-120.ea.freescale.net [10.171.82.81]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id 33F602060E; Wed, 14 Aug 2019 12:49:07 +0200 (CEST) From: Robert Chiras To: =?UTF-8?q?Guido=20G=C3=BCnther?= , Marek Vasut , Stefan Agner , David Airlie , Daniel Vetter , Rob Herring , Mark Rutland , Shawn Guo , Sascha Hauer , Fabio Estevam Cc: Pengutronix Kernel Team , NXP Linux Team , dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 11/15] drm/mxsfb: Update mxsfb to support LCD reset Date: Wed, 14 Aug 2019 13:48:47 +0300 Message-Id: <1565779731-1300-12-git-send-email-robert.chiras@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1565779731-1300-1-git-send-email-robert.chiras@nxp.com> References: <1565779731-1300-1-git-send-email-robert.chiras@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The eLCDIF controller has control pin for the external LCD reset pin. Add support for it and assert this pin in enable and de-assert it in disable. Signed-off-by: Robert Chiras --- drivers/gpu/drm/mxsfb/mxsfb_crtc.c | 14 ++++++++++---- drivers/gpu/drm/mxsfb/mxsfb_regs.h | 2 ++ 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/drivers/gpu/drm/mxsfb/mxsfb_crtc.c b/drivers/gpu/drm/mxsfb/mxsfb_crtc.c index 1be29f5..a4ba368 100644 --- a/drivers/gpu/drm/mxsfb/mxsfb_crtc.c +++ b/drivers/gpu/drm/mxsfb/mxsfb_crtc.c @@ -224,9 +224,12 @@ static void mxsfb_enable_controller(struct mxsfb_drm_private *mxsfb) clk_prepare_enable(mxsfb->clk_disp_axi); clk_prepare_enable(mxsfb->clk); - if (mxsfb->devdata->ipversion >= 4) + if (mxsfb->devdata->ipversion >= 4) { writel(CTRL2_OUTSTANDING_REQS(REQ_16), mxsfb->base + LCDC_V4_CTRL2 + REG_SET); + /* Assert LCD Reset bit */ + writel(CTRL2_LCD_RESET, mxsfb->base + LCDC_V4_CTRL2 + REG_SET); + } /* If it was disabled, re-enable the mode again */ writel(CTRL_DOTCLK_MODE, mxsfb->base + LCDC_CTRL + REG_SET); @@ -244,11 +247,14 @@ static void mxsfb_disable_controller(struct mxsfb_drm_private *mxsfb) { u32 reg; - if (mxsfb->devdata->ipversion >= 4) + writel(CTRL_RUN, mxsfb->base + LCDC_CTRL + REG_CLR); + + if (mxsfb->devdata->ipversion >= 4) { writel(CTRL2_OUTSTANDING_REQS(0x7), mxsfb->base + LCDC_V4_CTRL2 + REG_CLR); - - writel(CTRL_RUN, mxsfb->base + LCDC_CTRL + REG_CLR); + /* De-assert LCD Reset bit */ + writel(CTRL2_LCD_RESET, mxsfb->base + LCDC_V4_CTRL2 + REG_CLR); + } /* * Even if we disable the controller here, it will still continue diff --git a/drivers/gpu/drm/mxsfb/mxsfb_regs.h b/drivers/gpu/drm/mxsfb/mxsfb_regs.h index dc4daa0..0f63ba1 100644 --- a/drivers/gpu/drm/mxsfb/mxsfb_regs.h +++ b/drivers/gpu/drm/mxsfb/mxsfb_regs.h @@ -108,6 +108,8 @@ #define CTRL2_LINE_PATTERN_BGR 5 #define CTRL2_LINE_PATTERN_CLR 7 +#define CTRL2_LCD_RESET BIT(0) + #define TRANSFER_COUNT_SET_VCOUNT(x) REG_PUT((x), 31, 16) #define TRANSFER_COUNT_GET_VCOUNT(x) REG_GET((x), 31, 16) #define TRANSFER_COUNT_SET_HCOUNT(x) REG_PUT((x), 15, 0) -- 2.7.4