summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/xe/xe_preempt_fence_types.h
blob: b54b5c29b5331e7a0c445abbc10551afa76525fd (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
/* SPDX-License-Identifier: MIT */
/*
 * Copyright © 2022 Intel Corporation
 */

#ifndef _XE_PREEMPT_FENCE_TYPES_H_
#define _XE_PREEMPT_FENCE_TYPES_H_

#include <linux/dma-fence.h>
#include <linux/workqueue.h>

struct xe_exec_queue;

/**
 * struct xe_preempt_fence - XE preempt fence
 *
 * hardware and triggers a callback once the xe_engine is complete.
 */
struct xe_preempt_fence {
	/** @base: dma fence base */
	struct dma_fence base;
	/** @link: link into list of pending preempt fences */
	struct list_head link;
	/** @q: exec queue for this preempt fence */
	struct xe_exec_queue *q;
	/** @preempt_work: work struct which issues preemption */
	struct work_struct preempt_work;
	/** @error: preempt fence is in error state */
	int error;
};

#endif