summaryrefslogtreecommitdiffstats
path: root/src/gallium/drivers/nvc0/nvc0_fence.h
blob: 3d8c3f8ba604083fd812b0f51cda3cf570859c9f (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

#ifndef __NVC0_FENCE_H__
#define __NVC0_FENCE_H__

#include "util/u_inlines.h"
#include "util/u_double_list.h"

#define NVC0_FENCE_STATE_AVAILABLE 0
#define NVC0_FENCE_STATE_EMITTED   1
#define NVC0_FENCE_STATE_FLUSHED   2
#define NVC0_FENCE_STATE_SIGNALLED 3

struct nvc0_mm_allocation;

struct nvc0_fence {
   struct nvc0_fence *next;
   struct nvc0_screen *screen;
   int state;
   int ref;
   uint32_t sequence;
   struct nvc0_mm_allocation *buffers;
};

void nvc0_fence_emit(struct nvc0_fence *);
void nvc0_fence_del(struct nvc0_fence *);

boolean nvc0_fence_wait(struct nvc0_fence *);
boolean nvc0_fence_signalled(struct nvc0_fence *);

static INLINE void
nvc0_fence_reference(struct nvc0_fence **ref, struct nvc0_fence *fence)
{
   if (*ref) {
      if (--(*ref)->ref == 0)
         nvc0_fence_del(*ref);
   }
   if (fence)
      ++fence->ref;

   *ref = fence;
}

static INLINE struct nvc0_fence *
nvc0_fence(struct pipe_fence_handle *fence)
{
   return (struct nvc0_fence *)fence;
}

#endif // __NVC0_FENCE_H__