cciss: factor out command pool allocation functions
Signed-off-by: Stephen M. Cameron <scameron@beardog.cce.hp.com> Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
This commit is contained in:
Родитель
62710ae1ce
Коммит
54dae34320
|
@ -4653,6 +4653,39 @@ static __devinit int cciss_init_reset_devices(struct pci_dev *pdev)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static __devinit int cciss_allocate_cmd_pool(ctlr_info_t *h)
|
||||
{
|
||||
h->cmd_pool_bits = kmalloc(
|
||||
DIV_ROUND_UP(h->nr_cmds, BITS_PER_LONG) *
|
||||
sizeof(unsigned long), GFP_KERNEL);
|
||||
h->cmd_pool = pci_alloc_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(CommandList_struct),
|
||||
&(h->cmd_pool_dhandle));
|
||||
h->errinfo_pool = pci_alloc_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(ErrorInfo_struct),
|
||||
&(h->errinfo_pool_dhandle));
|
||||
if ((h->cmd_pool_bits == NULL)
|
||||
|| (h->cmd_pool == NULL)
|
||||
|| (h->errinfo_pool == NULL)) {
|
||||
dev_err(&h->pdev->dev, "out of memory");
|
||||
return -ENOMEM;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void cciss_free_cmd_pool(ctlr_info_t *h)
|
||||
{
|
||||
kfree(h->cmd_pool_bits);
|
||||
if (h->cmd_pool)
|
||||
pci_free_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(CommandList_struct),
|
||||
h->cmd_pool, h->cmd_pool_dhandle);
|
||||
if (h->errinfo_pool)
|
||||
pci_free_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(ErrorInfo_struct),
|
||||
h->errinfo_pool, h->errinfo_pool_dhandle);
|
||||
}
|
||||
|
||||
/*
|
||||
* This is it. Find all the controllers and register them. I really hate
|
||||
* stealing all these major device numbers.
|
||||
|
@ -4745,23 +4778,8 @@ static int __devinit cciss_init_one(struct pci_dev *pdev,
|
|||
h->devname, pdev->device, pci_name(pdev),
|
||||
h->intr[PERF_MODE_INT], dac ? "" : " not");
|
||||
|
||||
h->cmd_pool_bits =
|
||||
kmalloc(DIV_ROUND_UP(h->nr_cmds, BITS_PER_LONG)
|
||||
* sizeof(unsigned long), GFP_KERNEL);
|
||||
h->cmd_pool = (CommandList_struct *)
|
||||
pci_alloc_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(CommandList_struct),
|
||||
&(h->cmd_pool_dhandle));
|
||||
h->errinfo_pool = (ErrorInfo_struct *)
|
||||
pci_alloc_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(ErrorInfo_struct),
|
||||
&(h->errinfo_pool_dhandle));
|
||||
if ((h->cmd_pool_bits == NULL)
|
||||
|| (h->cmd_pool == NULL)
|
||||
|| (h->errinfo_pool == NULL)) {
|
||||
dev_err(&h->pdev->dev, "out of memory");
|
||||
if (cciss_allocate_cmd_pool(h))
|
||||
goto clean4;
|
||||
}
|
||||
|
||||
/* Need space for temp scatter list */
|
||||
h->scatter_list = kmalloc(h->max_commands *
|
||||
|
@ -4837,21 +4855,12 @@ static int __devinit cciss_init_one(struct pci_dev *pdev,
|
|||
return 1;
|
||||
|
||||
clean4:
|
||||
kfree(h->cmd_pool_bits);
|
||||
cciss_free_cmd_pool(h);
|
||||
/* Free up sg elements */
|
||||
for (k-- ; k >= 0; k--)
|
||||
kfree(h->scatter_list[k]);
|
||||
kfree(h->scatter_list);
|
||||
cciss_free_sg_chain_blocks(h->cmd_sg_list, h->nr_cmds);
|
||||
if (h->cmd_pool)
|
||||
pci_free_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(CommandList_struct),
|
||||
h->cmd_pool, h->cmd_pool_dhandle);
|
||||
if (h->errinfo_pool)
|
||||
pci_free_consistent(h->pdev,
|
||||
h->nr_cmds * sizeof(ErrorInfo_struct),
|
||||
h->errinfo_pool,
|
||||
h->errinfo_pool_dhandle);
|
||||
free_irq(h->intr[PERF_MODE_INT], h);
|
||||
clean2:
|
||||
unregister_blkdev(h->major, h->devname);
|
||||
|
@ -4949,11 +4958,7 @@ static void __devexit cciss_remove_one(struct pci_dev *pdev)
|
|||
iounmap(h->cfgtable);
|
||||
iounmap(h->vaddr);
|
||||
|
||||
pci_free_consistent(h->pdev, h->nr_cmds * sizeof(CommandList_struct),
|
||||
h->cmd_pool, h->cmd_pool_dhandle);
|
||||
pci_free_consistent(h->pdev, h->nr_cmds * sizeof(ErrorInfo_struct),
|
||||
h->errinfo_pool, h->errinfo_pool_dhandle);
|
||||
kfree(h->cmd_pool_bits);
|
||||
cciss_free_cmd_pool(h);
|
||||
/* Free up sg elements */
|
||||
for (j = 0; j < h->nr_cmds; j++)
|
||||
kfree(h->scatter_list[j]);
|
||||
|
|
Загрузка…
Ссылка в новой задаче