Merge tag 'drm-misc-fixes-2017-11-13' of git://anongit.freedesktop.org/drm/drm-misc...
[sfrench/cifs-2.6.git] / drivers / gpu / drm / nouveau / include / nvkm / core / object.h
1 #ifndef __NVKM_OBJECT_H__
2 #define __NVKM_OBJECT_H__
3 #include <core/oclass.h>
4 struct nvkm_event;
5 struct nvkm_gpuobj;
6
7 struct nvkm_object {
8         const struct nvkm_object_func *func;
9         struct nvkm_client *client;
10         struct nvkm_engine *engine;
11         s32 oclass;
12         u32 handle;
13
14         struct list_head head;
15         struct list_head tree;
16         u8  route;
17         u64 token;
18         u64 object;
19         struct rb_node node;
20 };
21
22 enum nvkm_object_map {
23         NVKM_OBJECT_MAP_IO,
24         NVKM_OBJECT_MAP_VA
25 };
26
27 struct nvkm_object_func {
28         void *(*dtor)(struct nvkm_object *);
29         int (*init)(struct nvkm_object *);
30         int (*fini)(struct nvkm_object *, bool suspend);
31         int (*mthd)(struct nvkm_object *, u32 mthd, void *data, u32 size);
32         int (*ntfy)(struct nvkm_object *, u32 mthd, struct nvkm_event **);
33         int (*map)(struct nvkm_object *, void *argv, u32 argc,
34                    enum nvkm_object_map *, u64 *addr, u64 *size);
35         int (*unmap)(struct nvkm_object *);
36         int (*rd08)(struct nvkm_object *, u64 addr, u8 *data);
37         int (*rd16)(struct nvkm_object *, u64 addr, u16 *data);
38         int (*rd32)(struct nvkm_object *, u64 addr, u32 *data);
39         int (*wr08)(struct nvkm_object *, u64 addr, u8 data);
40         int (*wr16)(struct nvkm_object *, u64 addr, u16 data);
41         int (*wr32)(struct nvkm_object *, u64 addr, u32 data);
42         int (*bind)(struct nvkm_object *, struct nvkm_gpuobj *, int align,
43                     struct nvkm_gpuobj **);
44         int (*sclass)(struct nvkm_object *, int index, struct nvkm_oclass *);
45 };
46
47 void nvkm_object_ctor(const struct nvkm_object_func *,
48                       const struct nvkm_oclass *, struct nvkm_object *);
49 int nvkm_object_new_(const struct nvkm_object_func *,
50                      const struct nvkm_oclass *, void *data, u32 size,
51                      struct nvkm_object **);
52 int nvkm_object_new(const struct nvkm_oclass *, void *data, u32 size,
53                     struct nvkm_object **);
54 void nvkm_object_del(struct nvkm_object **);
55 void *nvkm_object_dtor(struct nvkm_object *);
56 int nvkm_object_init(struct nvkm_object *);
57 int nvkm_object_fini(struct nvkm_object *, bool suspend);
58 int nvkm_object_mthd(struct nvkm_object *, u32 mthd, void *data, u32 size);
59 int nvkm_object_ntfy(struct nvkm_object *, u32 mthd, struct nvkm_event **);
60 int nvkm_object_map(struct nvkm_object *, void *argv, u32 argc,
61                     enum nvkm_object_map *, u64 *addr, u64 *size);
62 int nvkm_object_unmap(struct nvkm_object *);
63 int nvkm_object_rd08(struct nvkm_object *, u64 addr, u8  *data);
64 int nvkm_object_rd16(struct nvkm_object *, u64 addr, u16 *data);
65 int nvkm_object_rd32(struct nvkm_object *, u64 addr, u32 *data);
66 int nvkm_object_wr08(struct nvkm_object *, u64 addr, u8   data);
67 int nvkm_object_wr16(struct nvkm_object *, u64 addr, u16  data);
68 int nvkm_object_wr32(struct nvkm_object *, u64 addr, u32  data);
69 int nvkm_object_bind(struct nvkm_object *, struct nvkm_gpuobj *, int align,
70                      struct nvkm_gpuobj **);
71
72 bool nvkm_object_insert(struct nvkm_object *);
73 void nvkm_object_remove(struct nvkm_object *);
74 struct nvkm_object *nvkm_object_search(struct nvkm_client *, u64 object,
75                                        const struct nvkm_object_func *);
76 #endif