mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 e0d018119a
			
		
	
	
		e0d018119a
		
	
	
	
	
		
			
			The dma-fence core as of commit 418cc6ca06 ("dma-fence: Make ->wait
callback optional") provides appropriate defaults for these methods.
Signed-off-by: Eric Anholt <eric@anholt.net>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20180703170515.6298-2-eric@anholt.net
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Acked-by: Daniel Vetter <daniel@ffwll.ch>
		
	
			
		
			
				
	
	
		
			42 lines
		
	
	
		
			967 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			967 B
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0+
 | |
| /* Copyright (C) 2017-2018 Broadcom */
 | |
| 
 | |
| #include "v3d_drv.h"
 | |
| 
 | |
| struct dma_fence *v3d_fence_create(struct v3d_dev *v3d, enum v3d_queue queue)
 | |
| {
 | |
| 	struct v3d_fence *fence;
 | |
| 
 | |
| 	fence = kzalloc(sizeof(*fence), GFP_KERNEL);
 | |
| 	if (!fence)
 | |
| 		return ERR_PTR(-ENOMEM);
 | |
| 
 | |
| 	fence->dev = &v3d->drm;
 | |
| 	fence->queue = queue;
 | |
| 	fence->seqno = ++v3d->queue[queue].emit_seqno;
 | |
| 	dma_fence_init(&fence->base, &v3d_fence_ops, &v3d->job_lock,
 | |
| 		       v3d->queue[queue].fence_context, fence->seqno);
 | |
| 
 | |
| 	return &fence->base;
 | |
| }
 | |
| 
 | |
| static const char *v3d_fence_get_driver_name(struct dma_fence *fence)
 | |
| {
 | |
| 	return "v3d";
 | |
| }
 | |
| 
 | |
| static const char *v3d_fence_get_timeline_name(struct dma_fence *fence)
 | |
| {
 | |
| 	struct v3d_fence *f = to_v3d_fence(fence);
 | |
| 
 | |
| 	if (f->queue == V3D_BIN)
 | |
| 		return "v3d-bin";
 | |
| 	else
 | |
| 		return "v3d-render";
 | |
| }
 | |
| 
 | |
| const struct dma_fence_ops v3d_fence_ops = {
 | |
| 	.get_driver_name = v3d_fence_get_driver_name,
 | |
| 	.get_timeline_name = v3d_fence_get_timeline_name,
 | |
| };
 |