]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/commitdiff
platform/x86: intel_pmc_core: Change driver to a module
authorSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Thu, 11 Jan 2018 11:10:34 +0000 (16:40 +0530)
committerThadeu Lima de Souza Cascardo <cascardo@canonical.com>
Tue, 27 Mar 2018 17:28:48 +0000 (14:28 -0300)
BugLink: http://bugs.launchpad.net/bugs/1730770
Allow the driver to be a module since builtin_pci_driver funtionality is no
longer needed.

Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Signed-off-by: Rajneesh Bhardwaj <rajneesh.bhardwaj@intel.com>
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
(cherry picked from commit 2854a0aa822c11ea8538ebfe94a62e20ab570e2b)
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@canonical.com>
drivers/platform/x86/Kconfig
drivers/platform/x86/intel_pmc_core.c

index 2c745e8ccad6c190882725d8864d4f96ae2e68be..683a875f3b6c8677ff6ee7a779c65f18135b6cb4 100644 (file)
@@ -949,7 +949,7 @@ config INTEL_IMR
          If you are running on a Galileo/Quark say Y here.
 
 config INTEL_PMC_CORE
-       bool "Intel PMC Core driver"
+       tristate "Intel PMC Core driver"
        depends on PCI
        ---help---
          The Intel Platform Controller Hub for Intel Core SoCs provides access
index 00748472a55e1fd839c3c734c9e145a44d52e1b7..44353034718abb361bd97dadb53d94852370f191 100644 (file)
@@ -21,8 +21,8 @@
 #include <linux/debugfs.h>
 #include <linux/delay.h>
 #include <linux/device.h>
-#include <linux/init.h>
 #include <linux/io.h>
+#include <linux/module.h>
 #include <linux/pci.h>
 #include <linux/uaccess.h>
 
@@ -124,6 +124,7 @@ static const struct pci_device_id pmc_pci_ids[] = {
                                        (kernel_ulong_t)&spt_reg_map },
        { 0, },
 };
+MODULE_DEVICE_TABLE(pci, pmc_pci_ids);
 
 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)
        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 = {
        .name = "intel_pmc_core",
        .id_table = pmc_pci_ids,
        .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");