From mboxrd@z Thu Jan 1 00:00:00 1970 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 gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 1EA34CA0FE7 for ; Mon, 25 Aug 2025 14:19:26 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 7DB4610E4C1; Mon, 25 Aug 2025 14:19:25 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (2048-bit key; unprotected) header.d=qualcomm.com header.i=@qualcomm.com header.b="k1N9EP1g"; dkim-atps=neutral Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) by gabe.freedesktop.org (Postfix) with ESMTPS id BC49410E4C1 for ; Mon, 25 Aug 2025 14:19:24 +0000 (UTC) Received: from pps.filterd (m0279865.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 57P8Tn7e026626 for ; Mon, 25 Aug 2025 14:19:24 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= tEPgIOih29SfXqUD6GD70/nkYYFDZqCIEVkDEY8y1R0=; b=k1N9EP1gt6iwPhNj 25fvbPhO9rivKyVGtAra6vy9gwHtbBkActx3a0D4O6d+hNOgAnj52cOlZni8hEUw bL9sw463f9EDG4M01mrQrtmibag5QBhjgapmaWP9DZsRTo8xsW6A5OyH16TcrFa0 iDJX6Rw8Pv2fTB2dGDF/YouV+wThiWCfxEuzmz1iGGpHJO/VE40HP3WJgHQ7c7Ns Thg5jDC3Ua1Tz4p6MhThbPblAAV0bnHYfN5ZxOoluoym7iICVZ3yBntaajUUZr68 S5EPEkfqcKWlfZLPz5PwivFu6zuD+L2ZQwDc1brEnDcRfPwkpqOqn5pwX6gD08R0 CUsZJQ== Received: from mail-pg1-f199.google.com (mail-pg1-f199.google.com [209.85.215.199]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 48q5um5emn-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT) for ; Mon, 25 Aug 2025 14:19:24 +0000 (GMT) Received: by mail-pg1-f199.google.com with SMTP id 41be03b00d2f7-b4c22f91158so630474a12.1 for ; Mon, 25 Aug 2025 07:19:24 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1756131563; x=1756736363; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=tEPgIOih29SfXqUD6GD70/nkYYFDZqCIEVkDEY8y1R0=; b=oNE5jZnIa2boOEtY1SQtbvVuILXe8LQfMIh5aGxzK4tGrOzesxCV9OQI8sbom4PnaW LW/+G7PFu87jN9XCROz17F5l5BhqSQnP3W4AZX8ZYsZyPiIoEiT8hZzH6GIQqqh18ktA ugJ1QQk+h8Gjdn/wTSVP6ISb33OKdA/A0KZqbHVhbHJRM8aGttT5T53/5bsbx/je0jRw /s6RNs0CyORQOEU2Pg+wkJWVpy95i+fBxg618LjvIfaWB3Bb531N9cH6egeW1OGDquNr 4XEOpWdI24E2+d4SzLOOYvuCAQoQLofVb736GceVkhDra+FVD6/ug51Xoj+zioMySTtM BBoQ== X-Forwarded-Encrypted: i=1; AJvYcCWjdZJoBQj3ULE64NymHCfQyyrToEBdzsVlX50hTWU7NBT5GH8dmeOLpCNakdfetd41+j1/oyDwWZY=@lists.freedesktop.org X-Gm-Message-State: AOJu0Yzb2Ip1SHHP9wRCQ0EHjvdSkblioBFSLkKoQyooCcbhWhx0hWfr AcKXAh90GHXVBQLfKNtp77wH2PgdYv52yh//OjVdo7JG01ATIpUP7Uycy8u89bEFEnwBlWOq0sq GFz60yukEt6FGb65ZtGZiPjs1qCDhdkBGHPOyStvOTKwvN1GHO7m++PFIy5qRPPy18w5uUyY= X-Gm-Gg: ASbGncuKrKuFDOJ4b2nH892vnBF17IlKsLSS7cB0qEp2lli9sBCxPFd5Z/mT4Xk8Xtz VCKXMLOl2ZPXUUNBFtu41dGzrLIeq3XkwnHBUp2Yne5LLqR8+Ci2GxDelTAZQykXFIk15nqeUMD t4DoUq27TtsxApGVyYwncC+OgrE2SacwGvlOIEzyaDBSxesA0UXkndHc0//Mvz769LOV7jYHNvs wZ8ssW9Uwr7kgEZ8zkMeyCHD++FulgcvGRynija4hEUrgq6hv0k1EH++pEA6Ud+Vlxz3ilC+AOs 9GWHlPh8XXbMwUYa8lDlmDKM8M7RUDeLgd8kDGSO+cSzZf9QX0L3ZofED3tZaByUjYWn388= X-Received: by 2002:a05:6a20:12c7:b0:238:351a:f960 with SMTP id adf61e73a8af0-24340ddef22mr16065139637.23.1756131563321; Mon, 25 Aug 2025 07:19:23 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHn/UQFw+QFZO7ZeEzYcaO43UKCC3B5zX/4Z//+93qCW2qAoRaZpQx7NZQp/wR6yGUsZE9cyg== X-Received: by 2002:a05:6a20:12c7:b0:238:351a:f960 with SMTP id adf61e73a8af0-24340ddef22mr16065092637.23.1756131562810; Mon, 25 Aug 2025 07:19:22 -0700 (PDT) Received: from cse-cd01-lnx.ap.qualcomm.com ([114.94.8.21]) by smtp.gmail.com with ESMTPSA id d2e1a72fcca58-770401eb20dsm7672339b3a.79.2025.08.25.07.19.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Aug 2025 07:19:22 -0700 (PDT) From: Yongxing Mou Date: Mon, 25 Aug 2025 22:16:18 +0800 Subject: [PATCH v3 32/38] drm/msm/dp: propagate MST state changes to dp mst module MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Message-Id: <20250825-msm-dp-mst-v3-32-01faacfcdedd@oss.qualcomm.com> References: <20250825-msm-dp-mst-v3-0-01faacfcdedd@oss.qualcomm.com> In-Reply-To: <20250825-msm-dp-mst-v3-0-01faacfcdedd@oss.qualcomm.com> To: Rob Clark , Dmitry Baryshkov , Abhinav Kumar , Jessica Zhang , Sean Paul , Marijn Suijten , David Airlie , Simona Vetter Cc: linux-arm-msm@vger.kernel.org, dri-devel@lists.freedesktop.org, freedreno@lists.freedesktop.org, linux-kernel@vger.kernel.org, Yongxing Mou , Abhinav Kumar X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1756131424; l=3583; i=yongxing.mou@oss.qualcomm.com; s=20241121; h=from:subject:message-id; bh=Lq0MtIPay+yjPJuGDAZ+6ZARtIebH7XslPSHc3Frkes=; b=6Rua6mrAFQFC4aqDHArUc8KL8d279NHxrdV8BPhkF8hRjzpFRngjpVLc2ONfWrtvF6Q9IgQpA +8cCNDXjaOABXaZBjw+L/8BDqhSGiAHRnq+vFgUd/2FqpbbrCAcLxCN X-Developer-Key: i=yongxing.mou@oss.qualcomm.com; a=ed25519; pk=zeCnFRUqtOQMeFvdwex2M5o0Yf67UHYfwCyBRQ3kFbU= X-Authority-Analysis: v=2.4 cv=VtIjA/2n c=1 sm=1 tr=0 ts=68ac70ec cx=c_pps a=Oh5Dbbf/trHjhBongsHeRQ==:117 a=Uz3yg00KUFJ2y2WijEJ4bw==:17 a=IkcTkHD0fZMA:10 a=2OwXVqhp2XgA:10 a=COk6AnOGAAAA:8 a=EUspDBNiAAAA:8 a=XT7MnVG-IMvVsVpEgAUA:9 a=QEXdDO2ut3YA:10 a=_Vgx9l1VpLgwpw_dHYaR:22 a=TjNXssC_j7lpFel5tvFf:22 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjUwODIzMDAzMiBTYWx0ZWRfXwICPH1nbhTAN CvZmgtM3mSU8e7db18Rra5cqEHpOo0/GtnMXT+a+W3+u/DgGn0sSn1qeZL9MN+9Gsn9pjeIAhFi T/M/OaIcDcOUeq/y29Efx0IVP/qDfgSmhYK3Q7kJJykFZzpdQs0fqsZH0y9uglMk2y7tZgOUip7 uG1l5tjNRxuAsR9I/vEL1OWyBlDKP9oBZFqK2xuq13PsXvVqsAAhgUjF4dcaVHpiK0x5XiDOfXm 6n9FqNVG1f46/fKQZMFdHh8j9vIgicV58JUlWDMSlOBSNsGlrHDWWH8jA6wmO8pTG7m+FttFPGC /S5iitRyBYnbsKkTs0nJOLfkLAJ4byxJIq0vho+52wfU4YwhQL+OZkNv0Omy14CrUjlSU9LeIqO w78uFcZH X-Proofpoint-GUID: KVtTk7s9VyQvDRmr4PXbRkGOuDWZVLI0 X-Proofpoint-ORIG-GUID: KVtTk7s9VyQvDRmr4PXbRkGOuDWZVLI0 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1099,Hydra:6.1.9,FMLib:17.12.80.40 definitions=2025-08-25_07,2025-08-20_03,2025-03-28_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 clxscore=1015 phishscore=0 priorityscore=1501 impostorscore=0 bulkscore=0 suspectscore=0 malwarescore=0 adultscore=0 spamscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.19.0-2507300000 definitions=main-2508230032 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 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" Introduce APIs to update the MST state change to MST framework when device is plugged/unplugged. Signed-off-by: Abhinav Kumar Signed-off-by: Yongxing Mou --- drivers/gpu/drm/msm/dp/dp_display.c | 10 +++++++++- drivers/gpu/drm/msm/dp/dp_mst_drm.c | 15 +++++++++++++++ drivers/gpu/drm/msm/dp/dp_mst_drm.h | 1 + 3 files changed, 25 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/msm/dp/dp_display.c b/drivers/gpu/drm/msm/dp/dp_display.c index 59720e1ad4b1193e33a4fc6aad0c401eaf9cbec8..909c84a5c97f56138d0d62c5d856d2fd18d36b8c 100644 --- a/drivers/gpu/drm/msm/dp/dp_display.c +++ b/drivers/gpu/drm/msm/dp/dp_display.c @@ -28,6 +28,7 @@ #include "dp_drm.h" #include "dp_audio.h" #include "dp_debug.h" +#include "dp_mst_drm.h" static bool psr_enabled = false; module_param(psr_enabled, bool, 0); @@ -269,7 +270,6 @@ static int msm_dp_display_send_hpd_notification(struct msm_dp_display_private *d dp->panel->video_test = false; } - drm_dbg_dp(dp->drm_dev, "type=%d hpd=%d\n", dp->msm_dp_display.connector_type, hpd); @@ -386,6 +386,9 @@ static int msm_dp_display_process_hpd_high(struct msm_dp_display_private *dp) msm_dp_link_reset_phy_params_vx_px(dp->link); + if (dp->msm_dp_display.mst_active) + msm_dp_mst_display_set_mgr_state(&dp->msm_dp_display, true); + if (!dp->msm_dp_display.internal_hpd) msm_dp_display_send_hpd_notification(dp, true); @@ -608,6 +611,11 @@ static int msm_dp_hpd_unplug_handle(struct msm_dp_display_private *dp, u32 data) if (!dp->msm_dp_display.internal_hpd) msm_dp_display_send_hpd_notification(dp, false); + if (dp->msm_dp_display.mst_active) { + msm_dp_mst_display_set_mgr_state(&dp->msm_dp_display, false); + dp->msm_dp_display.mst_active = false; + } + /* signal the disconnect event early to ensure proper teardown */ msm_dp_display_handle_plugged_change(&dp->msm_dp_display, false); diff --git a/drivers/gpu/drm/msm/dp/dp_mst_drm.c b/drivers/gpu/drm/msm/dp/dp_mst_drm.c index 331d08854049d9c74d49aa231f3507539986099e..ca654b1963467c8220dd7ee073f25216455d0490 100644 --- a/drivers/gpu/drm/msm/dp/dp_mst_drm.c +++ b/drivers/gpu/drm/msm/dp/dp_mst_drm.c @@ -924,6 +924,21 @@ msm_dp_mst_add_connector(struct drm_dp_mst_topology_mgr *mgr, return connector; } +int msm_dp_mst_display_set_mgr_state(struct msm_dp *dp_display, bool state) +{ + int rc; + struct msm_dp_mst *mst = dp_display->msm_dp_mst; + + rc = drm_dp_mst_topology_mgr_set_mst(&mst->mst_mgr, state); + if (rc < 0) { + DRM_ERROR("failed to set topology mgr state to %d. rc %d\n", + state, rc); + } + + drm_dbg_dp(dp_display->drm_dev, "dp_mst_display_set_mgr_state state:%d\n", state); + return rc; +} + static const struct drm_dp_mst_topology_cbs msm_dp_mst_drm_cbs = { .add_connector = msm_dp_mst_add_connector, }; diff --git a/drivers/gpu/drm/msm/dp/dp_mst_drm.h b/drivers/gpu/drm/msm/dp/dp_mst_drm.h index 5e1b4db8aea4506b0e1cc1cc68980dd617d3f72a..8fe6cbbe741da4abb232256b3a15ba6b16ca4f3e 100644 --- a/drivers/gpu/drm/msm/dp/dp_mst_drm.h +++ b/drivers/gpu/drm/msm/dp/dp_mst_drm.h @@ -87,5 +87,6 @@ int msm_dp_mst_drm_bridge_init(struct msm_dp *dp, struct drm_encoder *encoder); int msm_dp_mst_init(struct msm_dp *dp_display, u32 max_streams, struct drm_dp_aux *drm_aux); void msm_dp_mst_display_hpd_irq(struct msm_dp *dp_display); +int msm_dp_mst_display_set_mgr_state(struct msm_dp *dp_display, bool state); #endif /* _DP_MST_DRM_H_ */ -- 2.34.1