blob: 9406c6fea525a2e5272b9dcbc8baf0a13bbb45da (
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
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_exec_queue *q,
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_exec_queue *q,
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
|