amdkfd: add __iomem attribute to doorbell_ptr
authorOded Gabbay <oded.gabbay@amd.com>
Thu, 20 Nov 2014 14:14:56 +0000 (16:14 +0200)
committerOded Gabbay <oded.gabbay@amd.com>
Thu, 20 Nov 2014 14:14:56 +0000 (16:14 +0200)
This patch was done due to sparse warning. It changes the definition of
doorbell_ptr in queue_properties to be with __iomem attribute, so it would
match the type which the doorbell module functions are returning.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Oded Gabbay <oded.gabbay@amd.com>
drivers/gpu/drm/amd/amdkfd/kfd_kernel_queue.c
drivers/gpu/drm/amd/amdkfd/kfd_priv.h

index 424ddccafd4fdb698c05c0959b935179a1d0ecf1..5055fc9c87311781b17c9f1291fbc41b7e419cc9 100644 (file)
@@ -66,8 +66,7 @@ static bool initialize(struct kernel_queue *kq, struct kfd_dev *dev,
        if (kq->mqd == NULL)
                return false;
 
-       prop.doorbell_ptr =
-               (uint32_t *)kfd_get_kernel_doorbell(dev, &prop.doorbell_off);
+       prop.doorbell_ptr = kfd_get_kernel_doorbell(dev, &prop.doorbell_off);
 
        if (prop.doorbell_ptr == NULL)
                goto err_get_kernel_doorbell;
@@ -172,7 +171,7 @@ err_rptr_allocate_vidmem:
        kfd2kgd->free_mem(dev->kgd, (struct kgd_mem *) kq->pq);
 err_pq_allocate_vidmem:
        pr_err("kfd: error init pq\n");
-       kfd_release_kernel_doorbell(dev, (u32 *)prop.doorbell_ptr);
+       kfd_release_kernel_doorbell(dev, prop.doorbell_ptr);
 err_get_kernel_doorbell:
        pr_err("kfd: error init doorbell");
        return false;
@@ -195,7 +194,7 @@ static void uninitialize(struct kernel_queue *kq)
        kfd2kgd->free_mem(kq->dev->kgd, (struct kgd_mem *) kq->wptr_mem);
        kfd2kgd->free_mem(kq->dev->kgd, (struct kgd_mem *) kq->pq);
        kfd_release_kernel_doorbell(kq->dev,
-                               (u32 *)kq->queue->properties.doorbell_ptr);
+                                       kq->queue->properties.doorbell_ptr);
        uninit_queue(kq->queue);
 }
 
@@ -255,7 +254,7 @@ static void submit_packet(struct kernel_queue *kq)
 #endif
 
        *kq->wptr_kernel = kq->pending_wptr;
-       write_kernel_doorbell((u32 *)kq->queue->properties.doorbell_ptr,
+       write_kernel_doorbell(kq->queue->properties.doorbell_ptr,
                                kq->pending_wptr);
 }
 
index 41e608d684b138b386397fa9bdd6ae4f62731c21..d0bcafcf048fcf0b2a9a0cb060d58015ba07fbfa 100644 (file)
@@ -279,7 +279,7 @@ struct queue_properties {
        uint32_t queue_percent;
        uint32_t *read_ptr;
        uint32_t *write_ptr;
-       uint32_t *doorbell_ptr;
+       uint32_t __iomem *doorbell_ptr;
        uint32_t doorbell_off;
        bool is_interop;
        bool is_active;