hc
2023-03-21 4b55d97acc464242bcd6a8ae77b8ff37c22dec58
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
// SPDX-License-Identifier: GPL-2.0+
/* Copyright (C) 2017-2018 Broadcom */
 
#include "v3d_drv.h"
 
struct dma_fence *v3d_fence_create(struct v3d_dev *v3d, enum v3d_queue queue)
{
   struct v3d_fence *fence;
 
   fence = kzalloc(sizeof(*fence), GFP_KERNEL);
   if (!fence)
       return ERR_PTR(-ENOMEM);
 
   fence->dev = &v3d->drm;
   fence->queue = queue;
   fence->seqno = ++v3d->queue[queue].emit_seqno;
   dma_fence_init(&fence->base, &v3d_fence_ops, &v3d->job_lock,
              v3d->queue[queue].fence_context, fence->seqno);
 
   return &fence->base;
}
 
static const char *v3d_fence_get_driver_name(struct dma_fence *fence)
{
   return "v3d";
}
 
static const char *v3d_fence_get_timeline_name(struct dma_fence *fence)
{
   struct v3d_fence *f = to_v3d_fence(fence);
 
   if (f->queue == V3D_BIN)
       return "v3d-bin";
   else
       return "v3d-render";
}
 
const struct dma_fence_ops v3d_fence_ops = {
   .get_driver_name = v3d_fence_get_driver_name,
   .get_timeline_name = v3d_fence_get_timeline_name,
};