|  | /* SPDX-License-Identifier: GPL-2.0-only */ | 
|  | /* | 
|  | * Copyright (C) 2013-2016 Red Hat | 
|  | * Author: Rob Clark <robdclark@gmail.com> | 
|  | */ | 
|  |  | 
|  | #ifndef __MSM_FENCE_H__ | 
|  | #define __MSM_FENCE_H__ | 
|  |  | 
|  | #include "msm_drv.h" | 
|  |  | 
|  | struct msm_fence_context { | 
|  | struct drm_device *dev; | 
|  | char name[32]; | 
|  | unsigned context; | 
|  | /* last_fence == completed_fence --> no pending work */ | 
|  | uint32_t last_fence;          /* last assigned fence */ | 
|  | uint32_t completed_fence;     /* last completed fence */ | 
|  | wait_queue_head_t event; | 
|  | spinlock_t spinlock; | 
|  | }; | 
|  |  | 
|  | struct msm_fence_context * msm_fence_context_alloc(struct drm_device *dev, | 
|  | const char *name); | 
|  | void msm_fence_context_free(struct msm_fence_context *fctx); | 
|  |  | 
|  | int msm_wait_fence(struct msm_fence_context *fctx, uint32_t fence, | 
|  | ktime_t *timeout, bool interruptible); | 
|  | void msm_update_fence(struct msm_fence_context *fctx, uint32_t fence); | 
|  |  | 
|  | struct dma_fence * msm_fence_alloc(struct msm_fence_context *fctx); | 
|  |  | 
|  | #endif |