提交 771db5c0 编写于 作者: R Romain Perier 提交者: Martin K. Petersen

scsi: lpfc: Replace PCI pool old API

The PCI pool API is deprecated. This commit replaces the PCI pool old
API by the appropriate function with the DMA pool API. It also updates
some comments, accordingly.
Signed-off-by: NRomain Perier <romain.perier@collabora.com>
Reviewed-by: NPeter Senna Tschudin <peter.senna@collabora.com>
Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
上级 decab9a6
...@@ -946,14 +946,14 @@ struct lpfc_hba { ...@@ -946,14 +946,14 @@ struct lpfc_hba {
struct list_head active_rrq_list; struct list_head active_rrq_list;
spinlock_t hbalock; spinlock_t hbalock;
/* pci_mem_pools */ /* dma_mem_pools */
struct pci_pool *lpfc_sg_dma_buf_pool; struct dma_pool *lpfc_sg_dma_buf_pool;
struct pci_pool *lpfc_mbuf_pool; struct dma_pool *lpfc_mbuf_pool;
struct pci_pool *lpfc_hrb_pool; /* header receive buffer pool */ struct dma_pool *lpfc_hrb_pool; /* header receive buffer pool */
struct pci_pool *lpfc_drb_pool; /* data receive buffer pool */ struct dma_pool *lpfc_drb_pool; /* data receive buffer pool */
struct pci_pool *lpfc_nvmet_drb_pool; /* data receive buffer pool */ struct dma_pool *lpfc_nvmet_drb_pool; /* data receive buffer pool */
struct pci_pool *lpfc_hbq_pool; /* SLI3 hbq buffer pool */ struct dma_pool *lpfc_hbq_pool; /* SLI3 hbq buffer pool */
struct pci_pool *txrdy_payload_pool; struct dma_pool *txrdy_payload_pool;
struct lpfc_dma_pool lpfc_mbuf_safety_pool; struct lpfc_dma_pool lpfc_mbuf_safety_pool;
mempool_t *mbox_mem_pool; mempool_t *mbox_mem_pool;
......
...@@ -3275,7 +3275,7 @@ lpfc_scsi_free(struct lpfc_hba *phba) ...@@ -3275,7 +3275,7 @@ lpfc_scsi_free(struct lpfc_hba *phba)
list_for_each_entry_safe(sb, sb_next, &phba->lpfc_scsi_buf_list_put, list_for_each_entry_safe(sb, sb_next, &phba->lpfc_scsi_buf_list_put,
list) { list) {
list_del(&sb->list); list_del(&sb->list);
pci_pool_free(phba->lpfc_sg_dma_buf_pool, sb->data, dma_pool_free(phba->lpfc_sg_dma_buf_pool, sb->data,
sb->dma_handle); sb->dma_handle);
kfree(sb); kfree(sb);
phba->total_scsi_bufs--; phba->total_scsi_bufs--;
...@@ -3286,7 +3286,7 @@ lpfc_scsi_free(struct lpfc_hba *phba) ...@@ -3286,7 +3286,7 @@ lpfc_scsi_free(struct lpfc_hba *phba)
list_for_each_entry_safe(sb, sb_next, &phba->lpfc_scsi_buf_list_get, list_for_each_entry_safe(sb, sb_next, &phba->lpfc_scsi_buf_list_get,
list) { list) {
list_del(&sb->list); list_del(&sb->list);
pci_pool_free(phba->lpfc_sg_dma_buf_pool, sb->data, dma_pool_free(phba->lpfc_sg_dma_buf_pool, sb->data,
sb->dma_handle); sb->dma_handle);
kfree(sb); kfree(sb);
phba->total_scsi_bufs--; phba->total_scsi_bufs--;
...@@ -3317,7 +3317,7 @@ lpfc_nvme_free(struct lpfc_hba *phba) ...@@ -3317,7 +3317,7 @@ lpfc_nvme_free(struct lpfc_hba *phba)
list_for_each_entry_safe(lpfc_ncmd, lpfc_ncmd_next, list_for_each_entry_safe(lpfc_ncmd, lpfc_ncmd_next,
&phba->lpfc_nvme_buf_list_put, list) { &phba->lpfc_nvme_buf_list_put, list) {
list_del(&lpfc_ncmd->list); list_del(&lpfc_ncmd->list);
pci_pool_free(phba->lpfc_sg_dma_buf_pool, lpfc_ncmd->data, dma_pool_free(phba->lpfc_sg_dma_buf_pool, lpfc_ncmd->data,
lpfc_ncmd->dma_handle); lpfc_ncmd->dma_handle);
kfree(lpfc_ncmd); kfree(lpfc_ncmd);
phba->total_nvme_bufs--; phba->total_nvme_bufs--;
...@@ -3328,7 +3328,7 @@ lpfc_nvme_free(struct lpfc_hba *phba) ...@@ -3328,7 +3328,7 @@ lpfc_nvme_free(struct lpfc_hba *phba)
list_for_each_entry_safe(lpfc_ncmd, lpfc_ncmd_next, list_for_each_entry_safe(lpfc_ncmd, lpfc_ncmd_next,
&phba->lpfc_nvme_buf_list_get, list) { &phba->lpfc_nvme_buf_list_get, list) {
list_del(&lpfc_ncmd->list); list_del(&lpfc_ncmd->list);
pci_pool_free(phba->lpfc_sg_dma_buf_pool, lpfc_ncmd->data, dma_pool_free(phba->lpfc_sg_dma_buf_pool, lpfc_ncmd->data,
lpfc_ncmd->dma_handle); lpfc_ncmd->dma_handle);
kfree(lpfc_ncmd); kfree(lpfc_ncmd);
phba->total_nvme_bufs--; phba->total_nvme_bufs--;
...@@ -3640,7 +3640,7 @@ lpfc_sli4_scsi_sgl_update(struct lpfc_hba *phba) ...@@ -3640,7 +3640,7 @@ lpfc_sli4_scsi_sgl_update(struct lpfc_hba *phba)
list_remove_head(&scsi_sgl_list, psb, list_remove_head(&scsi_sgl_list, psb,
struct lpfc_scsi_buf, list); struct lpfc_scsi_buf, list);
if (psb) { if (psb) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
psb->data, psb->dma_handle); psb->data, psb->dma_handle);
kfree(psb); kfree(psb);
} }
...@@ -3774,7 +3774,7 @@ lpfc_sli4_nvme_sgl_update(struct lpfc_hba *phba) ...@@ -3774,7 +3774,7 @@ lpfc_sli4_nvme_sgl_update(struct lpfc_hba *phba)
list_remove_head(&nvme_sgl_list, lpfc_ncmd, list_remove_head(&nvme_sgl_list, lpfc_ncmd,
struct lpfc_nvme_buf, list); struct lpfc_nvme_buf, list);
if (lpfc_ncmd) { if (lpfc_ncmd) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
lpfc_ncmd->data, lpfc_ncmd->data,
lpfc_ncmd->dma_handle); lpfc_ncmd->dma_handle);
kfree(lpfc_ncmd); kfree(lpfc_ncmd);
...@@ -6846,8 +6846,8 @@ lpfc_create_shost(struct lpfc_hba *phba) ...@@ -6846,8 +6846,8 @@ lpfc_create_shost(struct lpfc_hba *phba)
if (phba->nvmet_support) { if (phba->nvmet_support) {
/* Only 1 vport (pport) will support NVME target */ /* Only 1 vport (pport) will support NVME target */
if (phba->txrdy_payload_pool == NULL) { if (phba->txrdy_payload_pool == NULL) {
phba->txrdy_payload_pool = pci_pool_create( phba->txrdy_payload_pool = dma_pool_create(
"txrdy_pool", phba->pcidev, "txrdy_pool", &phba->pcidev->dev,
TXRDY_PAYLOAD_LEN, 16, 0); TXRDY_PAYLOAD_LEN, 16, 0);
if (phba->txrdy_payload_pool) { if (phba->txrdy_payload_pool) {
phba->targetport = NULL; phba->targetport = NULL;
......
...@@ -97,8 +97,8 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align) ...@@ -97,8 +97,8 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align)
i = SLI4_PAGE_SIZE; i = SLI4_PAGE_SIZE;
phba->lpfc_sg_dma_buf_pool = phba->lpfc_sg_dma_buf_pool =
pci_pool_create("lpfc_sg_dma_buf_pool", dma_pool_create("lpfc_sg_dma_buf_pool",
phba->pcidev, &phba->pcidev->dev,
phba->cfg_sg_dma_buf_size, phba->cfg_sg_dma_buf_size,
i, 0); i, 0);
if (!phba->lpfc_sg_dma_buf_pool) if (!phba->lpfc_sg_dma_buf_pool)
...@@ -106,15 +106,15 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align) ...@@ -106,15 +106,15 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align)
} else { } else {
phba->lpfc_sg_dma_buf_pool = phba->lpfc_sg_dma_buf_pool =
pci_pool_create("lpfc_sg_dma_buf_pool", dma_pool_create("lpfc_sg_dma_buf_pool",
phba->pcidev, phba->cfg_sg_dma_buf_size, &phba->pcidev->dev, phba->cfg_sg_dma_buf_size,
align, 0); align, 0);
if (!phba->lpfc_sg_dma_buf_pool) if (!phba->lpfc_sg_dma_buf_pool)
goto fail; goto fail;
} }
phba->lpfc_mbuf_pool = pci_pool_create("lpfc_mbuf_pool", phba->pcidev, phba->lpfc_mbuf_pool = dma_pool_create("lpfc_mbuf_pool", &phba->pcidev->dev,
LPFC_BPL_SIZE, LPFC_BPL_SIZE,
align, 0); align, 0);
if (!phba->lpfc_mbuf_pool) if (!phba->lpfc_mbuf_pool)
...@@ -128,7 +128,7 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align) ...@@ -128,7 +128,7 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align)
pool->max_count = 0; pool->max_count = 0;
pool->current_count = 0; pool->current_count = 0;
for ( i = 0; i < LPFC_MBUF_POOL_SIZE; i++) { for ( i = 0; i < LPFC_MBUF_POOL_SIZE; i++) {
pool->elements[i].virt = pci_pool_alloc(phba->lpfc_mbuf_pool, pool->elements[i].virt = dma_pool_alloc(phba->lpfc_mbuf_pool,
GFP_KERNEL, &pool->elements[i].phys); GFP_KERNEL, &pool->elements[i].phys);
if (!pool->elements[i].virt) if (!pool->elements[i].virt)
goto fail_free_mbuf_pool; goto fail_free_mbuf_pool;
...@@ -152,21 +152,21 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align) ...@@ -152,21 +152,21 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align)
sizeof(struct lpfc_node_rrq)); sizeof(struct lpfc_node_rrq));
if (!phba->rrq_pool) if (!phba->rrq_pool)
goto fail_free_nlp_mem_pool; goto fail_free_nlp_mem_pool;
phba->lpfc_hrb_pool = pci_pool_create("lpfc_hrb_pool", phba->lpfc_hrb_pool = dma_pool_create("lpfc_hrb_pool",
phba->pcidev, &phba->pcidev->dev,
LPFC_HDR_BUF_SIZE, align, 0); LPFC_HDR_BUF_SIZE, align, 0);
if (!phba->lpfc_hrb_pool) if (!phba->lpfc_hrb_pool)
goto fail_free_rrq_mem_pool; goto fail_free_rrq_mem_pool;
phba->lpfc_drb_pool = pci_pool_create("lpfc_drb_pool", phba->lpfc_drb_pool = dma_pool_create("lpfc_drb_pool",
phba->pcidev, &phba->pcidev->dev,
LPFC_DATA_BUF_SIZE, align, 0); LPFC_DATA_BUF_SIZE, align, 0);
if (!phba->lpfc_drb_pool) if (!phba->lpfc_drb_pool)
goto fail_free_hrb_pool; goto fail_free_hrb_pool;
phba->lpfc_hbq_pool = NULL; phba->lpfc_hbq_pool = NULL;
} else { } else {
phba->lpfc_hbq_pool = pci_pool_create("lpfc_hbq_pool", phba->lpfc_hbq_pool = dma_pool_create("lpfc_hbq_pool",
phba->pcidev, LPFC_BPL_SIZE, align, 0); &phba->pcidev->dev, LPFC_BPL_SIZE, align, 0);
if (!phba->lpfc_hbq_pool) if (!phba->lpfc_hbq_pool)
goto fail_free_nlp_mem_pool; goto fail_free_nlp_mem_pool;
phba->lpfc_hrb_pool = NULL; phba->lpfc_hrb_pool = NULL;
...@@ -185,10 +185,10 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align) ...@@ -185,10 +185,10 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align)
return 0; return 0;
fail_free_drb_pool: fail_free_drb_pool:
pci_pool_destroy(phba->lpfc_drb_pool); dma_pool_destroy(phba->lpfc_drb_pool);
phba->lpfc_drb_pool = NULL; phba->lpfc_drb_pool = NULL;
fail_free_hrb_pool: fail_free_hrb_pool:
pci_pool_destroy(phba->lpfc_hrb_pool); dma_pool_destroy(phba->lpfc_hrb_pool);
phba->lpfc_hrb_pool = NULL; phba->lpfc_hrb_pool = NULL;
fail_free_rrq_mem_pool: fail_free_rrq_mem_pool:
mempool_destroy(phba->rrq_pool); mempool_destroy(phba->rrq_pool);
...@@ -201,14 +201,14 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align) ...@@ -201,14 +201,14 @@ lpfc_mem_alloc(struct lpfc_hba *phba, int align)
phba->mbox_mem_pool = NULL; phba->mbox_mem_pool = NULL;
fail_free_mbuf_pool: fail_free_mbuf_pool:
while (i--) while (i--)
pci_pool_free(phba->lpfc_mbuf_pool, pool->elements[i].virt, dma_pool_free(phba->lpfc_mbuf_pool, pool->elements[i].virt,
pool->elements[i].phys); pool->elements[i].phys);
kfree(pool->elements); kfree(pool->elements);
fail_free_lpfc_mbuf_pool: fail_free_lpfc_mbuf_pool:
pci_pool_destroy(phba->lpfc_mbuf_pool); dma_pool_destroy(phba->lpfc_mbuf_pool);
phba->lpfc_mbuf_pool = NULL; phba->lpfc_mbuf_pool = NULL;
fail_free_dma_buf_pool: fail_free_dma_buf_pool:
pci_pool_destroy(phba->lpfc_sg_dma_buf_pool); dma_pool_destroy(phba->lpfc_sg_dma_buf_pool);
phba->lpfc_sg_dma_buf_pool = NULL; phba->lpfc_sg_dma_buf_pool = NULL;
fail: fail:
return -ENOMEM; return -ENOMEM;
...@@ -218,8 +218,8 @@ int ...@@ -218,8 +218,8 @@ int
lpfc_nvmet_mem_alloc(struct lpfc_hba *phba) lpfc_nvmet_mem_alloc(struct lpfc_hba *phba)
{ {
phba->lpfc_nvmet_drb_pool = phba->lpfc_nvmet_drb_pool =
pci_pool_create("lpfc_nvmet_drb_pool", dma_pool_create("lpfc_nvmet_drb_pool",
phba->pcidev, LPFC_NVMET_DATA_BUF_SIZE, &phba->pcidev->dev, LPFC_NVMET_DATA_BUF_SIZE,
SGL_ALIGN_SZ, 0); SGL_ALIGN_SZ, 0);
if (!phba->lpfc_nvmet_drb_pool) { if (!phba->lpfc_nvmet_drb_pool) {
lpfc_printf_log(phba, KERN_ERR, LOG_INIT, lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
...@@ -248,20 +248,20 @@ lpfc_mem_free(struct lpfc_hba *phba) ...@@ -248,20 +248,20 @@ lpfc_mem_free(struct lpfc_hba *phba)
/* Free HBQ pools */ /* Free HBQ pools */
lpfc_sli_hbqbuf_free_all(phba); lpfc_sli_hbqbuf_free_all(phba);
if (phba->lpfc_nvmet_drb_pool) if (phba->lpfc_nvmet_drb_pool)
pci_pool_destroy(phba->lpfc_nvmet_drb_pool); dma_pool_destroy(phba->lpfc_nvmet_drb_pool);
phba->lpfc_nvmet_drb_pool = NULL; phba->lpfc_nvmet_drb_pool = NULL;
if (phba->lpfc_drb_pool) if (phba->lpfc_drb_pool)
pci_pool_destroy(phba->lpfc_drb_pool); dma_pool_destroy(phba->lpfc_drb_pool);
phba->lpfc_drb_pool = NULL; phba->lpfc_drb_pool = NULL;
if (phba->lpfc_hrb_pool) if (phba->lpfc_hrb_pool)
pci_pool_destroy(phba->lpfc_hrb_pool); dma_pool_destroy(phba->lpfc_hrb_pool);
phba->lpfc_hrb_pool = NULL; phba->lpfc_hrb_pool = NULL;
if (phba->txrdy_payload_pool) if (phba->txrdy_payload_pool)
pci_pool_destroy(phba->txrdy_payload_pool); dma_pool_destroy(phba->txrdy_payload_pool);
phba->txrdy_payload_pool = NULL; phba->txrdy_payload_pool = NULL;
if (phba->lpfc_hbq_pool) if (phba->lpfc_hbq_pool)
pci_pool_destroy(phba->lpfc_hbq_pool); dma_pool_destroy(phba->lpfc_hbq_pool);
phba->lpfc_hbq_pool = NULL; phba->lpfc_hbq_pool = NULL;
if (phba->rrq_pool) if (phba->rrq_pool)
...@@ -282,15 +282,15 @@ lpfc_mem_free(struct lpfc_hba *phba) ...@@ -282,15 +282,15 @@ lpfc_mem_free(struct lpfc_hba *phba)
/* Free MBUF memory pool */ /* Free MBUF memory pool */
for (i = 0; i < pool->current_count; i++) for (i = 0; i < pool->current_count; i++)
pci_pool_free(phba->lpfc_mbuf_pool, pool->elements[i].virt, dma_pool_free(phba->lpfc_mbuf_pool, pool->elements[i].virt,
pool->elements[i].phys); pool->elements[i].phys);
kfree(pool->elements); kfree(pool->elements);
pci_pool_destroy(phba->lpfc_mbuf_pool); dma_pool_destroy(phba->lpfc_mbuf_pool);
phba->lpfc_mbuf_pool = NULL; phba->lpfc_mbuf_pool = NULL;
/* Free DMA buffer memory pool */ /* Free DMA buffer memory pool */
pci_pool_destroy(phba->lpfc_sg_dma_buf_pool); dma_pool_destroy(phba->lpfc_sg_dma_buf_pool);
phba->lpfc_sg_dma_buf_pool = NULL; phba->lpfc_sg_dma_buf_pool = NULL;
/* Free Device Data memory pool */ /* Free Device Data memory pool */
...@@ -379,7 +379,7 @@ lpfc_mem_free_all(struct lpfc_hba *phba) ...@@ -379,7 +379,7 @@ lpfc_mem_free_all(struct lpfc_hba *phba)
* @handle: used to return the DMA-mapped address of the mbuf * @handle: used to return the DMA-mapped address of the mbuf
* *
* Description: Allocates a DMA-mapped buffer from the lpfc_mbuf_pool PCI pool. * Description: Allocates a DMA-mapped buffer from the lpfc_mbuf_pool PCI pool.
* Allocates from generic pci_pool_alloc function first and if that fails and * Allocates from generic dma_pool_alloc function first and if that fails and
* mem_flags has MEM_PRI set (the only defined flag), returns an mbuf from the * mem_flags has MEM_PRI set (the only defined flag), returns an mbuf from the
* HBA's pool. * HBA's pool.
* *
...@@ -397,7 +397,7 @@ lpfc_mbuf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle) ...@@ -397,7 +397,7 @@ lpfc_mbuf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle)
unsigned long iflags; unsigned long iflags;
void *ret; void *ret;
ret = pci_pool_alloc(phba->lpfc_mbuf_pool, GFP_KERNEL, handle); ret = dma_pool_alloc(phba->lpfc_mbuf_pool, GFP_KERNEL, handle);
spin_lock_irqsave(&phba->hbalock, iflags); spin_lock_irqsave(&phba->hbalock, iflags);
if (!ret && (mem_flags & MEM_PRI) && pool->current_count) { if (!ret && (mem_flags & MEM_PRI) && pool->current_count) {
...@@ -433,7 +433,7 @@ __lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma) ...@@ -433,7 +433,7 @@ __lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma)
pool->elements[pool->current_count].phys = dma; pool->elements[pool->current_count].phys = dma;
pool->current_count++; pool->current_count++;
} else { } else {
pci_pool_free(phba->lpfc_mbuf_pool, virt, dma); dma_pool_free(phba->lpfc_mbuf_pool, virt, dma);
} }
return; return;
} }
...@@ -470,7 +470,7 @@ lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma) ...@@ -470,7 +470,7 @@ lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma)
* @handle: used to return the DMA-mapped address of the nvmet_buf * @handle: used to return the DMA-mapped address of the nvmet_buf
* *
* Description: Allocates a DMA-mapped buffer from the lpfc_sg_dma_buf_pool * Description: Allocates a DMA-mapped buffer from the lpfc_sg_dma_buf_pool
* PCI pool. Allocates from generic pci_pool_alloc function. * PCI pool. Allocates from generic dma_pool_alloc function.
* *
* Returns: * Returns:
* pointer to the allocated nvmet_buf on success * pointer to the allocated nvmet_buf on success
...@@ -481,7 +481,7 @@ lpfc_nvmet_buf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle) ...@@ -481,7 +481,7 @@ lpfc_nvmet_buf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle)
{ {
void *ret; void *ret;
ret = pci_pool_alloc(phba->lpfc_sg_dma_buf_pool, GFP_KERNEL, handle); ret = dma_pool_alloc(phba->lpfc_sg_dma_buf_pool, GFP_KERNEL, handle);
return ret; return ret;
} }
...@@ -497,7 +497,7 @@ lpfc_nvmet_buf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle) ...@@ -497,7 +497,7 @@ lpfc_nvmet_buf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle)
void void
lpfc_nvmet_buf_free(struct lpfc_hba *phba, void *virt, dma_addr_t dma) lpfc_nvmet_buf_free(struct lpfc_hba *phba, void *virt, dma_addr_t dma)
{ {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, virt, dma); dma_pool_free(phba->lpfc_sg_dma_buf_pool, virt, dma);
} }
/** /**
...@@ -522,7 +522,7 @@ lpfc_els_hbq_alloc(struct lpfc_hba *phba) ...@@ -522,7 +522,7 @@ lpfc_els_hbq_alloc(struct lpfc_hba *phba)
if (!hbqbp) if (!hbqbp)
return NULL; return NULL;
hbqbp->dbuf.virt = pci_pool_alloc(phba->lpfc_hbq_pool, GFP_KERNEL, hbqbp->dbuf.virt = dma_pool_alloc(phba->lpfc_hbq_pool, GFP_KERNEL,
&hbqbp->dbuf.phys); &hbqbp->dbuf.phys);
if (!hbqbp->dbuf.virt) { if (!hbqbp->dbuf.virt) {
kfree(hbqbp); kfree(hbqbp);
...@@ -547,7 +547,7 @@ lpfc_els_hbq_alloc(struct lpfc_hba *phba) ...@@ -547,7 +547,7 @@ lpfc_els_hbq_alloc(struct lpfc_hba *phba)
void void
lpfc_els_hbq_free(struct lpfc_hba *phba, struct hbq_dmabuf *hbqbp) lpfc_els_hbq_free(struct lpfc_hba *phba, struct hbq_dmabuf *hbqbp)
{ {
pci_pool_free(phba->lpfc_hbq_pool, hbqbp->dbuf.virt, hbqbp->dbuf.phys); dma_pool_free(phba->lpfc_hbq_pool, hbqbp->dbuf.virt, hbqbp->dbuf.phys);
kfree(hbqbp); kfree(hbqbp);
return; return;
} }
...@@ -574,16 +574,16 @@ lpfc_sli4_rb_alloc(struct lpfc_hba *phba) ...@@ -574,16 +574,16 @@ lpfc_sli4_rb_alloc(struct lpfc_hba *phba)
if (!dma_buf) if (!dma_buf)
return NULL; return NULL;
dma_buf->hbuf.virt = pci_pool_alloc(phba->lpfc_hrb_pool, GFP_KERNEL, dma_buf->hbuf.virt = dma_pool_alloc(phba->lpfc_hrb_pool, GFP_KERNEL,
&dma_buf->hbuf.phys); &dma_buf->hbuf.phys);
if (!dma_buf->hbuf.virt) { if (!dma_buf->hbuf.virt) {
kfree(dma_buf); kfree(dma_buf);
return NULL; return NULL;
} }
dma_buf->dbuf.virt = pci_pool_alloc(phba->lpfc_drb_pool, GFP_KERNEL, dma_buf->dbuf.virt = dma_pool_alloc(phba->lpfc_drb_pool, GFP_KERNEL,
&dma_buf->dbuf.phys); &dma_buf->dbuf.phys);
if (!dma_buf->dbuf.virt) { if (!dma_buf->dbuf.virt) {
pci_pool_free(phba->lpfc_hrb_pool, dma_buf->hbuf.virt, dma_pool_free(phba->lpfc_hrb_pool, dma_buf->hbuf.virt,
dma_buf->hbuf.phys); dma_buf->hbuf.phys);
kfree(dma_buf); kfree(dma_buf);
return NULL; return NULL;
...@@ -607,8 +607,8 @@ lpfc_sli4_rb_alloc(struct lpfc_hba *phba) ...@@ -607,8 +607,8 @@ lpfc_sli4_rb_alloc(struct lpfc_hba *phba)
void void
lpfc_sli4_rb_free(struct lpfc_hba *phba, struct hbq_dmabuf *dmab) lpfc_sli4_rb_free(struct lpfc_hba *phba, struct hbq_dmabuf *dmab)
{ {
pci_pool_free(phba->lpfc_hrb_pool, dmab->hbuf.virt, dmab->hbuf.phys); dma_pool_free(phba->lpfc_hrb_pool, dmab->hbuf.virt, dmab->hbuf.phys);
pci_pool_free(phba->lpfc_drb_pool, dmab->dbuf.virt, dmab->dbuf.phys); dma_pool_free(phba->lpfc_drb_pool, dmab->dbuf.virt, dmab->dbuf.phys);
kfree(dmab); kfree(dmab);
} }
...@@ -634,16 +634,16 @@ lpfc_sli4_nvmet_alloc(struct lpfc_hba *phba) ...@@ -634,16 +634,16 @@ lpfc_sli4_nvmet_alloc(struct lpfc_hba *phba)
if (!dma_buf) if (!dma_buf)
return NULL; return NULL;
dma_buf->hbuf.virt = pci_pool_alloc(phba->lpfc_hrb_pool, GFP_KERNEL, dma_buf->hbuf.virt = dma_pool_alloc(phba->lpfc_hrb_pool, GFP_KERNEL,
&dma_buf->hbuf.phys); &dma_buf->hbuf.phys);
if (!dma_buf->hbuf.virt) { if (!dma_buf->hbuf.virt) {
kfree(dma_buf); kfree(dma_buf);
return NULL; return NULL;
} }
dma_buf->dbuf.virt = pci_pool_alloc(phba->lpfc_nvmet_drb_pool, dma_buf->dbuf.virt = dma_pool_alloc(phba->lpfc_nvmet_drb_pool,
GFP_KERNEL, &dma_buf->dbuf.phys); GFP_KERNEL, &dma_buf->dbuf.phys);
if (!dma_buf->dbuf.virt) { if (!dma_buf->dbuf.virt) {
pci_pool_free(phba->lpfc_hrb_pool, dma_buf->hbuf.virt, dma_pool_free(phba->lpfc_hrb_pool, dma_buf->hbuf.virt,
dma_buf->hbuf.phys); dma_buf->hbuf.phys);
kfree(dma_buf); kfree(dma_buf);
return NULL; return NULL;
...@@ -667,8 +667,8 @@ lpfc_sli4_nvmet_alloc(struct lpfc_hba *phba) ...@@ -667,8 +667,8 @@ lpfc_sli4_nvmet_alloc(struct lpfc_hba *phba)
void void
lpfc_sli4_nvmet_free(struct lpfc_hba *phba, struct rqb_dmabuf *dmab) lpfc_sli4_nvmet_free(struct lpfc_hba *phba, struct rqb_dmabuf *dmab)
{ {
pci_pool_free(phba->lpfc_hrb_pool, dmab->hbuf.virt, dmab->hbuf.phys); dma_pool_free(phba->lpfc_hrb_pool, dmab->hbuf.virt, dmab->hbuf.phys);
pci_pool_free(phba->lpfc_nvmet_drb_pool, dma_pool_free(phba->lpfc_nvmet_drb_pool,
dmab->dbuf.virt, dmab->dbuf.phys); dmab->dbuf.virt, dmab->dbuf.phys);
kfree(dmab); kfree(dmab);
} }
......
...@@ -1939,7 +1939,7 @@ lpfc_new_nvme_buf(struct lpfc_vport *vport, int num_to_alloc) ...@@ -1939,7 +1939,7 @@ lpfc_new_nvme_buf(struct lpfc_vport *vport, int num_to_alloc)
* pci bus space for an I/O. The DMA buffer includes the * pci bus space for an I/O. The DMA buffer includes the
* number of SGE's necessary to support the sg_tablesize. * number of SGE's necessary to support the sg_tablesize.
*/ */
lpfc_ncmd->data = pci_pool_alloc(phba->lpfc_sg_dma_buf_pool, lpfc_ncmd->data = dma_pool_alloc(phba->lpfc_sg_dma_buf_pool,
GFP_KERNEL, GFP_KERNEL,
&lpfc_ncmd->dma_handle); &lpfc_ncmd->dma_handle);
if (!lpfc_ncmd->data) { if (!lpfc_ncmd->data) {
...@@ -1950,7 +1950,7 @@ lpfc_new_nvme_buf(struct lpfc_vport *vport, int num_to_alloc) ...@@ -1950,7 +1950,7 @@ lpfc_new_nvme_buf(struct lpfc_vport *vport, int num_to_alloc)
lxri = lpfc_sli4_next_xritag(phba); lxri = lpfc_sli4_next_xritag(phba);
if (lxri == NO_XRI) { if (lxri == NO_XRI) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
lpfc_ncmd->data, lpfc_ncmd->dma_handle); lpfc_ncmd->data, lpfc_ncmd->dma_handle);
kfree(lpfc_ncmd); kfree(lpfc_ncmd);
break; break;
...@@ -1961,7 +1961,7 @@ lpfc_new_nvme_buf(struct lpfc_vport *vport, int num_to_alloc) ...@@ -1961,7 +1961,7 @@ lpfc_new_nvme_buf(struct lpfc_vport *vport, int num_to_alloc)
/* Allocate iotag for lpfc_ncmd->cur_iocbq. */ /* Allocate iotag for lpfc_ncmd->cur_iocbq. */
iotag = lpfc_sli_next_iotag(phba, pwqeq); iotag = lpfc_sli_next_iotag(phba, pwqeq);
if (iotag == 0) { if (iotag == 0) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
lpfc_ncmd->data, lpfc_ncmd->dma_handle); lpfc_ncmd->data, lpfc_ncmd->dma_handle);
kfree(lpfc_ncmd); kfree(lpfc_ncmd);
lpfc_printf_log(phba, KERN_ERR, LOG_NVME_IOERR, lpfc_printf_log(phba, KERN_ERR, LOG_NVME_IOERR,
......
...@@ -175,7 +175,7 @@ lpfc_nvmet_ctxbuf_post(struct lpfc_hba *phba, struct lpfc_nvmet_ctxbuf *ctx_buf) ...@@ -175,7 +175,7 @@ lpfc_nvmet_ctxbuf_post(struct lpfc_hba *phba, struct lpfc_nvmet_ctxbuf *ctx_buf)
unsigned long iflag; unsigned long iflag;
if (ctxp->txrdy) { if (ctxp->txrdy) {
pci_pool_free(phba->txrdy_payload_pool, ctxp->txrdy, dma_pool_free(phba->txrdy_payload_pool, ctxp->txrdy,
ctxp->txrdy_phys); ctxp->txrdy_phys);
ctxp->txrdy = NULL; ctxp->txrdy = NULL;
ctxp->txrdy_phys = 0; ctxp->txrdy_phys = 0;
...@@ -1909,7 +1909,7 @@ lpfc_nvmet_prep_fcp_wqe(struct lpfc_hba *phba, ...@@ -1909,7 +1909,7 @@ lpfc_nvmet_prep_fcp_wqe(struct lpfc_hba *phba,
case NVMET_FCOP_WRITEDATA: case NVMET_FCOP_WRITEDATA:
/* Words 0 - 2 : The first sg segment */ /* Words 0 - 2 : The first sg segment */
txrdy = pci_pool_alloc(phba->txrdy_payload_pool, txrdy = dma_pool_alloc(phba->txrdy_payload_pool,
GFP_KERNEL, &physaddr); GFP_KERNEL, &physaddr);
if (!txrdy) { if (!txrdy) {
lpfc_printf_log(phba, KERN_ERR, LOG_NVME_IOERR, lpfc_printf_log(phba, KERN_ERR, LOG_NVME_IOERR,
......
...@@ -416,7 +416,7 @@ lpfc_new_scsi_buf_s3(struct lpfc_vport *vport, int num_to_alloc) ...@@ -416,7 +416,7 @@ lpfc_new_scsi_buf_s3(struct lpfc_vport *vport, int num_to_alloc)
* struct fcp_cmnd, struct fcp_rsp and the number of bde's * struct fcp_cmnd, struct fcp_rsp and the number of bde's
* necessary to support the sg_tablesize. * necessary to support the sg_tablesize.
*/ */
psb->data = pci_pool_zalloc(phba->lpfc_sg_dma_buf_pool, psb->data = dma_pool_zalloc(phba->lpfc_sg_dma_buf_pool,
GFP_KERNEL, &psb->dma_handle); GFP_KERNEL, &psb->dma_handle);
if (!psb->data) { if (!psb->data) {
kfree(psb); kfree(psb);
...@@ -427,7 +427,7 @@ lpfc_new_scsi_buf_s3(struct lpfc_vport *vport, int num_to_alloc) ...@@ -427,7 +427,7 @@ lpfc_new_scsi_buf_s3(struct lpfc_vport *vport, int num_to_alloc)
/* Allocate iotag for psb->cur_iocbq. */ /* Allocate iotag for psb->cur_iocbq. */
iotag = lpfc_sli_next_iotag(phba, &psb->cur_iocbq); iotag = lpfc_sli_next_iotag(phba, &psb->cur_iocbq);
if (iotag == 0) { if (iotag == 0) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
psb->data, psb->dma_handle); psb->data, psb->dma_handle);
kfree(psb); kfree(psb);
break; break;
...@@ -826,7 +826,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc) ...@@ -826,7 +826,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc)
* for the struct fcp_cmnd, struct fcp_rsp and the number * for the struct fcp_cmnd, struct fcp_rsp and the number
* of bde's necessary to support the sg_tablesize. * of bde's necessary to support the sg_tablesize.
*/ */
psb->data = pci_pool_zalloc(phba->lpfc_sg_dma_buf_pool, psb->data = dma_pool_zalloc(phba->lpfc_sg_dma_buf_pool,
GFP_KERNEL, &psb->dma_handle); GFP_KERNEL, &psb->dma_handle);
if (!psb->data) { if (!psb->data) {
kfree(psb); kfree(psb);
...@@ -839,7 +839,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc) ...@@ -839,7 +839,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc)
*/ */
if (phba->cfg_enable_bg && (((unsigned long)(psb->data) & if (phba->cfg_enable_bg && (((unsigned long)(psb->data) &
(unsigned long)(SLI4_PAGE_SIZE - 1)) != 0)) { (unsigned long)(SLI4_PAGE_SIZE - 1)) != 0)) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
psb->data, psb->dma_handle); psb->data, psb->dma_handle);
kfree(psb); kfree(psb);
break; break;
...@@ -848,7 +848,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc) ...@@ -848,7 +848,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc)
lxri = lpfc_sli4_next_xritag(phba); lxri = lpfc_sli4_next_xritag(phba);
if (lxri == NO_XRI) { if (lxri == NO_XRI) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
psb->data, psb->dma_handle); psb->data, psb->dma_handle);
kfree(psb); kfree(psb);
break; break;
...@@ -857,7 +857,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc) ...@@ -857,7 +857,7 @@ lpfc_new_scsi_buf_s4(struct lpfc_vport *vport, int num_to_alloc)
/* Allocate iotag for psb->cur_iocbq. */ /* Allocate iotag for psb->cur_iocbq. */
iotag = lpfc_sli_next_iotag(phba, &psb->cur_iocbq); iotag = lpfc_sli_next_iotag(phba, &psb->cur_iocbq);
if (iotag == 0) { if (iotag == 0) {
pci_pool_free(phba->lpfc_sg_dma_buf_pool, dma_pool_free(phba->lpfc_sg_dma_buf_pool,
psb->data, psb->dma_handle); psb->data, psb->dma_handle);
kfree(psb); kfree(psb);
lpfc_printf_log(phba, KERN_ERR, LOG_FCP, lpfc_printf_log(phba, KERN_ERR, LOG_FCP,
......
...@@ -17051,7 +17051,7 @@ lpfc_sli4_mds_loopback_cmpl(struct lpfc_hba *phba, struct lpfc_iocbq *cmdiocb, ...@@ -17051,7 +17051,7 @@ lpfc_sli4_mds_loopback_cmpl(struct lpfc_hba *phba, struct lpfc_iocbq *cmdiocb,
struct lpfc_dmabuf *pcmd = cmdiocb->context2; struct lpfc_dmabuf *pcmd = cmdiocb->context2;
if (pcmd && pcmd->virt) if (pcmd && pcmd->virt)
pci_pool_free(phba->lpfc_drb_pool, pcmd->virt, pcmd->phys); dma_pool_free(phba->lpfc_drb_pool, pcmd->virt, pcmd->phys);
kfree(pcmd); kfree(pcmd);
lpfc_sli_release_iocbq(phba, cmdiocb); lpfc_sli_release_iocbq(phba, cmdiocb);
} }
...@@ -17079,7 +17079,7 @@ lpfc_sli4_handle_mds_loopback(struct lpfc_vport *vport, ...@@ -17079,7 +17079,7 @@ lpfc_sli4_handle_mds_loopback(struct lpfc_vport *vport,
/* Allocate buffer for command payload */ /* Allocate buffer for command payload */
pcmd = kmalloc(sizeof(struct lpfc_dmabuf), GFP_KERNEL); pcmd = kmalloc(sizeof(struct lpfc_dmabuf), GFP_KERNEL);
if (pcmd) if (pcmd)
pcmd->virt = pci_pool_alloc(phba->lpfc_drb_pool, GFP_KERNEL, pcmd->virt = dma_pool_alloc(phba->lpfc_drb_pool, GFP_KERNEL,
&pcmd->phys); &pcmd->phys);
if (!pcmd || !pcmd->virt) if (!pcmd || !pcmd->virt)
goto exit; goto exit;
...@@ -17128,7 +17128,7 @@ lpfc_sli4_handle_mds_loopback(struct lpfc_vport *vport, ...@@ -17128,7 +17128,7 @@ lpfc_sli4_handle_mds_loopback(struct lpfc_vport *vport,
lpfc_printf_log(phba, KERN_WARNING, LOG_SLI, lpfc_printf_log(phba, KERN_WARNING, LOG_SLI,
"2023 Unable to process MDS loopback frame\n"); "2023 Unable to process MDS loopback frame\n");
if (pcmd && pcmd->virt) if (pcmd && pcmd->virt)
pci_pool_free(phba->lpfc_drb_pool, pcmd->virt, pcmd->phys); dma_pool_free(phba->lpfc_drb_pool, pcmd->virt, pcmd->phys);
kfree(pcmd); kfree(pcmd);
lpfc_sli_release_iocbq(phba, iocbq); lpfc_sli_release_iocbq(phba, iocbq);
lpfc_in_buf_free(phba, &dmabuf->dbuf); lpfc_in_buf_free(phba, &dmabuf->dbuf);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册