aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/message/i2o/iop.c89
1 files changed, 46 insertions, 43 deletions
diff --git a/drivers/message/i2o/iop.c b/drivers/message/i2o/iop.c
index 68aef58bf89c..bd971b1b88e3 100644
--- a/drivers/message/i2o/iop.c
+++ b/drivers/message/i2o/iop.c
@@ -652,6 +652,48 @@ static int i2o_iop_activate(struct i2o_controller *c)
652 return i2o_hrt_get(c); 652 return i2o_hrt_get(c);
653}; 653};
654 654
655static void i2o_res_alloc(struct i2o_controller *c, unsigned long flags)
656{
657 i2o_status_block *sb = c->status_block.virt;
658 struct resource *root, *res = &c->mem_resource;
659 resource_size_t size, min, max, align;
660 int err;
661
662 res->name = c->pdev->bus->name;
663 res->flags = flags;
664 res->start = 0;
665 res->end = 0;
666 osm_info("%s: requires private memory resources.\n", c->name);
667 root = pci_find_parent_resource(c->pdev, res);
668 if (root == NULL) {
669 osm_warn("%s: Can't find parent resource!\n", c->name);
670 return;
671 }
672
673 if (flags & IORESOURCE_MEM) {
674 size = min = max = sb->desired_mem_size;
675 align = 1 << 20; /* unspecified, use 1Mb and play safe */
676 } else {
677 size = min = max = sb->desired_io_size;
678 align = 1 << 12; /* unspecified, use 4Kb and play safe */
679 }
680
681 err = allocate_resource(root, res, size, min, max, align, NULL, NULL);
682 if (err < 0)
683 return;
684
685 if (flags & IORESOURCE_MEM) {
686 c->mem_alloc = 1;
687 sb->current_mem_size = resource_size(res);
688 sb->current_mem_base = res->start;
689 } else if (flags & IORESOURCE_IO) {
690 c->io_alloc = 1;
691 sb->current_io_size = resource_size(res);
692 sb->current_io_base = res->start;
693 }
694 osm_info("%s: allocated PCI space %pR\n", c->name, res);
695}
696
655/** 697/**
656 * i2o_iop_systab_set - Set the I2O System Table of the specified IOP 698 * i2o_iop_systab_set - Set the I2O System Table of the specified IOP
657 * @c: I2O controller to which the system table should be send 699 * @c: I2O controller to which the system table should be send
@@ -665,52 +707,13 @@ static int i2o_iop_systab_set(struct i2o_controller *c)
665 struct i2o_message *msg; 707 struct i2o_message *msg;
666 i2o_status_block *sb = c->status_block.virt; 708 i2o_status_block *sb = c->status_block.virt;
667 struct device *dev = &c->pdev->dev; 709 struct device *dev = &c->pdev->dev;
668 struct resource *root;
669 int rc; 710 int rc;
670 711
671 if (sb->current_mem_size < sb->desired_mem_size) { 712 if (sb->current_mem_size < sb->desired_mem_size)
672 struct resource *res = &c->mem_resource; 713 i2o_res_alloc(c, IORESOURCE_MEM);
673 res->name = c->pdev->bus->name;
674 res->flags = IORESOURCE_MEM;
675 res->start = 0;
676 res->end = 0;
677 osm_info("%s: requires private memory resources.\n", c->name);
678 root = pci_find_parent_resource(c->pdev, res);
679 if (root == NULL)
680 osm_warn("%s: Can't find parent resource!\n", c->name);
681 if (root && allocate_resource(root, res, sb->desired_mem_size, sb->desired_mem_size, sb->desired_mem_size, 1 << 20, /* Unspecified, so use 1Mb and play safe */
682 NULL, NULL) >= 0) {
683 c->mem_alloc = 1;
684 sb->current_mem_size = resource_size(res);
685 sb->current_mem_base = res->start;
686 osm_info("%s: allocated %llu bytes of PCI memory at "
687 "0x%016llX.\n", c->name,
688 (unsigned long long)resource_size(res),
689 (unsigned long long)res->start);
690 }
691 }
692 714
693 if (sb->current_io_size < sb->desired_io_size) { 715 if (sb->current_io_size < sb->desired_io_size)
694 struct resource *res = &c->io_resource; 716 i2o_res_alloc(c, IORESOURCE_IO);
695 res->name = c->pdev->bus->name;
696 res->flags = IORESOURCE_IO;
697 res->start = 0;
698 res->end = 0;
699 osm_info("%s: requires private memory resources.\n", c->name);
700 root = pci_find_parent_resource(c->pdev, res);
701 if (root == NULL)
702 osm_warn("%s: Can't find parent resource!\n", c->name);
703 if (root && allocate_resource(root, res, sb->desired_io_size, sb->desired_io_size, sb->desired_io_size, 1 << 12, /* Unspecified, so use 4Kb and play safe */
704 NULL, NULL) >= 0) {
705 c->io_alloc = 1;
706 sb->current_io_size = resource_size(res);
707 sb->current_io_base = res->start;
708 osm_info("%s: allocated %llu bytes of PCI I/O at "
709 "0x%016llX.\n", c->name,
710 (unsigned long long)resource_size(res),
711 (unsigned long long)res->start);
712 }
713 }
714 717
715 msg = i2o_msg_get_wait(c, I2O_TIMEOUT_MESSAGE_GET); 718 msg = i2o_msg_get_wait(c, I2O_TIMEOUT_MESSAGE_GET);
716 if (IS_ERR(msg)) 719 if (IS_ERR(msg))