mirror of
https://github.com/torvalds/linux.git
synced 2025-12-01 07:26:02 +07:00
scsi: ufs: mcq: Fix memory allocation checks for SQE and CQE
Previous checks incorrectly tested the DMA addresses (dma_handle) for
NULL. Since dma_alloc_coherent() returns the CPU (virtual) address, the
NULL check should be performed on the *_base_addr pointer to correctly
detect allocation failures.
Update the checks to validate sqe_base_addr and cqe_base_addr instead of
sqe_dma_addr and cqe_dma_addr.
Fixes: 4682abfae2 ("scsi: ufs: core: mcq: Allocate memory for MCQ mode")
Signed-off-by: Alok Tiwari <alok.a.tiwari@oracle.com>
Reviewed-by: Alim Akhtar <alim.akhtar@samsung.com>
Reviewed-by: Manivannan Sadhasivam <mani@kernel.org>
Reviewed-by: Peter Wang <peter.wang@mediatek.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
committed by
Martin K. Petersen
parent
708e2371f7
commit
5cb782ff3c
@@ -243,7 +243,7 @@ int ufshcd_mcq_memory_alloc(struct ufs_hba *hba)
|
||||
hwq->sqe_base_addr = dmam_alloc_coherent(hba->dev, utrdl_size,
|
||||
&hwq->sqe_dma_addr,
|
||||
GFP_KERNEL);
|
||||
if (!hwq->sqe_dma_addr) {
|
||||
if (!hwq->sqe_base_addr) {
|
||||
dev_err(hba->dev, "SQE allocation failed\n");
|
||||
return -ENOMEM;
|
||||
}
|
||||
@@ -252,7 +252,7 @@ int ufshcd_mcq_memory_alloc(struct ufs_hba *hba)
|
||||
hwq->cqe_base_addr = dmam_alloc_coherent(hba->dev, cqe_size,
|
||||
&hwq->cqe_dma_addr,
|
||||
GFP_KERNEL);
|
||||
if (!hwq->cqe_dma_addr) {
|
||||
if (!hwq->cqe_base_addr) {
|
||||
dev_err(hba->dev, "CQE allocation failed\n");
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user