aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/nouveau/core/engine/software/nv50.h
blob: 41542e725b4b3c63eaa0c906ceba8b9f1855929f (plain) (blame)
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
#ifndef __NVKM_SW_NV50_H__
#define __NVKM_SW_NV50_H__

#include <engine/software.h>

struct nv50_software_oclass {
	struct nouveau_oclass base;
	struct nouveau_oclass *cclass;
	struct nouveau_oclass *sclass;
};

struct nv50_software_priv {
	struct nouveau_software base;
};

int  nv50_software_ctor(struct nouveau_object *, struct nouveau_object *,
			struct nouveau_oclass *, void *, u32,
			struct nouveau_object **);

struct nv50_software_cclass {
	struct nouveau_oclass base;
	int (*vblank)(struct nvkm_notify *);
};

struct nv50_software_chan {
	struct nouveau_software_chan base;
	struct {
		struct nvkm_notify notify[4];
		u32 channel;
		u32 ctxdma;
		u64 offset;
		u32 value;
	} vblank;
};

int  nv50_software_context_ctor(struct nouveau_object *,
				struct nouveau_object *,
				struct nouveau_oclass *, void *, u32,
				struct nouveau_object **);
void nv50_software_context_dtor(struct nouveau_object *);

int nv50_software_mthd_vblsem_value(struct nouveau_object *, u32, void *, u32);
int nv50_software_mthd_vblsem_release(struct nouveau_object *, u32, void *, u32);
int nv50_software_mthd_flip(struct nouveau_object *, u32, void *, u32);

#endif