diff options
Diffstat (limited to 'drivers/pnp/pnpacpi')
-rw-r--r-- | drivers/pnp/pnpacpi/rsparser.c | 88 |
1 files changed, 48 insertions, 40 deletions
diff --git a/drivers/pnp/pnpacpi/rsparser.c b/drivers/pnp/pnpacpi/rsparser.c index 2669518b4795..3634f2f3f745 100644 --- a/drivers/pnp/pnpacpi/rsparser.c +++ b/drivers/pnp/pnpacpi/rsparser.c | |||
@@ -82,8 +82,8 @@ static void pnpacpi_parse_allocated_irqresource(struct pnp_dev *dev, | |||
82 | u32 gsi, int triggering, | 82 | u32 gsi, int triggering, |
83 | int polarity, int shareable) | 83 | int polarity, int shareable) |
84 | { | 84 | { |
85 | struct pnp_resource_table *res = dev->res; | 85 | struct resource *res; |
86 | int i = 0; | 86 | int i; |
87 | int irq; | 87 | int irq; |
88 | int p, t; | 88 | int p, t; |
89 | static unsigned char warned; | 89 | static unsigned char warned; |
@@ -91,9 +91,11 @@ static void pnpacpi_parse_allocated_irqresource(struct pnp_dev *dev, | |||
91 | if (!valid_IRQ(gsi)) | 91 | if (!valid_IRQ(gsi)) |
92 | return; | 92 | return; |
93 | 93 | ||
94 | while (!(res->irq_resource[i].flags & IORESOURCE_UNSET) && | 94 | for (i = 0; i < PNP_MAX_IRQ; i++) { |
95 | i < PNP_MAX_IRQ) | 95 | res = pnp_get_resource(dev, IORESOURCE_IRQ, i); |
96 | i++; | 96 | if (!pnp_resource_valid(res)) |
97 | break; | ||
98 | } | ||
97 | if (i >= PNP_MAX_IRQ) { | 99 | if (i >= PNP_MAX_IRQ) { |
98 | if (!warned) { | 100 | if (!warned) { |
99 | printk(KERN_WARNING "pnpacpi: exceeded the max number" | 101 | printk(KERN_WARNING "pnpacpi: exceeded the max number" |
@@ -119,16 +121,16 @@ static void pnpacpi_parse_allocated_irqresource(struct pnp_dev *dev, | |||
119 | } | 121 | } |
120 | } | 122 | } |
121 | 123 | ||
122 | res->irq_resource[i].flags = IORESOURCE_IRQ; // Also clears _UNSET flag | 124 | res->flags = IORESOURCE_IRQ; // Also clears _UNSET flag |
123 | res->irq_resource[i].flags |= irq_flags(triggering, polarity, shareable); | 125 | res->flags |= irq_flags(triggering, polarity, shareable); |
124 | irq = acpi_register_gsi(gsi, triggering, polarity); | 126 | irq = acpi_register_gsi(gsi, triggering, polarity); |
125 | if (irq < 0) { | 127 | if (irq < 0) { |
126 | res->irq_resource[i].flags |= IORESOURCE_DISABLED; | 128 | res->flags |= IORESOURCE_DISABLED; |
127 | return; | 129 | return; |
128 | } | 130 | } |
129 | 131 | ||
130 | res->irq_resource[i].start = irq; | 132 | res->start = irq; |
131 | res->irq_resource[i].end = irq; | 133 | res->end = irq; |
132 | pcibios_penalize_isa_irq(irq, 1); | 134 | pcibios_penalize_isa_irq(irq, 1); |
133 | } | 135 | } |
134 | 136 | ||
@@ -178,22 +180,24 @@ static int dma_flags(int type, int bus_master, int transfer) | |||
178 | static void pnpacpi_parse_allocated_dmaresource(struct pnp_dev *dev, | 180 | static void pnpacpi_parse_allocated_dmaresource(struct pnp_dev *dev, |
179 | u32 dma, int flags) | 181 | u32 dma, int flags) |
180 | { | 182 | { |
181 | struct pnp_resource_table *res = dev->res; | 183 | struct resource *res; |
182 | int i = 0; | 184 | int i; |
183 | static unsigned char warned; | 185 | static unsigned char warned; |
184 | 186 | ||
185 | while (i < PNP_MAX_DMA && | 187 | for (i = 0; i < PNP_MAX_DMA; i++) { |
186 | !(res->dma_resource[i].flags & IORESOURCE_UNSET)) | 188 | res = pnp_get_resource(dev, IORESOURCE_DMA, i); |
187 | i++; | 189 | if (!pnp_resource_valid(res)) |
190 | break; | ||
191 | } | ||
188 | if (i < PNP_MAX_DMA) { | 192 | if (i < PNP_MAX_DMA) { |
189 | res->dma_resource[i].flags = IORESOURCE_DMA; // Also clears _UNSET flag | 193 | res->flags = IORESOURCE_DMA; // Also clears _UNSET flag |
190 | res->dma_resource[i].flags |= flags; | 194 | res->flags |= flags; |
191 | if (dma == -1) { | 195 | if (dma == -1) { |
192 | res->dma_resource[i].flags |= IORESOURCE_DISABLED; | 196 | res->flags |= IORESOURCE_DISABLED; |
193 | return; | 197 | return; |
194 | } | 198 | } |
195 | res->dma_resource[i].start = dma; | 199 | res->start = dma; |
196 | res->dma_resource[i].end = dma; | 200 | res->end = dma; |
197 | } else if (!warned) { | 201 | } else if (!warned) { |
198 | printk(KERN_WARNING "pnpacpi: exceeded the max number of DMA " | 202 | printk(KERN_WARNING "pnpacpi: exceeded the max number of DMA " |
199 | "resources: %d \n", PNP_MAX_DMA); | 203 | "resources: %d \n", PNP_MAX_DMA); |
@@ -204,23 +208,25 @@ static void pnpacpi_parse_allocated_dmaresource(struct pnp_dev *dev, | |||
204 | static void pnpacpi_parse_allocated_ioresource(struct pnp_dev *dev, | 208 | static void pnpacpi_parse_allocated_ioresource(struct pnp_dev *dev, |
205 | u64 io, u64 len, int io_decode) | 209 | u64 io, u64 len, int io_decode) |
206 | { | 210 | { |
207 | struct pnp_resource_table *res = dev->res; | 211 | struct resource *res; |
208 | int i = 0; | 212 | int i; |
209 | static unsigned char warned; | 213 | static unsigned char warned; |
210 | 214 | ||
211 | while (!(res->port_resource[i].flags & IORESOURCE_UNSET) && | 215 | for (i = 0; i < PNP_MAX_PORT; i++) { |
212 | i < PNP_MAX_PORT) | 216 | res = pnp_get_resource(dev, IORESOURCE_IO, i); |
213 | i++; | 217 | if (!pnp_resource_valid(res)) |
218 | break; | ||
219 | } | ||
214 | if (i < PNP_MAX_PORT) { | 220 | if (i < PNP_MAX_PORT) { |
215 | res->port_resource[i].flags = IORESOURCE_IO; // Also clears _UNSET flag | 221 | res->flags = IORESOURCE_IO; // Also clears _UNSET flag |
216 | if (io_decode == ACPI_DECODE_16) | 222 | if (io_decode == ACPI_DECODE_16) |
217 | res->port_resource[i].flags |= PNP_PORT_FLAG_16BITADDR; | 223 | res->flags |= PNP_PORT_FLAG_16BITADDR; |
218 | if (len <= 0 || (io + len - 1) >= 0x10003) { | 224 | if (len <= 0 || (io + len - 1) >= 0x10003) { |
219 | res->port_resource[i].flags |= IORESOURCE_DISABLED; | 225 | res->flags |= IORESOURCE_DISABLED; |
220 | return; | 226 | return; |
221 | } | 227 | } |
222 | res->port_resource[i].start = io; | 228 | res->start = io; |
223 | res->port_resource[i].end = io + len - 1; | 229 | res->end = io + len - 1; |
224 | } else if (!warned) { | 230 | } else if (!warned) { |
225 | printk(KERN_WARNING "pnpacpi: exceeded the max number of IO " | 231 | printk(KERN_WARNING "pnpacpi: exceeded the max number of IO " |
226 | "resources: %d \n", PNP_MAX_PORT); | 232 | "resources: %d \n", PNP_MAX_PORT); |
@@ -232,24 +238,26 @@ static void pnpacpi_parse_allocated_memresource(struct pnp_dev *dev, | |||
232 | u64 mem, u64 len, | 238 | u64 mem, u64 len, |
233 | int write_protect) | 239 | int write_protect) |
234 | { | 240 | { |
235 | struct pnp_resource_table *res = dev->res; | 241 | struct resource *res; |
236 | int i = 0; | 242 | int i; |
237 | static unsigned char warned; | 243 | static unsigned char warned; |
238 | 244 | ||
239 | while (!(res->mem_resource[i].flags & IORESOURCE_UNSET) && | 245 | for (i = 0; i < PNP_MAX_MEM; i++) { |
240 | (i < PNP_MAX_MEM)) | 246 | res = pnp_get_resource(dev, IORESOURCE_MEM, i); |
241 | i++; | 247 | if (!pnp_resource_valid(res)) |
248 | break; | ||
249 | } | ||
242 | if (i < PNP_MAX_MEM) { | 250 | if (i < PNP_MAX_MEM) { |
243 | res->mem_resource[i].flags = IORESOURCE_MEM; // Also clears _UNSET flag | 251 | res->flags = IORESOURCE_MEM; // Also clears _UNSET flag |
244 | if (len <= 0) { | 252 | if (len <= 0) { |
245 | res->mem_resource[i].flags |= IORESOURCE_DISABLED; | 253 | res->flags |= IORESOURCE_DISABLED; |
246 | return; | 254 | return; |
247 | } | 255 | } |
248 | if (write_protect == ACPI_READ_WRITE_MEMORY) | 256 | if (write_protect == ACPI_READ_WRITE_MEMORY) |
249 | res->mem_resource[i].flags |= IORESOURCE_MEM_WRITEABLE; | 257 | res->flags |= IORESOURCE_MEM_WRITEABLE; |
250 | 258 | ||
251 | res->mem_resource[i].start = mem; | 259 | res->start = mem; |
252 | res->mem_resource[i].end = mem + len - 1; | 260 | res->end = mem + len - 1; |
253 | } else if (!warned) { | 261 | } else if (!warned) { |
254 | printk(KERN_WARNING "pnpacpi: exceeded the max number of mem " | 262 | printk(KERN_WARNING "pnpacpi: exceeded the max number of mem " |
255 | "resources: %d\n", PNP_MAX_MEM); | 263 | "resources: %d\n", PNP_MAX_MEM); |