1 // SPDX-License-Identifier: GPL-2.0
3 * Intel(R) Trace Hub ACPI driver
5 * Copyright (C) 2017 Intel Corporation.
8 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
10 #include <linux/types.h>
11 #include <linux/module.h>
12 #include <linux/device.h>
13 #include <linux/sysfs.h>
14 #include <linux/platform_device.h>
15 #include <linux/acpi.h>
19 #define DRIVER_NAME "intel_th_acpi"
21 static const struct intel_th_drvdata intel_th_acpi_pch
= {
25 static const struct intel_th_drvdata intel_th_acpi_uncore
= {
29 static const struct acpi_device_id intel_th_acpi_ids
[] = {
30 { "INTC1000", (kernel_ulong_t
)&intel_th_acpi_uncore
},
31 { "INTC1001", (kernel_ulong_t
)&intel_th_acpi_pch
},
35 MODULE_DEVICE_TABLE(acpi
, intel_th_acpi_ids
);
37 static int intel_th_acpi_probe(struct platform_device
*pdev
)
39 struct acpi_device
*adev
= ACPI_COMPANION(&pdev
->dev
);
40 struct resource resource
[TH_MMIO_END
];
41 const struct acpi_device_id
*id
;
45 id
= acpi_match_device(intel_th_acpi_ids
, &pdev
->dev
);
49 for (i
= 0, r
= 0; i
< pdev
->num_resources
&& r
< TH_MMIO_END
; i
++)
50 if (pdev
->resource
[i
].flags
&
51 (IORESOURCE_IRQ
| IORESOURCE_MEM
))
52 resource
[r
++] = pdev
->resource
[i
];
54 th
= intel_th_alloc(&pdev
->dev
, (void *)id
->driver_data
, resource
, r
);
58 adev
->driver_data
= th
;
63 static void intel_th_acpi_remove(struct platform_device
*pdev
)
65 struct intel_th
*th
= platform_get_drvdata(pdev
);
70 static struct platform_driver intel_th_acpi_driver
= {
71 .probe
= intel_th_acpi_probe
,
72 .remove
= intel_th_acpi_remove
,
75 .acpi_match_table
= intel_th_acpi_ids
,
79 module_platform_driver(intel_th_acpi_driver
);
81 MODULE_LICENSE("GPL v2");
82 MODULE_DESCRIPTION("Intel(R) Trace Hub ACPI controller driver");
83 MODULE_AUTHOR("Alexander Shishkin <alexander.shishkin@intel.com>");