summaryrefslogtreecommitdiff
path: root/src/gallium/drivers/nv50/nv50_fence.h
blob: dd0b74e89fa24ccb3d95c046bdc5e841a548a48f (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 __NV50_FENCE_H__
#define __NV50_FENCE_H__

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

#define NV50_FENCE_STATE_AVAILABLE 0
#define NV50_FENCE_STATE_EMITTED   1
#define NV50_FENCE_STATE_FLUSHED   2
#define NV50_FENCE_STATE_SIGNALLED 3

struct nv50_mm_allocation;

struct nv50_fence {
   struct nv50_fence *next;
   struct nv50_screen *screen;
   int state;
   int ref;
   uint32_t sequence;
   struct nv50_mm_allocation *buffers;
};

void nv50_fence_emit(struct nv50_fence *);
void nv50_fence_del(struct nv50_fence *);

boolean nv50_fence_wait(struct nv50_fence *);
boolean nv50_fence_signalled(struct nv50_fence *);

static INLINE void
nv50_fence_reference(struct nv50_fence **ref, struct nv50_fence *fence)
{
   if (*ref) {
      if (--(*ref)->ref == 0)
         nv50_fence_del(*ref);
   }
   if (fence)
      ++fence->ref;

   *ref = fence;
}

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

#endif // __NV50_FENCE_H__