| /linux/drivers/gpu/drm/amd/amdgpu/ |
| H A D | amdgpu_userq_fence.c | 47 static u64 amdgpu_userq_fence_read(struct amdgpu_userq_fence_driver *fence_drv) in amdgpu_userq_fence_read() argument 49 return le64_to_cpu(*fence_drv->cpu_addr); in amdgpu_userq_fence_read() 53 amdgpu_userq_fence_write(struct amdgpu_userq_fence_driver *fence_drv, in amdgpu_userq_fence_write() argument 56 if (fence_drv->cpu_addr) in amdgpu_userq_fence_write() 57 *fence_drv->cpu_addr = cpu_to_le64(seq); in amdgpu_userq_fence_write() 63 struct amdgpu_userq_fence_driver *fence_drv; in amdgpu_userq_fence_driver_alloc() local 70 fence_drv = kzalloc_obj(*fence_drv); in amdgpu_userq_fence_driver_alloc() 71 if (!fence_drv) in amdgpu_userq_fence_driver_alloc() 75 r = amdgpu_seq64_alloc(adev, &fence_drv->va, &fence_drv->gpu_addr, in amdgpu_userq_fence_driver_alloc() 76 &fence_drv->cpu_addr); in amdgpu_userq_fence_driver_alloc() [all …]
|
| H A D | amdgpu_userq_fence.h | 41 struct amdgpu_userq_fence_driver *fence_drv; member 61 void amdgpu_userq_fence_driver_get(struct amdgpu_userq_fence_driver *fence_drv); 62 void amdgpu_userq_fence_driver_put(struct amdgpu_userq_fence_driver *fence_drv); 66 int amdgpu_userq_fence_driver_process(struct amdgpu_userq_fence_driver *fence_drv);
|
| H A D | umsch_mm_v4_0.c | 310 set_hw_resources.api_status.api_completion_fence_addr = umsch->ring.fence_drv.gpu_addr; in umsch_mm_v4_0_set_hw_resources() 311 set_hw_resources.api_status.api_completion_fence_value = ++umsch->ring.fence_drv.sync_seq; in umsch_mm_v4_0_set_hw_resources() 360 add_queue.api_status.api_completion_fence_addr = umsch->ring.fence_drv.gpu_addr; in umsch_mm_v4_0_add_queue() 361 add_queue.api_status.api_completion_fence_value = ++umsch->ring.fence_drv.sync_seq; in umsch_mm_v4_0_add_queue() 392 remove_queue.api_status.api_completion_fence_addr = umsch->ring.fence_drv.gpu_addr; in umsch_mm_v4_0_remove_queue() 393 remove_queue.api_status.api_completion_fence_value = ++umsch->ring.fence_drv.sync_seq; in umsch_mm_v4_0_remove_queue()
|
| H A D | amdgpu_ring_mux.c | 99 last_seq = atomic_read(&e->ring->fence_drv.last_seq); in amdgpu_mux_resubmit_chunks() 109 le32_to_cpu(*(e->ring->fence_drv.cpu_addr + 2))) { in amdgpu_mux_resubmit_chunks() 474 last_seq = atomic_read(&ring->fence_drv.last_seq); in scan_and_remove_signaled_chunk() 537 chunk->sync_seq = READ_ONCE(ring->fence_drv.sync_seq); in amdgpu_ring_mux_end_ib() 570 mux->seqno_to_resubmit = ring->fence_drv.sync_seq; in amdgpu_mcbp_handle_trailing_fence_irq()
|
| H A D | amdgpu_dev_coredump.c | 546 if (atomic_read(&ring->fence_drv.last_seq) == ring->fence_drv.sync_seq && in amdgpu_coredump() 559 if (atomic_read(&ring->fence_drv.last_seq) == ring->fence_drv.sync_seq && in amdgpu_coredump()
|
| H A D | amdgpu_userq.h | 82 struct amdgpu_userq_fence_driver *fence_drv; member
|
| H A D | amdgpu_userq.c | 199 r = amdgpu_userq_fence_driver_process(queue->fence_drv); in amdgpu_userq_process_fence_irq() 436 queue->fence_drv = NULL; in amdgpu_userq_cleanup() 782 r = amdgpu_userq_fence_driver_alloc(adev, &queue->fence_drv); in amdgpu_userq_create()
|
| H A D | mes_v11_0.c | 208 seq = ++ring->fence_drv.sync_seq; in mes_v11_0_submit_pkt_and_poll_completion() 210 seq - ring->fence_drv.num_fences_mask, in mes_v11_0_submit_pkt_and_poll_completion() 226 ring->fence_drv.gpu_addr; in mes_v11_0_submit_pkt_and_poll_completion()
|
| H A D | mes_userqueue.c | 286 userq_props->fence_address = queue->fence_drv->gpu_addr; in mes_userq_mqd_create()
|
| H A D | mes_v12_0.c | 191 seq = ++ring->fence_drv.sync_seq; in mes_v12_0_submit_pkt_and_poll_completion() 193 seq - ring->fence_drv.num_fences_mask, in mes_v12_0_submit_pkt_and_poll_completion() 209 ring->fence_drv.gpu_addr; in mes_v12_0_submit_pkt_and_poll_completion()
|
| H A D | mes_v12_1.c | 191 seq = ++ring->fence_drv.sync_seq; in mes_v12_1_submit_pkt_and_poll_completion() 193 seq - ring->fence_drv.num_fences_mask, in mes_v12_1_submit_pkt_and_poll_completion() 209 ring->fence_drv.gpu_addr; in mes_v12_1_submit_pkt_and_poll_completion()
|
| H A D | sdma_v7_1.c | 1194 uint32_t seq = ring->fence_drv.sync_seq; in sdma_v7_1_ring_emit_pipeline_sync() 1195 uint64_t addr = ring->fence_drv.gpu_addr; in sdma_v7_1_ring_emit_pipeline_sync()
|
| H A D | sdma_v6_0.c | 1168 uint32_t seq = ring->fence_drv.sync_seq; in sdma_v6_0_ring_emit_pipeline_sync() 1169 uint64_t addr = ring->fence_drv.gpu_addr; in sdma_v6_0_ring_emit_pipeline_sync()
|
| H A D | sdma_v7_0.c | 1188 uint32_t seq = ring->fence_drv.sync_seq; in sdma_v7_0_ring_emit_pipeline_sync() 1189 uint64_t addr = ring->fence_drv.gpu_addr; in sdma_v7_0_ring_emit_pipeline_sync()
|
| /linux/drivers/gpu/drm/radeon/ |
| H A D | radeon_fence.c | 69 struct radeon_fence_driver *drv = &rdev->fence_drv[ring]; in radeon_fence_write() 90 struct radeon_fence_driver *drv = &rdev->fence_drv[ring]; in radeon_fence_read() 119 &rdev->fence_drv[ring].lockup_work, in radeon_fence_schedule_check() 145 (*fence)->seq = seq = ++rdev->fence_drv[ring].sync_seq[ring]; in radeon_fence_emit() 177 seq = atomic64_read(&fence->rdev->fence_drv[fence->ring].last_seq); in radeon_fence_check_signaled() 224 last_seq = atomic64_read(&rdev->fence_drv[ring].last_seq); in radeon_fence_activity() 226 last_emitted = rdev->fence_drv[ring].sync_seq[ring]; in radeon_fence_activity() 251 } while (atomic64_xchg(&rdev->fence_drv[ring].last_seq, seq) > seq); in radeon_fence_activity() 269 struct radeon_fence_driver *fence_drv; in radeon_fence_check_lockup() local 273 fence_drv = container_of(work, struct radeon_fence_driver, in radeon_fence_check_lockup() [all …]
|
| H A D | uvd_v2_2.c | 43 uint64_t addr = rdev->fence_drv[fence->ring].gpu_addr; in uvd_v2_2_fence_emit()
|
| H A D | evergreen_dma.c | 44 u64 addr = rdev->fence_drv[fence->ring].gpu_addr; in evergreen_dma_fence_ring_emit()
|
| H A D | r600_dma.c | 290 u64 addr = rdev->fence_drv[fence->ring].gpu_addr; in r600_dma_fence_ring_emit()
|
| H A D | cik_sdma.c | 203 u64 addr = rdev->fence_drv[fence->ring].gpu_addr; in cik_sdma_fence_ring_emit()
|
| /linux/drivers/gpu/drm/virtio/ |
| H A D | virtgpu_fence.c | 63 struct virtio_gpu_fence_driver *drv = &vgdev->fence_drv; in virtio_gpu_fence_alloc() 88 struct virtio_gpu_fence_driver *drv = &vgdev->fence_drv; in virtio_gpu_fence_emit() 113 struct virtio_gpu_fence_driver *drv = &vgdev->fence_drv; in virtio_gpu_fence_event_process() 118 atomic64_set(&vgdev->fence_drv.last_fence_id, fence_id); in virtio_gpu_fence_event_process()
|
| H A D | virtgpu_kms.c | 150 vgdev->fence_drv.context = dma_fence_context_alloc(1); in virtio_gpu_init() 151 spin_lock_init(&vgdev->fence_drv.lock); in virtio_gpu_init() 152 INIT_LIST_HEAD(&vgdev->fence_drv.fences); in virtio_gpu_init()
|
| H A D | virtgpu_ioctl.c | 172 fence = virtio_gpu_fence_alloc(vgdev, vgdev->fence_drv.context, 0); in virtio_gpu_resource_create_ioctl() 259 fence = virtio_gpu_fence_alloc(vgdev, vgdev->fence_drv.context, 0); in virtio_gpu_transfer_from_host_ioctl() 319 fence = virtio_gpu_fence_alloc(vgdev, vgdev->fence_drv.context, in virtio_gpu_transfer_to_host_ioctl()
|
| H A D | virtgpu_object.c | 113 fence = virtio_gpu_fence_alloc(vgdev, vgdev->fence_drv.context, 0); in virtio_gpu_detach_object_fenced()
|
| H A D | virtgpu_submit.c | 478 u64 fence_ctx = vgdev->fence_drv.context; in virtio_gpu_execbuffer_ioctl()
|
| H A D | virtgpu_plane.c | 372 vgdev->fence_drv.context, in virtio_gpu_plane_prepare_fb()
|