From nobody Sun Nov 24 04:45:39 2024 Received: from mx0a-0016f401.pphosted.com (mx0a-0016f401.pphosted.com [67.231.148.174]) (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 AEC5013CF82 for ; Fri, 8 Nov 2024 04:07:48 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=67.231.148.174 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1731038870; cv=none; b=daSe0i+3OLnnareShGqrY+jKmEN+gfSb+OcFEsMDXQSc0sW7v6GvMtd3prhy8c25cUF4Rfs92/WKYu2OIE3ZbcxkkyIv+bxZkeFI9WVWIuyP355EokM5YxkScqChzY7O9OrnTQg/q2ZGVQxB6R0LFzFttHc0Lu2EhWAgnWfrUqU= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1731038870; c=relaxed/simple; bh=3BBhHHa6rIFNrt/IOTllf7MvQ5LwoRNz5BsSMPmhrYE=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=oDVvgo/Cd/zOiAPamnBA0snxrYhpuj5jeSTgMRFgHu+ImVxPM/vt916p9qihh2SGfGSOsuArdJKSlhgieFH3SOfkPmXDKqFdhDPhYq5GyBoQXsfcO+B9X7rHZzpdimFN+RYHZwDTBRXqdEIWxX4YdyGEw5ZwROk0GOsEGGFhHkg= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=marvell.com; spf=pass smtp.mailfrom=marvell.com; dkim=pass (2048-bit key) header.d=marvell.com header.i=@marvell.com header.b=c8W9mpY7; arc=none smtp.client-ip=67.231.148.174 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=marvell.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=marvell.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=marvell.com header.i=@marvell.com header.b="c8W9mpY7" Received: from pps.filterd (m0431384.ppops.net [127.0.0.1]) by mx0a-0016f401.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 4A7MbeZF022679; Thu, 7 Nov 2024 20:07:34 -0800 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=pfpt0220; bh=b sh/TfKVaVmAQ/s79PFHSIvaGT8VuUklUA+F6C/IWJo=; b=c8W9mpY7p1joRnnLi vE9VUzggO+NwdPL3avggQyCbnPdi4oEkY4H3EET1ikp5nBAsKeYFeOVf1M1r9zAR 716MKOrM10bagmnfOhvV0SFslrHWNlUPI2Xv7+vKTQBLPkBoTqfjF8k8Pk5DbJGE /eJ68x1yCKaxpPQmhxY4img7ZdHD2Q+dO9j2r50EoUAzRjmKZ/PNg9COHpnRRkGU c2YKMmEuxPHhc6pG28mgyVtdhqLG87R73ZxGOyWIAN2bPdTfu7yJqtaV6qE9kvLV 2YwZvi3WOAd732CE+dCn8xMc+x8VouqVc9gN3DYk1WZky11gS741m+HaI21ddkyp 1JWRg== Received: from dc6wp-exch02.marvell.com ([4.21.29.225]) by mx0a-0016f401.pphosted.com (PPS) with ESMTPS id 42s6gu8m30-4 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 07 Nov 2024 20:07:34 -0800 (PST) Received: from DC6WP-EXCH02.marvell.com (10.76.176.209) by DC6WP-EXCH02.marvell.com (10.76.176.209) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.4; Thu, 7 Nov 2024 20:06:41 -0800 Received: from maili.marvell.com (10.69.176.80) by DC6WP-EXCH02.marvell.com (10.76.176.209) with Microsoft SMTP Server id 15.2.1544.4 via Frontend Transport; Thu, 7 Nov 2024 20:06:41 -0800 Received: from IPBU-BLR-SERVER1.marvell.com (IPBU-BLR-SERVER1.marvell.com [10.28.8.41]) by maili.marvell.com (Postfix) with ESMTP id D10575B6926; Thu, 7 Nov 2024 20:06:38 -0800 (PST) From: Gowthami Thiagarajan To: , , , CC: , , , , Gowthami Thiagarajan Subject: [PATCH v10 4/5] perf/marvell : Refactor to extract platform data - no functional change Date: Fri, 8 Nov 2024 09:36:18 +0530 Message-ID: <20241108040619.753343-5-gthiagarajan@marvell.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20241108040619.753343-1-gthiagarajan@marvell.com> References: <20241108040619.753343-1-gthiagarajan@marvell.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Proofpoint-ORIG-GUID: 6wQ_zX72FbYDoaU_blzlT_dGD-0q6Slr X-Proofpoint-GUID: 6wQ_zX72FbYDoaU_blzlT_dGD-0q6Slr X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.687,Hydra:6.0.235,FMLib:17.0.607.475 definitions=2020-10-13_15,2020-10-13_02,2020-04-07_01 Content-Type: text/plain; charset="utf-8" Refactor the Marvell TAD PMU driver to add versioning to the=20 existing driver. Make no functional changes, the behavior and performance of the driver remain unchanged. Signed-off-by: Gowthami Thiagarajan --- drivers/perf/marvell_cn10k_tad_pmu.c | 31 +++++++++++++++++++++++++--- 1 file changed, 28 insertions(+), 3 deletions(-) diff --git a/drivers/perf/marvell_cn10k_tad_pmu.c b/drivers/perf/marvell_cn= 10k_tad_pmu.c index 9e635f355470..15f9f67cb3bd 100644 --- a/drivers/perf/marvell_cn10k_tad_pmu.c +++ b/drivers/perf/marvell_cn10k_tad_pmu.c @@ -37,6 +37,14 @@ struct tad_pmu { DECLARE_BITMAP(counters_map, TAD_MAX_COUNTERS); }; =20 +enum mrvl_tad_pmu_version { + TAD_PMU_V1 =3D 1, +}; + +struct tad_pmu_data { + int id; +}; + static int tad_pmu_cpuhp_state; =20 static void tad_pmu_event_counter_read(struct perf_event *event) @@ -254,6 +262,7 @@ static const struct attribute_group *tad_pmu_attr_group= s[] =3D { =20 static int tad_pmu_probe(struct platform_device *pdev) { + const struct tad_pmu_data *dev_data; struct device *dev =3D &pdev->dev; struct tad_region *regions; struct tad_pmu *tad_pmu; @@ -261,6 +270,7 @@ static int tad_pmu_probe(struct platform_device *pdev) u32 tad_pmu_page_size; u32 tad_page_size; u32 tad_cnt; + int version; int i, ret; char *name; =20 @@ -270,6 +280,13 @@ static int tad_pmu_probe(struct platform_device *pdev) =20 platform_set_drvdata(pdev, tad_pmu); =20 + dev_data =3D device_get_match_data(&pdev->dev); + if (!dev_data) { + dev_err(&pdev->dev, "Error: No device match data found\n"); + return -ENODEV; + } + version =3D dev_data->id; + res =3D platform_get_resource(pdev, IORESOURCE_MEM, 0); if (!res) { dev_err(&pdev->dev, "Mem resource not found\n"); @@ -319,7 +336,6 @@ static int tad_pmu_probe(struct platform_device *pdev) tad_pmu->pmu =3D (struct pmu) { =20 .module =3D THIS_MODULE, - .attr_groups =3D tad_pmu_attr_groups, .capabilities =3D PERF_PMU_CAP_NO_EXCLUDE | PERF_PMU_CAP_NO_INTERRUPT, .task_ctx_nr =3D perf_invalid_context, @@ -332,6 +348,9 @@ static int tad_pmu_probe(struct platform_device *pdev) .read =3D tad_pmu_event_counter_read, }; =20 + if (version =3D=3D TAD_PMU_V1) + tad_pmu->pmu.attr_groups =3D tad_pmu_attr_groups; + tad_pmu->cpu =3D raw_smp_processor_id(); =20 /* Register pmu instance for cpu hotplug */ @@ -360,16 +379,22 @@ static void tad_pmu_remove(struct platform_device *pd= ev) perf_pmu_unregister(&pmu->pmu); } =20 +#if defined(CONFIG_OF) || defined(CONFIG_ACPI) +static const struct tad_pmu_data tad_pmu_data =3D { + .id =3D TAD_PMU_V1, +}; +#endif + #ifdef CONFIG_OF static const struct of_device_id tad_pmu_of_match[] =3D { - { .compatible =3D "marvell,cn10k-tad-pmu", }, + { .compatible =3D "marvell,cn10k-tad-pmu", .data =3D &tad_pmu_data }, {}, }; #endif =20 #ifdef CONFIG_ACPI static const struct acpi_device_id tad_pmu_acpi_match[] =3D { - {"MRVL000B", 0}, + {"MRVL000B", (kernel_ulong_t)&tad_pmu_data}, {}, }; MODULE_DEVICE_TABLE(acpi, tad_pmu_acpi_match); --=20 2.25.1