Root/target/linux/ar71xx/patches-3.6/150-MIPS-pci-ar724x-remove-static-PCI-resources.patch

1From f1c3a7dadf7b77809cda7f77df4b1ba3b24fbfa3 Mon Sep 17 00:00:00 2001
2From: Gabor Juhos <juhosg@openwrt.org>
3Date: Wed, 27 Jun 2012 10:12:50 +0200
4Subject: [PATCH 11/34] MIPS: pci-ar724x: remove static PCI resources
5
6Get those from the platform device instead.
7
8Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
9---
10 arch/mips/ath79/pci.c | 21 ++++++++++++++++++++-
11 arch/mips/pci/pci-ar724x.c | 40 ++++++++++++++++++++++++----------------
12 2 files changed, 44 insertions(+), 17 deletions(-)
13
14--- a/arch/mips/ath79/pci.c
15+++ b/arch/mips/ath79/pci.c
16@@ -137,10 +137,13 @@ static struct platform_device *
17 ath79_register_pci_ar724x(int id,
18               unsigned long cfg_base,
19               unsigned long ctrl_base,
20+ unsigned long mem_base,
21+ unsigned long mem_size,
22+ unsigned long io_base,
23               int irq)
24 {
25     struct platform_device *pdev;
26- struct resource res[3];
27+ struct resource res[5];
28 
29     memset(res, 0, sizeof(res));
30 
31@@ -158,6 +161,16 @@ ath79_register_pci_ar724x(int id,
32     res[2].start = irq;
33     res[2].end = irq;
34 
35+ res[3].name = "mem_base";
36+ res[3].flags = IORESOURCE_MEM;
37+ res[3].start = mem_base;
38+ res[3].end = mem_base + mem_size - 1;
39+
40+ res[4].name = "io_base";
41+ res[4].flags = IORESOURCE_IO;
42+ res[4].start = io_base;
43+ res[4].end = io_base;
44+
45     pdev = platform_device_register_simple("ar724x-pci", id,
46                            res, ARRAY_SIZE(res));
47     return pdev;
48@@ -173,6 +186,9 @@ int __init ath79_register_pci(void)
49         pdev = ath79_register_pci_ar724x(-1,
50                          AR724X_PCI_CFG_BASE,
51                          AR724X_PCI_CTRL_BASE,
52+ AR724X_PCI_MEM_BASE,
53+ AR724X_PCI_MEM_SIZE,
54+ 0,
55                          ATH79_CPU_IRQ_IP2);
56     } else if (soc_is_ar9342() ||
57            soc_is_ar9344()) {
58@@ -185,6 +201,9 @@ int __init ath79_register_pci(void)
59         pdev = ath79_register_pci_ar724x(-1,
60                          AR724X_PCI_CFG_BASE,
61                          AR724X_PCI_CTRL_BASE,
62+ AR724X_PCI_MEM_BASE,
63+ AR724X_PCI_MEM_SIZE,
64+ 0,
65                          ATH79_IP2_IRQ(0));
66     } else {
67         /* No PCI support */
68--- a/arch/mips/pci/pci-ar724x.c
69+++ b/arch/mips/pci/pci-ar724x.c
70@@ -42,6 +42,8 @@ struct ar724x_pci_controller {
71     spinlock_t lock;
72 
73     struct pci_controller pci_controller;
74+ struct resource io_res;
75+ struct resource mem_res;
76 };
77 
78 static inline bool ar724x_pci_check_link(struct ar724x_pci_controller *apc)
79@@ -190,20 +192,6 @@ static struct pci_ops ar724x_pci_ops = {
80     .write = ar724x_pci_write,
81 };
82 
83-static struct resource ar724x_io_resource = {
84- .name = "PCI IO space",
85- .start = 0,
86- .end = 0,
87- .flags = IORESOURCE_IO,
88-};
89-
90-static struct resource ar724x_mem_resource = {
91- .name = "PCI memory space",
92- .start = AR724X_PCI_MEM_BASE,
93- .end = AR724X_PCI_MEM_BASE + AR724X_PCI_MEM_SIZE - 1,
94- .flags = IORESOURCE_MEM,
95-};
96-
97 static void ar724x_pci_irq_handler(unsigned int irq, struct irq_desc *desc)
98 {
99     struct ar724x_pci_controller *apc;
100@@ -331,9 +319,29 @@ static int __devinit ar724x_pci_probe(st
101 
102     spin_lock_init(&apc->lock);
103 
104+ res = platform_get_resource_byname(pdev, IORESOURCE_IO, "io_base");
105+ if (!res)
106+ return -EINVAL;
107+
108+ apc->io_res.parent = res;
109+ apc->io_res.name = "PCI IO space";
110+ apc->io_res.start = res->start;
111+ apc->io_res.end = res->end;
112+ apc->io_res.flags = IORESOURCE_IO;
113+
114+ res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "mem_base");
115+ if (!res)
116+ return -EINVAL;
117+
118+ apc->mem_res.parent = res;
119+ apc->mem_res.name = "PCI memory space";
120+ apc->mem_res.start = res->start;
121+ apc->mem_res.end = res->end;
122+ apc->mem_res.flags = IORESOURCE_MEM;
123+
124     apc->pci_controller.pci_ops = &ar724x_pci_ops;
125- apc->pci_controller.io_resource = &ar724x_io_resource;
126- apc->pci_controller.mem_resource = &ar724x_mem_resource;
127+ apc->pci_controller.io_resource = &apc->io_res;
128+ apc->pci_controller.mem_resource = &apc->mem_res;
129 
130     apc->link_up = ar724x_pci_check_link(apc);
131     if (!apc->link_up)
132

Archive Download this file



interactive