diff options
author | Bjorn Helgaas <bjorn.helgaas@hp.com> | 2008-04-28 18:34:37 -0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2008-04-29 03:22:29 -0400 |
commit | d6180f36617953990bf90d4c1ff85b77e9995cd1 (patch) | |
tree | a9fa336f7cb1f99a62c859926c6cbcfb53f5b81e /drivers/pnp/pnpacpi | |
parent | cc8c2e308194f0997c718c7c735550ff06754d20 (diff) |
PNP: make generic pnp_add_mem_resource()
Add a pnp_add_mem_resource() that can be used by all the PNP
backends. This consolidates a little more pnp_resource_table
knowledge into one place.
Signed-off-by: Bjorn Helgaas <bjorn.helgaas@hp.com>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers/pnp/pnpacpi')
-rw-r--r-- | drivers/pnp/pnpacpi/rsparser.c | 34 |
1 files changed, 9 insertions, 25 deletions
diff --git a/drivers/pnp/pnpacpi/rsparser.c b/drivers/pnp/pnpacpi/rsparser.c index d3ca8e035c19..a512908bf4e3 100644 --- a/drivers/pnp/pnpacpi/rsparser.c +++ b/drivers/pnp/pnpacpi/rsparser.c | |||
@@ -173,34 +173,18 @@ static void pnpacpi_parse_allocated_ioresource(struct pnp_dev *dev, u64 start, | |||
173 | } | 173 | } |
174 | 174 | ||
175 | static void pnpacpi_parse_allocated_memresource(struct pnp_dev *dev, | 175 | static void pnpacpi_parse_allocated_memresource(struct pnp_dev *dev, |
176 | u64 mem, u64 len, | 176 | u64 start, u64 len, |
177 | int write_protect) | 177 | int write_protect) |
178 | { | 178 | { |
179 | struct resource *res; | 179 | int flags = 0; |
180 | int i; | 180 | u64 end = start + len - 1; |
181 | static unsigned char warned; | ||
182 | 181 | ||
183 | for (i = 0; i < PNP_MAX_MEM; i++) { | 182 | if (len == 0) |
184 | res = pnp_get_resource(dev, IORESOURCE_MEM, i); | 183 | flags |= IORESOURCE_DISABLED; |
185 | if (!pnp_resource_valid(res)) | 184 | if (write_protect == ACPI_READ_WRITE_MEMORY) |
186 | break; | 185 | flags |= IORESOURCE_MEM_WRITEABLE; |
187 | } | 186 | |
188 | if (i < PNP_MAX_MEM) { | 187 | pnp_add_mem_resource(dev, start, end, flags); |
189 | res->flags = IORESOURCE_MEM; // Also clears _UNSET flag | ||
190 | if (len <= 0) { | ||
191 | res->flags |= IORESOURCE_DISABLED; | ||
192 | return; | ||
193 | } | ||
194 | if (write_protect == ACPI_READ_WRITE_MEMORY) | ||
195 | res->flags |= IORESOURCE_MEM_WRITEABLE; | ||
196 | |||
197 | res->start = mem; | ||
198 | res->end = mem + len - 1; | ||
199 | } else if (!warned) { | ||
200 | printk(KERN_WARNING "pnpacpi: exceeded the max number of mem " | ||
201 | "resources: %d\n", PNP_MAX_MEM); | ||
202 | warned = 1; | ||
203 | } | ||
204 | } | 188 | } |
205 | 189 | ||
206 | static void pnpacpi_parse_allocated_address_space(struct pnp_dev *dev, | 190 | static void pnpacpi_parse_allocated_address_space(struct pnp_dev *dev, |