Skip to content

Commit

Permalink
Merge pull request #315 from deepin-community/revert-314-bai/linux-6.…
Browse files Browse the repository at this point in the history
…6.36-nouveau-fix

Revert "Reapply "drm/nouveau/firmware: Fix SG_DEBUG error with nvkm_firmware_ctor()"
  • Loading branch information
opsiff authored Jul 9, 2024
2 parents 90a069f + bb7dbd4 commit 203f542
Showing 1 changed file with 7 additions and 12 deletions.
19 changes: 7 additions & 12 deletions drivers/gpu/drm/nouveau/nvkm/core/firmware.c
Original file line number Diff line number Diff line change
Expand Up @@ -187,9 +187,7 @@ nvkm_firmware_dtor(struct nvkm_firmware *fw)
break;
case NVKM_FIRMWARE_IMG_DMA:
nvkm_memory_unref(&memory);
dma_unmap_single(fw->device->dev, fw->phys, sg_dma_len(&fw->mem.sgl),
DMA_TO_DEVICE);
kfree(fw->img);
dma_free_coherent(fw->device->dev, sg_dma_len(&fw->mem.sgl), fw->img, fw->phys);
break;
default:
WARN_ON(1);
Expand All @@ -213,17 +211,14 @@ nvkm_firmware_ctor(const struct nvkm_firmware_func *func, const char *name,
fw->img = kmemdup(src, fw->len, GFP_KERNEL);
break;
case NVKM_FIRMWARE_IMG_DMA: {
len = ALIGN(fw->len, PAGE_SIZE);
dma_addr_t addr;

fw->img = kmalloc(len, GFP_KERNEL);
if (!fw->img)
return -ENOMEM;
len = ALIGN(fw->len, PAGE_SIZE);

memcpy(fw->img, src, fw->len);
fw->phys = dma_map_single(fw->device->dev, fw->img, len, DMA_TO_DEVICE);
if (dma_mapping_error(fw->device->dev, fw->phys)) {
kfree(fw->img);
return -EFAULT;
fw->img = dma_alloc_coherent(fw->device->dev, len, &addr, GFP_KERNEL);
if (fw->img) {
memcpy(fw->img, src, fw->len);
fw->phys = addr;
}

sg_init_one(&fw->mem.sgl, fw->img, len);
Expand Down

0 comments on commit 203f542

Please sign in to comment.