summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/xe/xe_preempt_fence.h
blob: 4f3966103203c7bef0778e50122a11582f089e1b (plain) (blame)
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/* SPDX-License-Identifier: MIT */
/*
 * Copyright © 2022 Intel Corporation
 */

#ifndef _XE_PREEMPT_FENCE_H_
#define _XE_PREEMPT_FENCE_H_

#include "xe_preempt_fence_types.h"

struct list_head;

struct dma_fence *
xe_preempt_fence_create(struct xe_engine *e,
			u64 context, u32 seqno);

struct xe_preempt_fence *xe_preempt_fence_alloc(void);

void xe_preempt_fence_free(struct xe_preempt_fence *pfence);

struct dma_fence *
xe_preempt_fence_arm(struct xe_preempt_fence *pfence, struct xe_engine *e,
		     u64 context, u32 seqno);

static inline struct xe_preempt_fence *
to_preempt_fence(struct dma_fence *fence)
{
	return container_of(fence, struct xe_preempt_fence, base);
}

/**
 * xe_preempt_fence_link() - Return a link used to keep unarmed preempt
 * fences on a list.
 * @pfence: Pointer to the preempt fence.
 *
 * The link is embedded in the struct xe_preempt_fence. Use
 * link_to_preempt_fence() to convert back to the preempt fence.
 *
 * Return: A pointer to an embedded struct list_head.
 */
static inline struct list_head *
xe_preempt_fence_link(struct xe_preempt_fence *pfence)
{
	return &pfence->link;
}

/**
 * to_preempt_fence_from_link() - Convert back to a preempt fence pointer
 * from a link obtained with xe_preempt_fence_link().
 * @link: The struct list_head obtained from xe_preempt_fence_link().
 *
 * Return: A pointer to the embedding struct xe_preempt_fence.
 */
static inline struct xe_preempt_fence *
to_preempt_fence_from_link(struct list_head *link)
{
	return container_of(link, struct xe_preempt_fence, link);
}

bool xe_fence_is_xe_preempt(const struct dma_fence *fence);
#endif