diff options
Diffstat (limited to 'drivers/spi/spi-pxa2xx-pci.c')
-rw-r--r-- | drivers/spi/spi-pxa2xx-pci.c | 73 |
1 files changed, 5 insertions, 68 deletions
diff --git a/drivers/spi/spi-pxa2xx-pci.c b/drivers/spi/spi-pxa2xx-pci.c index ece979e9c642..364964d2ed04 100644 --- a/drivers/spi/spi-pxa2xx-pci.c +++ b/drivers/spi/spi-pxa2xx-pci.c | |||
@@ -8,55 +8,11 @@ | |||
8 | #include <linux/module.h> | 8 | #include <linux/module.h> |
9 | #include <linux/spi/pxa2xx_spi.h> | 9 | #include <linux/spi/pxa2xx_spi.h> |
10 | 10 | ||
11 | struct ce4100_info { | ||
12 | struct ssp_device ssp; | ||
13 | struct platform_device *spi_pdev; | ||
14 | }; | ||
15 | |||
16 | static DEFINE_MUTEX(ssp_lock); | ||
17 | static LIST_HEAD(ssp_list); | ||
18 | |||
19 | struct ssp_device *pxa_ssp_request(int port, const char *label) | ||
20 | { | ||
21 | struct ssp_device *ssp = NULL; | ||
22 | |||
23 | mutex_lock(&ssp_lock); | ||
24 | |||
25 | list_for_each_entry(ssp, &ssp_list, node) { | ||
26 | if (ssp->port_id == port && ssp->use_count == 0) { | ||
27 | ssp->use_count++; | ||
28 | ssp->label = label; | ||
29 | break; | ||
30 | } | ||
31 | } | ||
32 | |||
33 | mutex_unlock(&ssp_lock); | ||
34 | |||
35 | if (&ssp->node == &ssp_list) | ||
36 | return NULL; | ||
37 | |||
38 | return ssp; | ||
39 | } | ||
40 | EXPORT_SYMBOL_GPL(pxa_ssp_request); | ||
41 | |||
42 | void pxa_ssp_free(struct ssp_device *ssp) | ||
43 | { | ||
44 | mutex_lock(&ssp_lock); | ||
45 | if (ssp->use_count) { | ||
46 | ssp->use_count--; | ||
47 | ssp->label = NULL; | ||
48 | } else | ||
49 | dev_err(&ssp->pdev->dev, "device already free\n"); | ||
50 | mutex_unlock(&ssp_lock); | ||
51 | } | ||
52 | EXPORT_SYMBOL_GPL(pxa_ssp_free); | ||
53 | |||
54 | static int ce4100_spi_probe(struct pci_dev *dev, | 11 | static int ce4100_spi_probe(struct pci_dev *dev, |
55 | const struct pci_device_id *ent) | 12 | const struct pci_device_id *ent) |
56 | { | 13 | { |
57 | struct platform_device_info pi; | 14 | struct platform_device_info pi; |
58 | int ret; | 15 | int ret; |
59 | struct ce4100_info *spi_info; | ||
60 | struct platform_device *pdev; | 16 | struct platform_device *pdev; |
61 | struct pxa2xx_spi_master spi_pdata; | 17 | struct pxa2xx_spi_master spi_pdata; |
62 | struct ssp_device *ssp; | 18 | struct ssp_device *ssp; |
@@ -69,14 +25,10 @@ static int ce4100_spi_probe(struct pci_dev *dev, | |||
69 | if (!ret) | 25 | if (!ret) |
70 | return ret; | 26 | return ret; |
71 | 27 | ||
72 | spi_info = devm_kzalloc(&dev->dev, sizeof(*spi_info), GFP_KERNEL); | ||
73 | if (!spi_info) | ||
74 | return -ENOMEM; | ||
75 | |||
76 | memset(&spi_pdata, 0, sizeof(spi_pdata)); | 28 | memset(&spi_pdata, 0, sizeof(spi_pdata)); |
77 | spi_pdata.num_chipselect = dev->devfn; | 29 | spi_pdata.num_chipselect = dev->devfn; |
78 | 30 | ||
79 | ssp = &spi_info->ssp; | 31 | ssp = &spi_pdata.ssp; |
80 | ssp->phys_base = pci_resource_start(dev, 0); | 32 | ssp->phys_base = pci_resource_start(dev, 0); |
81 | ssp->mmio_base = pcim_iomap_table(dev)[0]; | 33 | ssp->mmio_base = pcim_iomap_table(dev)[0]; |
82 | if (!ssp->mmio_base) { | 34 | if (!ssp->mmio_base) { |
@@ -87,10 +39,6 @@ static int ce4100_spi_probe(struct pci_dev *dev, | |||
87 | ssp->port_id = dev->devfn; | 39 | ssp->port_id = dev->devfn; |
88 | ssp->type = PXA25x_SSP; | 40 | ssp->type = PXA25x_SSP; |
89 | 41 | ||
90 | mutex_lock(&ssp_lock); | ||
91 | list_add(&ssp->node, &ssp_list); | ||
92 | mutex_unlock(&ssp_lock); | ||
93 | |||
94 | memset(&pi, 0, sizeof(pi)); | 42 | memset(&pi, 0, sizeof(pi)); |
95 | pi.parent = &dev->dev; | 43 | pi.parent = &dev->dev; |
96 | pi.name = "pxa2xx-spi"; | 44 | pi.name = "pxa2xx-spi"; |
@@ -99,30 +47,19 @@ static int ce4100_spi_probe(struct pci_dev *dev, | |||
99 | pi.size_data = sizeof(spi_pdata); | 47 | pi.size_data = sizeof(spi_pdata); |
100 | 48 | ||
101 | pdev = platform_device_register_full(&pi); | 49 | pdev = platform_device_register_full(&pi); |
102 | if (!pdev) { | 50 | if (!pdev) |
103 | mutex_lock(&ssp_lock); | ||
104 | list_del(&ssp->node); | ||
105 | mutex_unlock(&ssp_lock); | ||
106 | |||
107 | return -ENOMEM; | 51 | return -ENOMEM; |
108 | } | ||
109 | 52 | ||
110 | spi_info->spi_pdev = pdev; | 53 | pci_set_drvdata(dev, pdev); |
111 | pci_set_drvdata(dev, spi_info); | ||
112 | 54 | ||
113 | return 0; | 55 | return 0; |
114 | } | 56 | } |
115 | 57 | ||
116 | static void ce4100_spi_remove(struct pci_dev *dev) | 58 | static void ce4100_spi_remove(struct pci_dev *dev) |
117 | { | 59 | { |
118 | struct ce4100_info *spi_info = pci_get_drvdata(dev); | 60 | struct platform_device *pdev = pci_get_drvdata(dev); |
119 | struct ssp_device *ssp = &spi_info->ssp; | ||
120 | |||
121 | platform_device_unregister(spi_info->spi_pdev); | ||
122 | 61 | ||
123 | mutex_lock(&ssp_lock); | 62 | platform_device_unregister(pdev); |
124 | list_del(&ssp->node); | ||
125 | mutex_unlock(&ssp_lock); | ||
126 | } | 63 | } |
127 | 64 | ||
128 | static DEFINE_PCI_DEVICE_TABLE(ce4100_spi_devices) = { | 65 | static DEFINE_PCI_DEVICE_TABLE(ce4100_spi_devices) = { |