Blame view
drivers/pwm/pwm-lpss-pci.c
2.55 KB
c558e39e1 pwm: lpss: Proper... |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
/* * Intel Low Power Subsystem PWM controller PCI driver * * Copyright (C) 2014, Intel Corporation * * Derived from the original pwm-lpss.c * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */ #include <linux/kernel.h> #include <linux/module.h> #include <linux/pci.h> |
f080be27d pwm: lpss: Add su... |
16 |
#include <linux/pm_runtime.h> |
c558e39e1 pwm: lpss: Proper... |
17 18 19 20 21 22 23 24 25 |
#include "pwm-lpss.h" static int pwm_lpss_probe_pci(struct pci_dev *pdev, const struct pci_device_id *id) { const struct pwm_lpss_boardinfo *info; struct pwm_lpss_chip *lpwm; int err; |
90927fe9a pwm: lpss: pci: M... |
26 |
err = pcim_enable_device(pdev); |
c558e39e1 pwm: lpss: Proper... |
27 28 29 30 31 32 33 34 35 |
if (err < 0) return err; info = (struct pwm_lpss_boardinfo *)id->driver_data; lpwm = pwm_lpss_probe(&pdev->dev, &pdev->resource[0], info); if (IS_ERR(lpwm)) return PTR_ERR(lpwm); pci_set_drvdata(pdev, lpwm); |
f080be27d pwm: lpss: Add su... |
36 37 38 |
pm_runtime_put(&pdev->dev); pm_runtime_allow(&pdev->dev); |
c558e39e1 pwm: lpss: Proper... |
39 40 41 42 43 44 |
return 0; } static void pwm_lpss_remove_pci(struct pci_dev *pdev) { struct pwm_lpss_chip *lpwm = pci_get_drvdata(pdev); |
f080be27d pwm: lpss: Add su... |
45 46 |
pm_runtime_forbid(&pdev->dev); pm_runtime_get_sync(&pdev->dev); |
c558e39e1 pwm: lpss: Proper... |
47 |
pwm_lpss_remove(lpwm); |
c558e39e1 pwm: lpss: Proper... |
48 |
} |
f080be27d pwm: lpss: Add su... |
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
#ifdef CONFIG_PM static int pwm_lpss_runtime_suspend_pci(struct device *dev) { /* * The PCI core will handle transition to D3 automatically. We only * need to provide runtime PM hooks for that to happen. */ return 0; } static int pwm_lpss_runtime_resume_pci(struct device *dev) { return 0; } #endif static const struct dev_pm_ops pwm_lpss_pci_pm = { SET_RUNTIME_PM_OPS(pwm_lpss_runtime_suspend_pci, pwm_lpss_runtime_resume_pci, NULL) }; |
c558e39e1 pwm: lpss: Proper... |
69 |
static const struct pci_device_id pwm_lpss_pci_ids[] = { |
87219cb47 pwm: lpss: Suppor... |
70 |
{ PCI_VDEVICE(INTEL, 0x0ac8), (unsigned long)&pwm_lpss_bxt_info}, |
c558e39e1 pwm: lpss: Proper... |
71 72 |
{ PCI_VDEVICE(INTEL, 0x0f08), (unsigned long)&pwm_lpss_byt_info}, { PCI_VDEVICE(INTEL, 0x0f09), (unsigned long)&pwm_lpss_byt_info}, |
b89b4b7a3 pwm: lpss: pci: E... |
73 |
{ PCI_VDEVICE(INTEL, 0x11a5), (unsigned long)&pwm_lpss_bxt_info}, |
87219cb47 pwm: lpss: Suppor... |
74 |
{ PCI_VDEVICE(INTEL, 0x1ac8), (unsigned long)&pwm_lpss_bxt_info}, |
c558e39e1 pwm: lpss: Proper... |
75 76 |
{ PCI_VDEVICE(INTEL, 0x2288), (unsigned long)&pwm_lpss_bsw_info}, { PCI_VDEVICE(INTEL, 0x2289), (unsigned long)&pwm_lpss_bsw_info}, |
03f00e531 pwm: lpss: Add mo... |
77 |
{ PCI_VDEVICE(INTEL, 0x5ac8), (unsigned long)&pwm_lpss_bxt_info}, |
c558e39e1 pwm: lpss: Proper... |
78 79 80 81 82 83 84 85 86 |
{ }, }; MODULE_DEVICE_TABLE(pci, pwm_lpss_pci_ids); static struct pci_driver pwm_lpss_driver_pci = { .name = "pwm-lpss", .id_table = pwm_lpss_pci_ids, .probe = pwm_lpss_probe_pci, .remove = pwm_lpss_remove_pci, |
f080be27d pwm: lpss: Add su... |
87 88 89 |
.driver = { .pm = &pwm_lpss_pci_pm, }, |
c558e39e1 pwm: lpss: Proper... |
90 91 92 93 94 |
}; module_pci_driver(pwm_lpss_driver_pci); MODULE_DESCRIPTION("PWM PCI driver for Intel LPSS"); MODULE_LICENSE("GPL v2"); |