From patchwork Mon Jun 16 00:28:12 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Dmitry Baryshkov X-Patchwork-Id: 896970 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2D5F3126F0A for ; Mon, 16 Jun 2025 00:28:28 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1750033709; cv=none; b=kz8cuvhFsmCH2Q9O/gfc7QVe40P8TzO+NkK9RWc/MdDKv1pDyvCT9Af4pA1ejL7lo3ivodqLFPZI5428asNoaI1miA/PHv7uWxAfdAuZVMSPasn3XOSlhANdX2ON1gRAxx++fmIuBWFT7xhdlzqsa/fbjUEVDkZu/KSeoK93edA= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1750033709; c=relaxed/simple; bh=tTkONwaTKNs5Th90Uob+QQKWh4KxfwIU+Ne+iEv3Fu8=; h=From:Subject:Date:Message-Id:MIME-Version:Content-Type:To:Cc; b=iWmXrlGjXc1XlruSHeK1Z1VvMeosSRZig9LdQLLy46ofPR+USzVuTzpsaoht9mRYIktTIBdnf65LpaANYU0TZvVqPhLObpJelgBMVELSm9sHKV9dw6ugadNhEHJjU8zBt1/SNV22ZsyO0mv+zFSB8V7VZZX2qq2o9pCqKFqdRiY= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=g89+fnln; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="g89+fnln" Received: from pps.filterd (m0279866.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 55FNeh69021721 for ; Mon, 16 Jun 2025 00:28:27 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:message-id :mime-version:subject:to; s=qcppdkim1; bh=PvOfpKcTPNY/T+XF/EuQGK wrKoT6J0q2a3ZDB8OoQGs=; b=g89+fnlnKrClToJ9Ma/kmuqgzvURLz37oVXtA6 kPCvfyxXXRSCbyGkG9jv5xb8AeIPrZJfWoYT/KUdBNlDUWSgTqDOrkxVIuZqbi+L 0/V6k4YE7YkFWAPDCTY9DpGiaiNtBM4uSKJaGe5nJIWviyzzUJ1gAP3Y3P0oELpG feAmG0wTiB+jAtOy/LRQtIkhUNtWmNh4Vd0E6EQs0jrMlB28zlch8vTodLFNiZqV LgMS7sju2fb9pgYDARxSdCGj4nhmK1bl2FSoZr0QriISXzg3bKIRY9b+x/d2NYWQ 1JDSDEteHvTLfR7mNE6BoaGuMp3xso6RZKzWuOeFlMW/TuPw== Received: from mail-qv1-f70.google.com (mail-qv1-f70.google.com [209.85.219.70]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4792c9thn0-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT) for ; Mon, 16 Jun 2025 00:28:27 +0000 (GMT) Received: by mail-qv1-f70.google.com with SMTP id 6a1803df08f44-6fad1f7f175so66546506d6.1 for ; Sun, 15 Jun 2025 17:28:27 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1750033705; x=1750638505; h=cc:to:content-transfer-encoding:mime-version:message-id:date :subject:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=PvOfpKcTPNY/T+XF/EuQGKwrKoT6J0q2a3ZDB8OoQGs=; b=W8aoN59u8rXwpnMEAso0rVAulvNOfKmALE7nulJCuIla8J7GPa4ZHkw2/8Y3n2b45O Mp4rS40nznMomL1losa5C2mHHovVhMW2U1726LBMWb8cPPhi6ZXuaDC4np86GLWP+wd0 u/ju4kPhSmCdms7RP49KUSk8cTRAUTTyjraqOjmFTSIFMk9zNxOQW7cD2MxSdT0ysOGW rBKiExN9W9YVLcKHDOD5CxH9JWQQlEf0euhCVsvWxjuTnJ+mRmeeKefFJl5o4NO7UR13 APTxgaz081nxANvM/x9yP4kOWyfNNL3+EuPN/dvwCx8UvLLpBipGnQX3cZgtSSsUsmku Mt9g== X-Gm-Message-State: AOJu0Yw/BZTh0DFkSyn3SgqN1tUpLEq+7PFJ9/HQpam6cXV3J0uw8Cdo h+l6sAxc4sz/+1idT12F3B/Kn22gxuGgBsg3mJC60YHBGD5bpZMMQQN6gPuhR1MMY8vudje+QYG 88M/sZfvwWPE4giE6l8s2SggF1ezmGvktenRO1HfHE4PLVByuoNSVR2e60e1ZSpCvEsrBiEXVjV VlvZs= X-Gm-Gg: ASbGncuuEe9A8rZBxKPZ5n29e0nZmebrwqcoOK0d9VTh8KjueaFL2dyfGEekwepiFOF sicagKK/G+W85Rr4GXbblvjlxqTE55nIo6xsnFLbFCe4PdJiBjiljtWVhPuR3oblxpYLrjhfH93 p6ABW7X7ScTIwfe08luKgN3654XoZBMO28kq33BQRXXS3s5KNcJNWlZUl3OZx+/wEBj0bXFWwMq 4wFJ2YLaPHXy4C8Ch5oVwhWiKg1SitV7SRL66kCjPmGK1PkhcQaeOuMgej6pisb7WTxyBMwAZ3k +RPFhVzL62LW5V2XUrVhf1fCpO6H8w4CRR86PD04K0OAjBPHxjUjpqEZ+hG1T6RB0aAjRtAM9hN qNcSLlypzLKc0KlZPyBQZaF5M+/3XAmoeGLE= X-Received: by 2002:a05:6214:e61:b0:6fa:edb8:b343 with SMTP id 6a1803df08f44-6fb45afe68emr133413506d6.2.1750033705111; Sun, 15 Jun 2025 17:28:25 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGmGu2GYdq2W+SCMEcx1ePbAUyOpvMBtExb1SkBXqC5Dpe4fxzjvdP5hMCJmzgCnUMKQLYdiw== X-Received: by 2002:a05:6214:e61:b0:6fa:edb8:b343 with SMTP id 6a1803df08f44-6fb45afe68emr133413256d6.2.1750033704653; Sun, 15 Jun 2025 17:28:24 -0700 (PDT) Received: from umbar.lan (2001-14ba-a0c3-3a00-264b-feff-fe8b-be8a.rev.dnainternet.fi. [2001:14ba:a0c3:3a00:264b:feff:fe8b:be8a]) by smtp.gmail.com with ESMTPSA id 2adb3069b0e04-553ac136104sm1334990e87.77.2025.06.15.17.28.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 15 Jun 2025 17:28:23 -0700 (PDT) From: Dmitry Baryshkov Subject: [PATCH 00/28] interconnect: qcom: icc-rpmh: use NULL-terminated arrays and drop static IDs Date: Mon, 16 Jun 2025 03:28:12 +0300 Message-Id: <20250616-rework-icc-v1-0-bc1326294d71@oss.qualcomm.com> Precedence: bulk X-Mailing-List: linux-arm-msm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-B4-Tracking: v=1; b=H4sIAB1lT2gC/6tWKk4tykwtVrJSqFYqSi3LLM7MzwNyDHUUlJIzE vPSU3UzU4B8JSMDI1MDM0Nj3aLU8vyibN3M5GRdgxTjJHMjc7NEc0sLJaCGgqLUtMwKsGHRsbW 1AGSy6+BcAAAA X-Change-ID: 20250613-rework-icc-0d3b7276a798 To: Georgi Djakov , Bjorn Andersson Cc: linux-arm-msm@vger.kernel.org, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=5425; i=dmitry.baryshkov@oss.qualcomm.com; h=from:subject:message-id; bh=tTkONwaTKNs5Th90Uob+QQKWh4KxfwIU+Ne+iEv3Fu8=; b=owEBbQGS/pANAwAKAYs8ij4CKSjVAcsmYgBoT2UhujIdU8ZiDZPCRTfol/v1s4RujRBQ41cbr oFGcgp5fQ2JATMEAAEKAB0WIQRMcISVXLJjVvC4lX+LPIo+Aiko1QUCaE9lIQAKCRCLPIo+Aiko 1WvAB/9hKGAcqZ1WCq0hiRlwkcv7lXVVfO30f0+Azc6Dk6xMQoZQiIPKFt1GWKzj0yJ0BUGl5o9 mnnl7hjrOFbcZKimAqrIbz9pJeJGF/TjRwrkL6Kykc9p9FKWEqlD7VNH5gpGFURQOWZhE7wqux/ dhofSr2ePRrqDa2FtIozGxtgyWMGqzC0WMqpiHeMAy2vESvzTGhL/XWgI9axbW+JxVz4006oiLl XzdoTN7rNDJnz28fKqk7UeUpXli9e796cgBeKqrfSmKf32BpG2We/2KT6XbRmqUvppLJtNFa52t i5i/z/nmKd+0oiO9rTE+T41GF4L03UJPdoBPml3uSief1QIr X-Developer-Key: i=dmitry.baryshkov@oss.qualcomm.com; a=openpgp; fpr=8F88381DD5C873E4AE487DA5199BF1243632046A X-Proofpoint-GUID: 1KhRp1-_q0H_NXEoEzMrYhFtTZf9JcgA X-Proofpoint-Spam-Details-Enc: AW1haW4tMjUwNjE2MDAwMSBTYWx0ZWRfXyCMP57LhjzVL +X6Dpj3awp+YQMOl4gJoW3V9qPe2k8AzEgdlFMFqWGVoouMAfMdylZCESGdGymwzLQYhEM5mhp3 TGcW7uO4xwbfB1n/GkNw1OTwdV6REcBND2uncHuWk+5XgYG+BiQs9VJhK0Y+xvs5qw9561iqcQM L9L+eKDODHogqaal/vSfFeE1vh0U+zO/KI/xwdnQZFa5jMLhfXRzc9Y8I+vd/AYqvoQAAigTdiH cB0fx+jjLeQIUI2+YQ5U+WzrHErypegT/BX2zWS6IkwIX2LDJFYIlgjTKHdm17ljVepAAtbEewS X0GErlFt2yXFE9oHLTzOuCYPljdkEmbmFyKmAJRX2YSwdyXTbKOcreSR6vbH9uGyjNI1J/dTuK2 RsU5Vf47Zh9NlR6J78SlGAGdL1Znl+nSfytukM8A0Lw23B5/Ndik29o8Wz28fQvZ9wdV8+dD X-Proofpoint-ORIG-GUID: 1KhRp1-_q0H_NXEoEzMrYhFtTZf9JcgA X-Authority-Analysis: v=2.4 cv=etffzppX c=1 sm=1 tr=0 ts=684f652b cx=c_pps a=oc9J++0uMp73DTRD5QyR2A==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=6IFa9wvqVegA:10 a=EUspDBNiAAAA:8 a=XAMh8DXI7HpmVRFZxe8A:9 a=QEXdDO2ut3YA:10 a=iYH6xdkBrDN1Jqds4HTS:22 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1099,Hydra:6.0.736,FMLib:17.12.80.40 definitions=2025-06-15_10,2025-06-13_01,2025-03-28_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 clxscore=1015 impostorscore=0 adultscore=0 spamscore=0 malwarescore=0 priorityscore=1501 suspectscore=0 phishscore=0 mlxlogscore=614 lowpriorityscore=0 bulkscore=0 mlxscore=0 classifier=spam authscore=0 authtc=n/a authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.19.0-2505280000 definitions=main-2506160001 Qualcomm interconnect code has been using .num_foo fields together with the arrays embedded in the structure, which results in hard-to-notice mistakes if .num_foo gets omitted or incorrect. Rework RPMh interconnect code to use NULL-terminated arrays for the dynamic IDs case (as now all the arrays contain only pointers) and, while we are at it, rework all the drivers to use dynamic IDs and drop static IDs code. This series touches only RPMh interconnect drivers. Corresponding series for RPM drivers will follow up shortly. Signed-off-by: Dmitry Baryshkov --- Dmitry Baryshkov (28): interconnect: qcom: sc8280xp: specify num_links for qnm_a1noc_cfg interconnect: qcom: sc8180x: specify num_nodes interconnect: qcom: rpmh: make nodes a NULL_terminated array interconnect: qcom: rpmh: make link_nodes a NULL_terminated array interconnect: qcom: sc7280: convert to dynamic IDs interconnect: qcom: sc8180x: convert to dynamic IDs interconnect: qcom: sc8280xp: convert to dynamic IDs interconnect: qcom: sdm845: convert to dynamic IDs interconnect: qcom: sm8250: convert to dynamic IDs interconnect: qcom: x1e80100: convert to dynamic IDs interconnect: qcom: qcs615: convert to dynamic IDs interconnect: qcom: qcs8300: convert to dynamic IDs interconnect: qcom: qdu1000: convert to dynamic IDs interconnect: qcom: sar2130p: convert to dynamic IDs interconnect: qcom: sc7180: convert to dynamic IDs interconnect: qcom: sdm670: convert to dynamic IDs interconnect: qcom: sdx55: convert to dynamic IDs interconnect: qcom: sdx65: convert to dynamic IDs interconnect: qcom: sdx75: convert to dynamic IDs interconnect: qcom: sm6350: convert to dynamic IDs interconnect: qcom: sm7150: convert to dynamic IDs interconnect: qcom: sm8150: convert to dynamic IDs interconnect: qcom: sm8350: convert to dynamic IDs interconnect: qcom: sm8450: convert to dynamic IDs interconnect: qcom: sm8550: convert to dynamic IDs interconnect: qcom: sm8650: convert to dynamic IDs interconnect: qcom: sm8750: convert to dynamic IDs interconnect: qcom: icc-rpmh: drop support for non-dynamic IDS drivers/interconnect/qcom/bcm-voter.c | 4 +- drivers/interconnect/qcom/icc-rpmh.c | 20 +- drivers/interconnect/qcom/icc-rpmh.h | 13 +- drivers/interconnect/qcom/qcs615.c | 713 ++++++++----------- drivers/interconnect/qcom/qcs615.h | 128 ---- drivers/interconnect/qcom/qcs8300.c | 911 +++++++++++------------- drivers/interconnect/qcom/qcs8300.h | 177 ----- drivers/interconnect/qcom/qdu1000.c | 470 ++++++------ drivers/interconnect/qcom/qdu1000.h | 95 --- drivers/interconnect/qcom/sa8775p.c | 493 ++++++------- drivers/interconnect/qcom/sar2130p.c | 795 ++++++++------------- drivers/interconnect/qcom/sc7180.c | 892 +++++++++++------------ drivers/interconnect/qcom/sc7180.h | 149 ---- drivers/interconnect/qcom/sc7280.c | 840 ++++++++++------------ drivers/interconnect/qcom/sc7280.h | 154 ---- drivers/interconnect/qcom/sc8180x.c | 1013 +++++++++++++------------- drivers/interconnect/qcom/sc8180x.h | 179 ----- drivers/interconnect/qcom/sc8280xp.c | 1257 ++++++++++++++++----------------- drivers/interconnect/qcom/sc8280xp.h | 209 ------ drivers/interconnect/qcom/sdm670.c | 712 +++++++++---------- drivers/interconnect/qcom/sdm670.h | 128 ---- drivers/interconnect/qcom/sdm845.c | 986 ++++++++++++-------------- drivers/interconnect/qcom/sdm845.h | 140 ---- drivers/interconnect/qcom/sdx55.c | 611 ++++++++-------- drivers/interconnect/qcom/sdx55.h | 70 -- drivers/interconnect/qcom/sdx65.c | 577 +++++++-------- drivers/interconnect/qcom/sdx65.h | 65 -- drivers/interconnect/qcom/sdx75.c | 498 ++++++------- drivers/interconnect/qcom/sdx75.h | 97 --- drivers/interconnect/qcom/sm6350.c | 838 +++++++++++----------- drivers/interconnect/qcom/sm6350.h | 139 ---- drivers/interconnect/qcom/sm7150.c | 860 +++++++++++----------- drivers/interconnect/qcom/sm7150.h | 140 ---- drivers/interconnect/qcom/sm8150.c | 930 ++++++++++++------------ drivers/interconnect/qcom/sm8150.h | 152 ---- drivers/interconnect/qcom/sm8250.c | 977 ++++++++++++------------- drivers/interconnect/qcom/sm8250.h | 168 ----- drivers/interconnect/qcom/sm8350.c | 901 ++++++++++++----------- drivers/interconnect/qcom/sm8350.h | 158 ----- drivers/interconnect/qcom/sm8450.c | 823 ++++++++++----------- drivers/interconnect/qcom/sm8450.h | 169 ----- drivers/interconnect/qcom/sm8550.c | 683 ++++++++---------- drivers/interconnect/qcom/sm8550.h | 138 ---- drivers/interconnect/qcom/sm8650.c | 713 ++++++++----------- drivers/interconnect/qcom/sm8650.h | 144 ---- drivers/interconnect/qcom/sm8750.c | 779 ++++++++------------ drivers/interconnect/qcom/x1e80100.c | 819 ++++++++++----------- drivers/interconnect/qcom/x1e80100.h | 192 ----- 48 files changed, 8655 insertions(+), 13464 deletions(-) --- base-commit: 410f15dcfe222c06f0d6379adec630061e88dc72 change-id: 20250613-rework-icc-0d3b7276a798 Best regards,