drm/nouveau/fb/gp100: initial support
[deliverable/linux.git] / drivers / gpu / drm / nouveau / nvkm / subdev / fb / priv.h
CommitLineData
dceef5d8
BS
1#ifndef __NVKM_FB_PRIV_H__
2#define __NVKM_FB_PRIV_H__
03c8952f 3#define nvkm_fb(p) container_of((p), struct nvkm_fb, subdev)
dceef5d8 4#include <subdev/fb.h>
639c308e 5struct nvkm_bios;
dceef5d8 6
03c8952f
BS
7struct nvkm_fb_func {
8 void *(*dtor)(struct nvkm_fb *);
917d95a8 9 int (*oneinit)(struct nvkm_fb *);
03c8952f 10 void (*init)(struct nvkm_fb *);
c73baa83 11 void (*init_page)(struct nvkm_fb *);
7ff51f82 12 void (*init_unkn)(struct nvkm_fb *);
03c8952f
BS
13 void (*intr)(struct nvkm_fb *);
14
15 struct {
16 int regions;
17 void (*init)(struct nvkm_fb *, int i, u32 addr, u32 size,
18 u32 pitch, u32 flags, struct nvkm_fb_tile *);
19 void (*comp)(struct nvkm_fb *, int i, u32 size, u32 flags,
20 struct nvkm_fb_tile *);
21 void (*fini)(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
22 void (*prog)(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
23 } tile;
24
d36a99d2 25 int (*ram_new)(struct nvkm_fb *, struct nvkm_ram **);
03c8952f
BS
26
27 bool (*memtype_valid)(struct nvkm_fb *, u32 memtype);
8613e731
BS
28};
29
03c8952f
BS
30void nvkm_fb_ctor(const struct nvkm_fb_func *, struct nvkm_device *device,
31 int index, struct nvkm_fb *);
32int nvkm_fb_new_(const struct nvkm_fb_func *, struct nvkm_device *device,
33 int index, struct nvkm_fb **);
34int nvkm_fb_bios_memtype(struct nvkm_bios *);
35
639c308e 36bool nv04_fb_memtype_valid(struct nvkm_fb *, u32 memtype);
dceef5d8 37
03c8952f
BS
38void nv10_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
39 u32 pitch, u32 flags, struct nvkm_fb_tile *);
40void nv10_fb_tile_fini(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
41void nv10_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
42
43void nv20_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
44 u32 pitch, u32 flags, struct nvkm_fb_tile *);
45void nv20_fb_tile_fini(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
46void nv20_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
47
48void nv30_fb_init(struct nvkm_fb *);
49void nv30_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
50 u32 pitch, u32 flags, struct nvkm_fb_tile *);
51
52void nv40_fb_tile_comp(struct nvkm_fb *, int i, u32 size, u32 flags,
53 struct nvkm_fb_tile *);
54
55void nv41_fb_init(struct nvkm_fb *);
56void nv41_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
57
58void nv44_fb_init(struct nvkm_fb *);
59void nv44_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
60
61void nv46_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
62 u32 pitch, u32 flags, struct nvkm_fb_tile *);
63
99c59172 64int gf100_fb_oneinit(struct nvkm_fb *);
c73baa83 65void gf100_fb_init_page(struct nvkm_fb *);
03c8952f 66bool gf100_fb_memtype_valid(struct nvkm_fb *, u32);
7ff51f82
BS
67
68void gm200_fb_init_page(struct nvkm_fb *);
dceef5d8 69#endif
This page took 0.188539 seconds and 5 git commands to generate.