Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp2162591ybl; Thu, 29 Aug 2019 04:33:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqyuKhrUDskTO7aQXCRpDmYk2CXqzyyDwNjtLkrsIn6W1839ueOZlzUkroxxxbhK3aIBiiUz X-Received: by 2002:a17:902:8301:: with SMTP id bd1mr8660290plb.120.1567078407762; Thu, 29 Aug 2019 04:33:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567078407; cv=none; d=google.com; s=arc-20160816; b=zYdCTclKyAmMjCZm/+7YYyXG+AWiAiQEhQ1ijBZWub+ilhu37U8R3WTECSICiS+sNz fRK+dG80ywB3Kfi/mYWfjLj4omLEzG+iJHu97FRTrAVl9zbOFVtxZFo4M5uGq2tayASx AUXOXePrlCfTeR6PKyI1tjQEVYynX98Mu8tMTmlqWJkWi7FlavoD8+TCKycmyEJi+QYG ZwscVjch9XCHP4OdAj03H0jflZ2yEn+bcwGBe7ER6SxznsCwHRLvbvaBNt9JwhnmXECA NlW8phYD8Qr80W8NWwGTkLWxJbh7t7R6s4HIBL2fp/KzwD72YCb/G0Gr/VIH57diM3rc OUrw== 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 :message-id:date:subject:cc:to:from; bh=c4Uy9YjtstuXunkpU/1Qr0HIvm+ZlFzBKeKZ3n43Aa8=; b=QpVdcQAeO9KMLZ7nkU0kAzRb+xXtfR3o9eMBVuWsmhqrzZQaA2qrwdvZrmT3csXHZI r8TMVqOU4KLLXWEg8+7Ho+lhziK5LzNyT4MfgZ7bBpr7zWI2fuhBeRoviULjPdvdJ9H2 2gsaoWd53eJ6PC6bww1xIjPDMYoYmSGZMCfo8RdVE8pzD5M2+8sccJLkpM8eplWoOKhb h7sd0PLRvNj5jLh7UxufD+moAq7NtgbhyxA4quv74EekQ01RxARIR1OFk+KBpqUA4Yia lvmRj3Uvci1OZSwCfN1S4yHqU8ueJO160dOfi5zQZ9lbeFKeEkgcXH4bN75t2+zNwDtV 08Zw== 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 b15si1791998pgj.141.2019.08.29.04.33.10; Thu, 29 Aug 2019 04:33:27 -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 S1727174AbfH2LaV (ORCPT + 99 others); Thu, 29 Aug 2019 07:30:21 -0400 Received: from inva021.nxp.com ([92.121.34.21]:49206 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725782AbfH2LaV (ORCPT ); Thu, 29 Aug 2019 07:30:21 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id B7C9E20032E; Thu, 29 Aug 2019 13:30:18 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 9FE25200333; Thu, 29 Aug 2019 13:30:18 +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 F0B5420613; Thu, 29 Aug 2019 13:30:17 +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 v4 00/14] Improvements and fixes for mxsfb DRM driver Date: Thu, 29 Aug 2019 14:30:01 +0300 Message-Id: <1567078215-31601-1-git-send-email-robert.chiras@nxp.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 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 This patch-set improves the use of eLCDIF block on iMX 8 SoCs (like 8MQ, 8MM and 8QXP). Following, are the new features added and fixes from this patch-set: 1. Add support for drm_bridge On 8MQ and 8MM, the LCDIF block is not directly connected to a parallel display connector, where an LCD panel can be attached, but instead it is connected to DSI controller. Since this DSI stands between the display controller (eLCDIF) and the physical connector, the DSI can be implemented as a DRM bridge. So, in order to be able to connect the mxsfb driver to the DSI driver, the support for a drm_bridge was needed in mxsfb DRM driver (the actual driver for the eLCDIF block). 2. Add support for additional pixel formats Some of the pixel formats needed by Android were not implemented in this driver, but they were actually supported. So, add support for them. 3. Add support for horizontal stride Having support for horizontal stride allows the use of eLCDIF with a GPU (for example) that can only output resolution sizes multiple of a power of 8. For example, 1080 is not a power of 16, so in order to support 1920x1080 output from GPUs that can produce linear buffers only in sizes multiple to 16, this feature is needed. 3. Few minor features and bug-fixing The addition of max-memory-bandwidth DT property was actually needed in order to limit the bandwidth usage of the eLCDIF block. This is need on systems where multiple display controllers are presend and the memory bandwidth is not enough to handle all of them at maximum capacity (like it is the case on 8MQ, where there are two display controllers: DCSS and eLCDIF). The rest of the patches are bug-fixes. v4: - Removed the "Fix vblank events" patch (will cover this issue later, on a separate thread) - Colleted "Tested-by" from Guido - Collected "Reviewed-by" from Rob Herring v3: - Removed the max-res property patches and added support for max-memory-bandwidth property, as it is also implemented in other drivers - Removed unnecessary drm_vblank_off in probe v2: - Collected Tested-by from Guido - Split the first patch, which added more than one feature into relevant patches, explaining each feature added - Also split the second patch into more patches, to differentiate between the feature itself (additional pixel formats support) and the cleanup of the register definitions for a better representation (guido) - Included a patch submitted by Guido, while he was testing my patch-set Guido Günther (1): drm/mxsfb: Read bus flags from bridge if present Mirela Rabulea (1): drm/mxsfb: Signal mode changed when bpp changed Robert Chiras (12): drm/mxsfb: Update mxsfb to support a bridge drm/mxsfb: Add defines for the rest of registers drm/mxsfb: Reset vital registers for a proper initialization drm/mxsfb: Update register definitions using bit manipulation defines drm/mxsfb: Update mxsfb with additional pixel formats drm/mxsfb: Add max-memory-bandwidth property for MXSFB dt-bindings: display: Add max-memory-bandwidth property for mxsfb drm/mxsfb: Update mxsfb to support LCD reset drm/mxsfb: Improve the axi clock usage drm/mxsfb: Clear OUTSTANDING_REQS bits drm/mxsfb: Add support for horizontal stride drm/mxsfb: Add support for live pixel format change .../devicetree/bindings/display/mxsfb.txt | 5 + drivers/gpu/drm/mxsfb/mxsfb_crtc.c | 287 ++++++++++++++++++--- drivers/gpu/drm/mxsfb/mxsfb_drv.c | 194 ++++++++++++-- drivers/gpu/drm/mxsfb/mxsfb_drv.h | 12 +- drivers/gpu/drm/mxsfb/mxsfb_out.c | 26 +- drivers/gpu/drm/mxsfb/mxsfb_regs.h | 193 +++++++++----- 6 files changed, 581 insertions(+), 136 deletions(-) -- 2.7.4