提交 a2b091db 编写于 作者: P Petr Vandrovec 提交者: Linus Torvalds

[PATCH] Correctly report PnP 64bit resources

Change PnP resource handling code to use proper type for resource start and
length.  Fixes bogus regions reported in /proc/iomem.

I've also made some pointer constant, as they are constant...
Signed-off-by: NPetr Vandrovec <petr@vandrovec.name>
Cc: Bjorn Helgaas <bjorn.helgaas@hp.com>
Cc: Adam Belay <ambx1@neo.rr.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 7479d2b9
...@@ -22,7 +22,7 @@ static const struct pnp_device_id pnp_dev_table[] = { ...@@ -22,7 +22,7 @@ static const struct pnp_device_id pnp_dev_table[] = {
{ "", 0 } { "", 0 }
}; };
static void reserve_range(char *pnpid, int start, int end, int port) static void reserve_range(const char *pnpid, resource_size_t start, resource_size_t end, int port)
{ {
struct resource *res; struct resource *res;
char *regionid; char *regionid;
...@@ -32,9 +32,9 @@ static void reserve_range(char *pnpid, int start, int end, int port) ...@@ -32,9 +32,9 @@ static void reserve_range(char *pnpid, int start, int end, int port)
return; return;
snprintf(regionid, 16, "pnp %s", pnpid); snprintf(regionid, 16, "pnp %s", pnpid);
if (port) if (port)
res = request_region(start,end-start+1,regionid); res = request_region(start, end-start+1, regionid);
else else
res = request_mem_region(start,end-start+1,regionid); res = request_mem_region(start, end-start+1, regionid);
if (res == NULL) if (res == NULL)
kfree(regionid); kfree(regionid);
else else
...@@ -45,12 +45,13 @@ static void reserve_range(char *pnpid, int start, int end, int port) ...@@ -45,12 +45,13 @@ static void reserve_range(char *pnpid, int start, int end, int port)
* have double reservations. * have double reservations.
*/ */
printk(KERN_INFO printk(KERN_INFO
"pnp: %s: %s range 0x%x-0x%x %s reserved\n", "pnp: %s: %s range 0x%llx-0x%llx %s reserved\n",
pnpid, port ? "ioport" : "iomem", start, end, pnpid, port ? "ioport" : "iomem",
(unsigned long long)start, (unsigned long long)end,
NULL != res ? "has been" : "could not be"); NULL != res ? "has been" : "could not be");
} }
static void reserve_resources_of_dev(struct pnp_dev *dev) static void reserve_resources_of_dev(const struct pnp_dev *dev)
{ {
int i; int i;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册