From patchwork Mon Sep 2 09:06:33 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 172724 Delivered-To: patch@linaro.org Received: by 2002:a92:d204:0:0:0:0:0 with SMTP id y4csp4056254ily; Mon, 2 Sep 2019 02:06:55 -0700 (PDT) X-Google-Smtp-Source: APXvYqxKZ3V9IKtnjnWZc/85B3vVKe3WLSowgz0GbV9hK8Tb4Zt2kbmxfrgxr87i7DegU3twyBIp X-Received: by 2002:a63:de43:: with SMTP id y3mr24579382pgi.211.1567415215383; Mon, 02 Sep 2019 02:06:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567415215; cv=none; d=google.com; s=arc-20160816; b=tbpR97mCDIF8V9f6C06gl2RHRaZgUTv6yGiKCafO9VCGrqrY3gCN8Y0J0LEkEgrV3V HWuSUKnJ2GIxQ4hp5eUadUZ0KIqJCElKGGH3XYnkT9xstUVJuOoCb+vykex8jV9dDy8P aBd6YDpNKRwHXi6wWZtbbyf+aG9e8kdipU46r1n/Q98irYHNRcUq+cUHPcsqMSF6c2yq IIdDJHxtFUBDUgG1jyQ9/5gtRFj3sruNkXClsMOUeEL2dNsi9PE8Dp3tvB2UzzecbKTY OeojC/OiAFzgi76X27Epobhlj4rVJNEOhczFanz0bmjdE8aYN+0B4gcEEWeb2EaUbTfe h8Gw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:content-transfer-encoding:list-subscribe:list-help :list-post:list-archive:list-unsubscribe:list-id:precedence :mime-version:references:in-reply-to:message-id:date:subject:to:from :delivered-to; bh=2+fwCmGiqFcVTa50dPbkBPGqtgWvES9ajTnQWc5IwdU=; b=YgRRM8Amf4bka3k0timjpwT1acXe1a4CqiPUnCw/1dhU5xsmNecv5MwLLpipd5+pws /wi3XPvQd2HNIT4gqaoBk//6Q7FtRfRvsr+JqHFRe0pvr0AwSrn0lg4B3ZlgK+FjsDHQ QWQlzJtbYPU/t5zCql6uzSSM8YByDN69epNd3W4UcueCdLk2E0Ak5k+Pch2TnbwpvWUa XyndShGf/U/Mntypuv8+KCFKAwUKSoN9V8VLdNTgezXE7/a8Rw7nUOskp68om1JcgQvN DTXbFoquCOV1m1sy6hvz7F2IknNfEuYd3FqNbszFsjemVu28hoPGZQfde1Z58jBtsYqU uViA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of dri-devel-bounces@lists.freedesktop.org designates 2610:10:20:722:a800:ff:fe36:1795 as permitted sender) smtp.mailfrom=dri-devel-bounces@lists.freedesktop.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from gabe.freedesktop.org (gabe.freedesktop.org. [2610:10:20:722:a800:ff:fe36:1795]) by mx.google.com with ESMTPS id g3si11668933pjt.70.2019.09.02.02.06.55 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 02 Sep 2019 02:06:55 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of dri-devel-bounces@lists.freedesktop.org designates 2610:10:20:722:a800:ff:fe36:1795 as permitted sender) client-ip=2610:10:20:722:a800:ff:fe36:1795; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of dri-devel-bounces@lists.freedesktop.org designates 2610:10:20:722:a800:ff:fe36:1795 as permitted sender) smtp.mailfrom=dri-devel-bounces@lists.freedesktop.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 28F4289AB9; Mon, 2 Sep 2019 09:06:54 +0000 (UTC) X-Original-To: dri-devel@lists.freedesktop.org Delivered-To: dri-devel@lists.freedesktop.org Received: from mail-lf1-x144.google.com (mail-lf1-x144.google.com [IPv6:2a00:1450:4864:20::144]) by gabe.freedesktop.org (Postfix) with ESMTPS id F114A89AB9 for ; Mon, 2 Sep 2019 09:06:50 +0000 (UTC) Received: by mail-lf1-x144.google.com with SMTP id z21so9887591lfe.1 for ; Mon, 02 Sep 2019 02:06:50 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Vmr/ht5IYIBUcs9L8LKGf97yXpVO4QhW+1CQmiiyIqw=; b=P+nbOEUw36MIVSs3MVK3Gu1qMKa4NwvNcok3HxX4otK4Wj4bS6S256evRJqgTSUE6x chaI7pPyyVRZxrkw9lyHzRLl/2V3P290xpRr44/FTsnjvSzjmOj+yA0/19BKtRDC893D pBO3EpRpEAqCxGN21qO2BixknWz/6rumaBqBAwJLWQlTwJByueyBoSVdskDkrdrhenq9 K+UEiVEPjia9hKuR75SQ8IPaNWCnKI33SdYC0zixFj1WfGt+ybFrL7SIYcgJ70NMvfBD epvs+GEBjjuDIkoKd8c7H55ZoJOlDu5xWYydMEpEFXi4T+NsbreRDa5REIJL7mqqfqzT K3Iw== X-Gm-Message-State: APjAAAWgGpwj4oO8eZZ/kuW7YeBuXkjTQhq5TDpNW/tOgbMaxllndiFQ gCWL6kmaFEC8ux3Gj7Tig6NWyA== X-Received: by 2002:a19:a407:: with SMTP id q7mr15021178lfc.166.1567415209183; Mon, 02 Sep 2019 02:06:49 -0700 (PDT) Received: from genomnajs.ideon.se ([85.235.10.227]) by smtp.gmail.com with ESMTPSA id m3sm725034ljc.29.2019.09.02.02.06.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 02 Sep 2019 02:06:47 -0700 (PDT) From: Linus Walleij To: Thierry Reding , Sam Ravnborg , dri-devel@lists.freedesktop.org Subject: [PATCH 2/2] drm/panel: Add driver for Sony ACX424AKP panel Date: Mon, 2 Sep 2019 11:06:33 +0200 Message-Id: <20190902090633.24239-2-linus.walleij@linaro.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190902090633.24239-1-linus.walleij@linaro.org> References: <20190902090633.24239-1-linus.walleij@linaro.org> MIME-Version: 1.0 X-Mailman-Original-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Vmr/ht5IYIBUcs9L8LKGf97yXpVO4QhW+1CQmiiyIqw=; b=NoS4TCrL0VIz4GKLS6X9n6ghT8AAc494lGb+yiXg3MWlN119lyrmOz/P0mE2qlkEK0 Ce9P1r5L11u0njtw+1eXsLzG/smjBNtswcbD4TGRRHm4rt3ooLvhIrxr5qLRSeoClz2H JRTKkKK6bhfbUMZoUQ0A9MovJZenmSooEIvGdxytgBrHvmqUaWf+5ssh2owhKV+C5Awq 7LKF+KZoyeBuA+GJgLIN3/6gwOBGUOjM4i92j7W0DMSw/uF5cWM6rUf5ewHOuKk+Vdru bnTnuvjHPnMNekzbkL+K7HCuNh8oY8j/esp5wdcVMSoHu1+VBKy3nkaBs9ECxEP9aDKP uS+w== X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" The Sony ACX424AKP is a command/videomode DSI panel for mobile devices. It is used on the ST-Ericsson HREF520 reference design. We support video mode by default, but it is possible to switch the panel into command mode by using the bool property "dsi-command-mode". Signed-off-by: Linus Walleij --- drivers/gpu/drm/panel/Kconfig | 7 + drivers/gpu/drm/panel/Makefile | 1 + drivers/gpu/drm/panel/panel-sony-acx424akp.c | 530 +++++++++++++++++++ 3 files changed, 538 insertions(+) create mode 100644 drivers/gpu/drm/panel/panel-sony-acx424akp.c diff --git a/drivers/gpu/drm/panel/Kconfig b/drivers/gpu/drm/panel/Kconfig index d9d931aa6e26..435388a874e2 100644 --- a/drivers/gpu/drm/panel/Kconfig +++ b/drivers/gpu/drm/panel/Kconfig @@ -275,6 +275,13 @@ config DRM_PANEL_SITRONIX_ST7789V Say Y here if you want to enable support for the Sitronix ST7789V controller for 240x320 LCD panels +config DRM_PANEL_SONY_ACX424AKP + tristate "Sony ACX424AKP DSI command mode panel" + depends on OF + depends on DRM_MIPI_DSI + depends on BACKLIGHT_CLASS_DEVICE + select VIDEOMODE_HELPERS + config DRM_PANEL_TPO_TPG110 tristate "TPO TPG 800x400 panel" depends on OF && SPI && GPIOLIB diff --git a/drivers/gpu/drm/panel/Makefile b/drivers/gpu/drm/panel/Makefile index fb0cb3aaa9e6..9ed4d853267e 100644 --- a/drivers/gpu/drm/panel/Makefile +++ b/drivers/gpu/drm/panel/Makefile @@ -28,5 +28,6 @@ obj-$(CONFIG_DRM_PANEL_SHARP_LQ101R1SX01) += panel-sharp-lq101r1sx01.o obj-$(CONFIG_DRM_PANEL_SHARP_LS043T1LE01) += panel-sharp-ls043t1le01.o obj-$(CONFIG_DRM_PANEL_SITRONIX_ST7701) += panel-sitronix-st7701.o obj-$(CONFIG_DRM_PANEL_SITRONIX_ST7789V) += panel-sitronix-st7789v.o +obj-$(CONFIG_DRM_PANEL_SONY_ACX424AKP) += panel-sony-acx424akp.o obj-$(CONFIG_DRM_PANEL_TPO_TPG110) += panel-tpo-tpg110.o obj-$(CONFIG_DRM_PANEL_TRULY_NT35597_WQXGA) += panel-truly-nt35597.o diff --git a/drivers/gpu/drm/panel/panel-sony-acx424akp.c b/drivers/gpu/drm/panel/panel-sony-acx424akp.c new file mode 100644 index 000000000000..807560d2a8ec --- /dev/null +++ b/drivers/gpu/drm/panel/panel-sony-acx424akp.c @@ -0,0 +1,530 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * MIPI-DSI Sony ACX424AKP panel driver. This is a 480x864 + * AMOLED panel with a command-only DSI interface. + * + * Copyright (C) Linaro Ltd. 2019 + * Author: Linus Walleij + * Based on code and know-how from Marcus Lorentzon + * Copyright (C) ST-Ericsson SA 2010 + */ + +#include +#include +#include +#include +#include