mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-04 04:02:26 +00:00
perf/marvell: Refactor to extract platform data
Refactor the Marvell TAD PMU driver to add versioning to the existing driver. Make no functional changes, the behavior and performance of the driver remain unchanged. Signed-off-by: Gowthami Thiagarajan <gthiagarajan@marvell.com> Link: https://lore.kernel.org/r/20241108040619.753343-5-gthiagarajan@marvell.com Signed-off-by: Will Deacon <will@kernel.org>
This commit is contained in:
parent
d950c381dc
commit
59731e231c
@ -37,6 +37,14 @@ struct tad_pmu {
|
|||||||
DECLARE_BITMAP(counters_map, TAD_MAX_COUNTERS);
|
DECLARE_BITMAP(counters_map, TAD_MAX_COUNTERS);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum mrvl_tad_pmu_version {
|
||||||
|
TAD_PMU_V1 = 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct tad_pmu_data {
|
||||||
|
int id;
|
||||||
|
};
|
||||||
|
|
||||||
static int tad_pmu_cpuhp_state;
|
static int tad_pmu_cpuhp_state;
|
||||||
|
|
||||||
static void tad_pmu_event_counter_read(struct perf_event *event)
|
static void tad_pmu_event_counter_read(struct perf_event *event)
|
||||||
@ -254,6 +262,7 @@ static const struct attribute_group *tad_pmu_attr_groups[] = {
|
|||||||
|
|
||||||
static int tad_pmu_probe(struct platform_device *pdev)
|
static int tad_pmu_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
|
const struct tad_pmu_data *dev_data;
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
struct tad_region *regions;
|
struct tad_region *regions;
|
||||||
struct tad_pmu *tad_pmu;
|
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_pmu_page_size;
|
||||||
u32 tad_page_size;
|
u32 tad_page_size;
|
||||||
u32 tad_cnt;
|
u32 tad_cnt;
|
||||||
|
int version;
|
||||||
int i, ret;
|
int i, ret;
|
||||||
char *name;
|
char *name;
|
||||||
|
|
||||||
@ -270,6 +280,13 @@ static int tad_pmu_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
platform_set_drvdata(pdev, tad_pmu);
|
platform_set_drvdata(pdev, tad_pmu);
|
||||||
|
|
||||||
|
dev_data = device_get_match_data(&pdev->dev);
|
||||||
|
if (!dev_data) {
|
||||||
|
dev_err(&pdev->dev, "Error: No device match data found\n");
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
version = dev_data->id;
|
||||||
|
|
||||||
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
||||||
if (!res) {
|
if (!res) {
|
||||||
dev_err(&pdev->dev, "Mem resource not found\n");
|
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 = (struct pmu) {
|
tad_pmu->pmu = (struct pmu) {
|
||||||
|
|
||||||
.module = THIS_MODULE,
|
.module = THIS_MODULE,
|
||||||
.attr_groups = tad_pmu_attr_groups,
|
|
||||||
.capabilities = PERF_PMU_CAP_NO_EXCLUDE |
|
.capabilities = PERF_PMU_CAP_NO_EXCLUDE |
|
||||||
PERF_PMU_CAP_NO_INTERRUPT,
|
PERF_PMU_CAP_NO_INTERRUPT,
|
||||||
.task_ctx_nr = perf_invalid_context,
|
.task_ctx_nr = perf_invalid_context,
|
||||||
@ -332,6 +348,9 @@ static int tad_pmu_probe(struct platform_device *pdev)
|
|||||||
.read = tad_pmu_event_counter_read,
|
.read = tad_pmu_event_counter_read,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (version == TAD_PMU_V1)
|
||||||
|
tad_pmu->pmu.attr_groups = tad_pmu_attr_groups;
|
||||||
|
|
||||||
tad_pmu->cpu = raw_smp_processor_id();
|
tad_pmu->cpu = raw_smp_processor_id();
|
||||||
|
|
||||||
/* Register pmu instance for cpu hotplug */
|
/* Register pmu instance for cpu hotplug */
|
||||||
@ -360,16 +379,22 @@ static void tad_pmu_remove(struct platform_device *pdev)
|
|||||||
perf_pmu_unregister(&pmu->pmu);
|
perf_pmu_unregister(&pmu->pmu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(CONFIG_OF) || defined(CONFIG_ACPI)
|
||||||
|
static const struct tad_pmu_data tad_pmu_data = {
|
||||||
|
.id = TAD_PMU_V1,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_OF
|
#ifdef CONFIG_OF
|
||||||
static const struct of_device_id tad_pmu_of_match[] = {
|
static const struct of_device_id tad_pmu_of_match[] = {
|
||||||
{ .compatible = "marvell,cn10k-tad-pmu", },
|
{ .compatible = "marvell,cn10k-tad-pmu", .data = &tad_pmu_data },
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_ACPI
|
#ifdef CONFIG_ACPI
|
||||||
static const struct acpi_device_id tad_pmu_acpi_match[] = {
|
static const struct acpi_device_id tad_pmu_acpi_match[] = {
|
||||||
{"MRVL000B", 0},
|
{"MRVL000B", (kernel_ulong_t)&tad_pmu_data},
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(acpi, tad_pmu_acpi_match);
|
MODULE_DEVICE_TABLE(acpi, tad_pmu_acpi_match);
|
||||||
|
Loading…
Reference in New Issue
Block a user