Commit 2854a0aa authored by Srinivas Pandruvada's avatar Srinivas Pandruvada Committed by Andy Shevchenko

platform/x86: intel_pmc_core: Change driver to a module

Allow the driver to be a module since builtin_pci_driver funtionality is no
longer needed.
Signed-off-by: default avatarSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Signed-off-by: default avatarRajneesh Bhardwaj <rajneesh.bhardwaj@intel.com>
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
parent 7fc65892
...@@ -974,7 +974,7 @@ config INTEL_IMR ...@@ -974,7 +974,7 @@ config INTEL_IMR
If you are running on a Galileo/Quark say Y here. If you are running on a Galileo/Quark say Y here.
config INTEL_PMC_CORE config INTEL_PMC_CORE
bool "Intel PMC Core driver" tristate "Intel PMC Core driver"
depends on PCI depends on PCI
---help--- ---help---
The Intel Platform Controller Hub for Intel Core SoCs provides access The Intel Platform Controller Hub for Intel Core SoCs provides access
......
...@@ -21,8 +21,8 @@ ...@@ -21,8 +21,8 @@
#include <linux/debugfs.h> #include <linux/debugfs.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/device.h> #include <linux/device.h>
#include <linux/init.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/module.h>
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/uaccess.h> #include <linux/uaccess.h>
...@@ -124,6 +124,7 @@ static const struct pci_device_id pmc_pci_ids[] = { ...@@ -124,6 +124,7 @@ static const struct pci_device_id pmc_pci_ids[] = {
(kernel_ulong_t)&spt_reg_map }, (kernel_ulong_t)&spt_reg_map },
{ 0, }, { 0, },
}; };
MODULE_DEVICE_TABLE(pci, pmc_pci_ids);
static inline u8 pmc_core_reg_read_byte(struct pmc_dev *pmcdev, int offset) static inline u8 pmc_core_reg_read_byte(struct pmc_dev *pmcdev, int offset)
{ {
...@@ -520,10 +521,20 @@ static int pmc_core_probe(struct pci_dev *dev, const struct pci_device_id *id) ...@@ -520,10 +521,20 @@ static int pmc_core_probe(struct pci_dev *dev, const struct pci_device_id *id)
return 0; return 0;
} }
static void pmc_core_remove(struct pci_dev *dev)
{
pmc_core_dbgfs_unregister(&pmc);
mutex_destroy(&pmc.lock);
}
static struct pci_driver intel_pmc_core_driver = { static struct pci_driver intel_pmc_core_driver = {
.name = "intel_pmc_core", .name = "intel_pmc_core",
.id_table = pmc_pci_ids, .id_table = pmc_pci_ids,
.probe = pmc_core_probe, .probe = pmc_core_probe,
.remove = pmc_core_remove,
}; };
builtin_pci_driver(intel_pmc_core_driver); module_pci_driver(intel_pmc_core_driver);
MODULE_LICENSE("GPL v2");
MODULE_DESCRIPTION("Intel PMC Core Driver");
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment