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
|