summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/msm/msm_syncobj.h
blob: bcaa15d01da0986fcc8fe39fef5a22cb0d94d7f9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/* SPDX-License-Identifier: GPL-2.0-only */
/* Copyright (C) 2020 Google, Inc */

#ifndef __MSM_GEM_SYNCOBJ_H__
#define __MSM_GEM_SYNCOBJ_H__

#include "drm/drm_device.h"
#include "drm/drm_syncobj.h"
#include "drm/gpu_scheduler.h"

struct msm_syncobj_post_dep {
	struct drm_syncobj *syncobj;
	uint64_t point;
	struct dma_fence_chain *chain;
};

struct drm_syncobj **
msm_syncobj_parse_deps(struct drm_device *dev,
		       struct drm_sched_job *job,
		       struct drm_file *file,
		       uint64_t in_syncobjs_addr,
		       uint32_t nr_in_syncobjs,
		       size_t syncobj_stride);

void msm_syncobj_reset(struct drm_syncobj **syncobjs, uint32_t nr_syncobjs);

struct msm_syncobj_post_dep *
msm_syncobj_parse_post_deps(struct drm_device *dev,
			    struct drm_file *file,
			    uint64_t syncobjs_addr,
			    uint32_t nr_syncobjs,
			    size_t syncobj_stride);

void msm_syncobj_process_post_deps(struct msm_syncobj_post_dep *post_deps,
				   uint32_t count, struct dma_fence *fence);

#endif /* __MSM_GEM_SYNCOBJ_H__ */