From patchwork Thu Oct 21 09:27:07 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Markus Schneider-Pargmann X-Patchwork-Id: 12576979 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 91FDFC433EF for ; Fri, 22 Oct 2021 04:05:51 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id B909360F6E for ; Fri, 22 Oct 2021 04:05:50 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org B909360F6E Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=baylibre.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-Id:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=F3Sr3uZKS4+aJ9E5Jq4owxNZJk0UODtAhdz6WK4Zz9k=; b=coujABOOXN3Tp6 pNpixUjG4S6bICC/4KlyTfb4UrBR4c4J8BelHApdanyep8WnkS1CfQ4n/2NuRbSdrh36uLR1G00gx d7FmHbJhTYKuftPbc5fM/IG0HpFngQXe+4l7If6F/FjGOSu3C/VKXZM1zO8w6Act/ymv/5OofML9T N5P6OWhplvbGvt7jJpVIdDXs18tvn5x1HxHqQzROVlWvRIUZi0OZVa/QpeYyJvTHGPiIxl8Y7IRIi WKVwGZK7RP+jy14y/MvL53b+Kpr3YgO3N4RF+p8iS2vXgrAslJNLepn1YT6E/DksfiMBtvKhC8uwb fE4Xl1q0f5be1rj9jbGQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1mdloU-009hrR-5V; Fri, 22 Oct 2021 04:05:50 +0000 Received: from desiato.infradead.org ([2001:8b0:10b:1:d65d:64ff:fe57:4e05]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1mdUMQ-00711h-W7 for linux-phy@bombadil.infradead.org; Thu, 21 Oct 2021 09:27:43 +0000 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=desiato.20200630; h=Content-Transfer-Encoding:MIME-Version :References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender:Reply-To: Content-Type:Content-ID:Content-Description; bh=oxhFBOGZmgRXPor6lbkAlyiOraW8VoAcP/2tZEuRZ/c=; b=NEBXVjecfFewbUUkr1e4icze5n +zhIX8/f4W/UyVzScTOyiP8gbqZMFHmnFTxxreuFvq7CqvsypQb48bwMZNN2awsAJZONJ3HYWxFjD T54TPCAHI3CxnWi3JFI2I1va+itiPTFVXF4RprJR9iQJC/LIm5iBCYLEsaCZiqmfuynVGpcBdSzHX Fl8Cnckp2NMNR43jgQSr7Z9DKYzvCyuLrqtKeEm156GkqBxEbJ30bOfdo+pXH7YJ+hS21kIQfIqe3 ScdNJhouXewhAQ95bTre0rkmfy4TCLDyRu1dEoDMVoMSwRyVVq8nHGOGGsRKgL+Km296AFMD9qO04 Czcc1ExQ==; Received: from mail-wr1-x42b.google.com ([2a00:1450:4864:20::42b]) by desiato.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1mdUMG-00BHI3-SA for linux-phy@lists.infradead.org; Thu, 21 Oct 2021 09:27:41 +0000 Received: by mail-wr1-x42b.google.com with SMTP id r10so1014759wra.12 for ; Thu, 21 Oct 2021 02:27:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20210112.gappssmtp.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=oxhFBOGZmgRXPor6lbkAlyiOraW8VoAcP/2tZEuRZ/c=; b=aeDiMja1rOjQi8pIm6eTaxCekuqU/2mGjpuau/PB+Jj6za5O2NBkLn1cM9tO6A+wjy unt4Dm5U7p1nOfV1diJbDKx9AxTl1khL71VjlfoBVtlyKiwOt5FKVIkI+eJ3/DqCTho3 kqWU8nLPQdjShudL+MhtQIuiM2GLjJ9M86HdFLxuxbIKfi5EqS8mPEIWWyoOcagkBMrG mMwny+I4T/5xf2YD7a07G1OLnE11okNO4+YK2yZhgHsZtUYJ+i96dfHuw0Aj7jiXm3FM nDofBAdE64u18PFU95yPzikODQheCpPA4Wn5T+SGoIUSnHkjyGIwC1XUTAZV8zlPmSgF lIOQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=oxhFBOGZmgRXPor6lbkAlyiOraW8VoAcP/2tZEuRZ/c=; b=P1zE/pltQ5tKLcIJwEmau7haH8ualh8AjSq3Hp7w7gzlh/LQwBxkwOaS5h614dSXGU vR/JT4dveOv4qQCqdEUDD6f3x45B4KfEMo2Lq1OpzoDmp/cUbv0MIawZp0sKTjDkvF9r j+U7sp6ZPam7F3jJUGXLdzHggUoWHVZBGZz52xG5N+tT4k7LOzrUAvgd8EvWxSE8irfH UeuHMkNS+BhSClleg1kkXOmPwzfkXcIFgmZLytJW3a2GGRqM646sgZavJJ+EsX/ChXNd LLepkGgKhEuLbPEPhM780pAEVyW86hFOvIf5Ja83uiVtM3d2JaxvtOPMNGzUTJallo08 d2ww== X-Gm-Message-State: AOAM5319KiL3IXeb49kgTSwUx/E/PWFWCD+nBKqJSkQr1AbMUBqZbfrO X2c064M5wdg+TKagOePM9Yv7WA== X-Google-Smtp-Source: ABdhPJwyqTzaCN6XidyxWnZOiDWd9DYeAitY073k8ij+wqJVyJT4zmyMTzEfjN0+1wNOje2pWnl9tA== X-Received: by 2002:adf:d1c2:: with SMTP id b2mr5989101wrd.73.1634808451233; Thu, 21 Oct 2021 02:27:31 -0700 (PDT) Received: from blmsp.lan ([2a02:2454:3e6:c900:5142:5fbb:5821:5dc3]) by smtp.gmail.com with ESMTPSA id d3sm4538468wrb.36.2021.10.21.02.27.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 21 Oct 2021 02:27:30 -0700 (PDT) From: Markus Schneider-Pargmann To: Chun-Kuang Hu , Philipp Zabel , Rob Herring , Vinod Koul Cc: Sam Ravnborg , dri-devel@lists.freedesktop.org, linux-mediatek@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-phy@lists.infradead.org, devicetree@vger.kernel.org, Markus Schneider-Pargmann Subject: [PATCH v5 7/7] drm/mediatek: Add mt8195 DisplayPort driver Date: Thu, 21 Oct 2021 11:27:07 +0200 Message-Id: <20211021092707.3562523-8-msp@baylibre.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20211021092707.3562523-1-msp@baylibre.com> References: <20211021092707.3562523-1-msp@baylibre.com> MIME-Version: 1.0 X-Mailman-Approved-At: Thu, 21 Oct 2021 21:05:48 -0700 X-BeenThere: linux-phy@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: Linux Phy Mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-phy" Errors-To: linux-phy-bounces+linux-phy=archiver.kernel.org@lists.infradead.org This patch adds a DisplayPort driver for the Mediatek mt8195 SoC and a according phy driver mediatek-dp-phy. It supports both functional units on the mt8195, the embedded DisplayPort as well as the external DisplayPort units. It offers hot-plug-detection, audio up to 8 channels, and DisplayPort 1.4 with up to 4 lanes. The driver creates a child device for the phy. The child device will never exist without the parent being active. As they are sharing a register range, the parent passes a regmap pointer to the child so that both can work with the same register range. The phy driver sets device data that is read by the parent to get the phy device that can be used to control the phy properties. This driver is based on an initial version by Jason-JH.Lin . Signed-off-by: Markus Schneider-Pargmann Reported-by: kernel test robot Reported-by: kernel test robot Reported-by: kernel test robot --- Notes: Changes v4 -> v5: - Remove edp_tx compatible and rename the dp_tx compatible to dp-tx. - Detect whether it is edp by checking whether a panel is present. Changes v2 -> v3: - Solve TODOs and add defines for undescribed registers - Remove TODOs that were irrelevant Changes v1 -> v2: - Fix checkpatch --strict suggestions - General cleanups of the code. - Remove all remaining non-atomic functions. - Remove unused includes and sort them. - Remove unused select GENERIC_PHY - Rename phy registers DP_PHY -> MTK_DP_PHY - Replace usage of delays with usleep_range. - Split the phy register accesses into a separate phy driver. - Use a lock to guard access to mtk_dp->edid as it can be allocated/used/freed in different threads - use struct dp_sdp for sdp packets. Changes RFC -> v1: - Removed unused register definitions. - Replaced workqueue with threaded irq. - Removed connector code. - Move to atomic_* drm functions. - General cleanups of the code. - Remove unused select GENERIC_PHY. drivers/gpu/drm/mediatek/Kconfig | 7 + drivers/gpu/drm/mediatek/Makefile | 2 + drivers/gpu/drm/mediatek/mtk_dp.c | 2813 ++++++++++++++++++++++++ drivers/gpu/drm/mediatek/mtk_dp_reg.h | 535 +++++ drivers/gpu/drm/mediatek/mtk_drm_drv.c | 1 + drivers/gpu/drm/mediatek/mtk_drm_drv.h | 1 + 6 files changed, 3359 insertions(+) create mode 100644 drivers/gpu/drm/mediatek/mtk_dp.c create mode 100644 drivers/gpu/drm/mediatek/mtk_dp_reg.h diff --git a/drivers/gpu/drm/mediatek/Kconfig b/drivers/gpu/drm/mediatek/Kconfig index 2976d21e9a34..029b94c71613 100644 --- a/drivers/gpu/drm/mediatek/Kconfig +++ b/drivers/gpu/drm/mediatek/Kconfig @@ -28,3 +28,10 @@ config DRM_MEDIATEK_HDMI select PHY_MTK_HDMI help DRM/KMS HDMI driver for Mediatek SoCs + +config MTK_DPTX_SUPPORT + tristate "DRM DPTX Support for Mediatek SoCs" + depends on DRM_MEDIATEK + select PHY_MTK_DP + help + DRM/KMS Display Port driver for Mediatek SoCs. diff --git a/drivers/gpu/drm/mediatek/Makefile b/drivers/gpu/drm/mediatek/Makefile index 29098d7c8307..d86a6406055e 100644 --- a/drivers/gpu/drm/mediatek/Makefile +++ b/drivers/gpu/drm/mediatek/Makefile @@ -21,3 +21,5 @@ mediatek-drm-hdmi-objs := mtk_cec.o \ mtk_hdmi_ddc.o obj-$(CONFIG_DRM_MEDIATEK_HDMI) += mediatek-drm-hdmi.o + +obj-$(CONFIG_MTK_DPTX_SUPPORT) += mtk_dp.o diff --git a/drivers/gpu/drm/mediatek/mtk_dp.c b/drivers/gpu/drm/mediatek/mtk_dp.c new file mode 100644 index 000000000000..d93adab2d3c5 --- /dev/null +++ b/drivers/gpu/drm/mediatek/mtk_dp.c @@ -0,0 +1,2813 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright (c) 2019 MediaTek Inc. + * Copyright (c) 2021 BayLibre + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include