Commit 6e906f0e authored by Bjorn Helgaas's avatar Bjorn Helgaas Committed by Andi Kleen

PNP: make resource assignment functions return 0 (success) or -EBUSY (failure)

This patch doesn't change any behavior; it just makes the return
values more conventional.

This changes pnp_assign_dma() from a void function to one that
returns an int, just like the other assignment functions.  For
now, at least, pnp_assign_dma() always returns 0 (success), so
it appears to never fail, just like before.
Signed-off-by: default avatarBjorn Helgaas <bjorn.helgaas@hp.com>
Signed-off-by: default avatarAndi Kleen <ak@linux.intel.com>
Acked-by: default avatarRene Herman <rene.herman@gmail.com>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent 819beac3
...@@ -26,7 +26,7 @@ static int pnp_assign_port(struct pnp_dev *dev, struct pnp_port *rule, int idx) ...@@ -26,7 +26,7 @@ static int pnp_assign_port(struct pnp_dev *dev, struct pnp_port *rule, int idx)
dev_dbg(&dev->dev, " io %d already set to %#llx-%#llx " dev_dbg(&dev->dev, " io %d already set to %#llx-%#llx "
"flags %#lx\n", idx, (unsigned long long) res->start, "flags %#lx\n", idx, (unsigned long long) res->start,
(unsigned long long) res->end, res->flags); (unsigned long long) res->end, res->flags);
return 1; return 0;
} }
res = &local_res; res = &local_res;
...@@ -51,13 +51,13 @@ static int pnp_assign_port(struct pnp_dev *dev, struct pnp_port *rule, int idx) ...@@ -51,13 +51,13 @@ static int pnp_assign_port(struct pnp_dev *dev, struct pnp_port *rule, int idx)
"(min %#llx max %#llx)\n", idx, "(min %#llx max %#llx)\n", idx,
(unsigned long long) rule->min, (unsigned long long) rule->min,
(unsigned long long) rule->max); (unsigned long long) rule->max);
return 0; return -EBUSY;
} }
} }
__add: __add:
pnp_add_io_resource(dev, res->start, res->end, res->flags); pnp_add_io_resource(dev, res->start, res->end, res->flags);
return 1; return 0;
} }
static int pnp_assign_mem(struct pnp_dev *dev, struct pnp_mem *rule, int idx) static int pnp_assign_mem(struct pnp_dev *dev, struct pnp_mem *rule, int idx)
...@@ -69,7 +69,7 @@ static int pnp_assign_mem(struct pnp_dev *dev, struct pnp_mem *rule, int idx) ...@@ -69,7 +69,7 @@ static int pnp_assign_mem(struct pnp_dev *dev, struct pnp_mem *rule, int idx)
dev_dbg(&dev->dev, " mem %d already set to %#llx-%#llx " dev_dbg(&dev->dev, " mem %d already set to %#llx-%#llx "
"flags %#lx\n", idx, (unsigned long long) res->start, "flags %#lx\n", idx, (unsigned long long) res->start,
(unsigned long long) res->end, res->flags); (unsigned long long) res->end, res->flags);
return 1; return 0;
} }
res = &local_res; res = &local_res;
...@@ -103,13 +103,13 @@ static int pnp_assign_mem(struct pnp_dev *dev, struct pnp_mem *rule, int idx) ...@@ -103,13 +103,13 @@ static int pnp_assign_mem(struct pnp_dev *dev, struct pnp_mem *rule, int idx)
"(min %#llx max %#llx)\n", idx, "(min %#llx max %#llx)\n", idx,
(unsigned long long) rule->min, (unsigned long long) rule->min,
(unsigned long long) rule->max); (unsigned long long) rule->max);
return 0; return -EBUSY;
} }
} }
__add: __add:
pnp_add_mem_resource(dev, res->start, res->end, res->flags); pnp_add_mem_resource(dev, res->start, res->end, res->flags);
return 1; return 0;
} }
static int pnp_assign_irq(struct pnp_dev *dev, struct pnp_irq *rule, int idx) static int pnp_assign_irq(struct pnp_dev *dev, struct pnp_irq *rule, int idx)
...@@ -126,7 +126,7 @@ static int pnp_assign_irq(struct pnp_dev *dev, struct pnp_irq *rule, int idx) ...@@ -126,7 +126,7 @@ static int pnp_assign_irq(struct pnp_dev *dev, struct pnp_irq *rule, int idx)
if (res) { if (res) {
dev_dbg(&dev->dev, " irq %d already set to %d flags %#lx\n", dev_dbg(&dev->dev, " irq %d already set to %d flags %#lx\n",
idx, (int) res->start, res->flags); idx, (int) res->start, res->flags);
return 1; return 0;
} }
res = &local_res; res = &local_res;
...@@ -154,14 +154,14 @@ static int pnp_assign_irq(struct pnp_dev *dev, struct pnp_irq *rule, int idx) ...@@ -154,14 +154,14 @@ static int pnp_assign_irq(struct pnp_dev *dev, struct pnp_irq *rule, int idx)
} }
} }
dev_dbg(&dev->dev, " couldn't assign irq %d\n", idx); dev_dbg(&dev->dev, " couldn't assign irq %d\n", idx);
return 0; return -EBUSY;
__add: __add:
pnp_add_irq_resource(dev, res->start, res->flags); pnp_add_irq_resource(dev, res->start, res->flags);
return 1; return 0;
} }
static void pnp_assign_dma(struct pnp_dev *dev, struct pnp_dma *rule, int idx) static int pnp_assign_dma(struct pnp_dev *dev, struct pnp_dma *rule, int idx)
{ {
struct resource *res, local_res; struct resource *res, local_res;
int i; int i;
...@@ -175,7 +175,7 @@ static void pnp_assign_dma(struct pnp_dev *dev, struct pnp_dma *rule, int idx) ...@@ -175,7 +175,7 @@ static void pnp_assign_dma(struct pnp_dev *dev, struct pnp_dma *rule, int idx)
if (res) { if (res) {
dev_dbg(&dev->dev, " dma %d already set to %d flags %#lx\n", dev_dbg(&dev->dev, " dma %d already set to %d flags %#lx\n",
idx, (int) res->start, res->flags); idx, (int) res->start, res->flags);
return; return 0;
} }
res = &local_res; res = &local_res;
...@@ -198,6 +198,7 @@ static void pnp_assign_dma(struct pnp_dev *dev, struct pnp_dma *rule, int idx) ...@@ -198,6 +198,7 @@ static void pnp_assign_dma(struct pnp_dev *dev, struct pnp_dma *rule, int idx)
__add: __add:
pnp_add_dma_resource(dev, res->start, res->flags); pnp_add_dma_resource(dev, res->start, res->flags);
return 0;
} }
void pnp_init_resources(struct pnp_dev *dev) void pnp_init_resources(struct pnp_dev *dev)
...@@ -243,25 +244,26 @@ static int pnp_assign_resources(struct pnp_dev *dev, int depnum) ...@@ -243,25 +244,26 @@ static int pnp_assign_resources(struct pnp_dev *dev, int depnum)
irq = dev->independent->irq; irq = dev->independent->irq;
dma = dev->independent->dma; dma = dev->independent->dma;
while (port) { while (port) {
if (!pnp_assign_port(dev, port, nport)) if (pnp_assign_port(dev, port, nport) < 0)
goto fail; goto fail;
nport++; nport++;
port = port->next; port = port->next;
} }
while (mem) { while (mem) {
if (!pnp_assign_mem(dev, mem, nmem)) if (pnp_assign_mem(dev, mem, nmem) < 0)
goto fail; goto fail;
nmem++; nmem++;
mem = mem->next; mem = mem->next;
} }
while (irq) { while (irq) {
if (!pnp_assign_irq(dev, irq, nirq)) if (pnp_assign_irq(dev, irq, nirq) < 0)
goto fail; goto fail;
nirq++; nirq++;
irq = irq->next; irq = irq->next;
} }
while (dma) { while (dma) {
pnp_assign_dma(dev, dma, ndma); if (pnp_assign_dma(dev, dma, ndma) < 0)
goto fail;
ndma++; ndma++;
dma = dma->next; dma = dma->next;
} }
...@@ -281,25 +283,26 @@ static int pnp_assign_resources(struct pnp_dev *dev, int depnum) ...@@ -281,25 +283,26 @@ static int pnp_assign_resources(struct pnp_dev *dev, int depnum)
irq = dep->irq; irq = dep->irq;
dma = dep->dma; dma = dep->dma;
while (port) { while (port) {
if (!pnp_assign_port(dev, port, nport)) if (pnp_assign_port(dev, port, nport) < 0)
goto fail; goto fail;
nport++; nport++;
port = port->next; port = port->next;
} }
while (mem) { while (mem) {
if (!pnp_assign_mem(dev, mem, nmem)) if (pnp_assign_mem(dev, mem, nmem) < 0)
goto fail; goto fail;
nmem++; nmem++;
mem = mem->next; mem = mem->next;
} }
while (irq) { while (irq) {
if (!pnp_assign_irq(dev, irq, nirq)) if (pnp_assign_irq(dev, irq, nirq) < 0)
goto fail; goto fail;
nirq++; nirq++;
irq = irq->next; irq = irq->next;
} }
while (dma) { while (dma) {
pnp_assign_dma(dev, dma, ndma); if (pnp_assign_dma(dev, dma, ndma) < 0)
goto fail;
ndma++; ndma++;
dma = dma->next; dma = dma->next;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment