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

#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_SIGNALLED 2

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__