]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blame - drivers/gpu/drm/nouveau/nvkm/subdev/fb/priv.h
drm/nouveau/mmu: remove old vmm frontend
[mirror_ubuntu-bionic-kernel.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 *);
af793b8c 9 u32 (*tags)(struct nvkm_fb *);
917d95a8 10 int (*oneinit)(struct nvkm_fb *);
03c8952f 11 void (*init)(struct nvkm_fb *);
2854ab8d 12 int (*init_page)(struct nvkm_fb *);
7ff51f82 13 void (*init_unkn)(struct nvkm_fb *);
03c8952f
BS
14 void (*intr)(struct nvkm_fb *);
15
16 struct {
17 int regions;
18 void (*init)(struct nvkm_fb *, int i, u32 addr, u32 size,
19 u32 pitch, u32 flags, struct nvkm_fb_tile *);
20 void (*comp)(struct nvkm_fb *, int i, u32 size, u32 flags,
21 struct nvkm_fb_tile *);
22 void (*fini)(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
23 void (*prog)(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
24 } tile;
25
d36a99d2 26 int (*ram_new)(struct nvkm_fb *, struct nvkm_ram **);
03c8952f 27
2854ab8d 28 u8 default_bigpage;
8613e731
BS
29};
30
03c8952f
BS
31void nvkm_fb_ctor(const struct nvkm_fb_func *, struct nvkm_device *device,
32 int index, struct nvkm_fb *);
33int nvkm_fb_new_(const struct nvkm_fb_func *, struct nvkm_device *device,
34 int index, struct nvkm_fb **);
35int nvkm_fb_bios_memtype(struct nvkm_bios *);
36
03c8952f
BS
37void nv10_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
38 u32 pitch, u32 flags, struct nvkm_fb_tile *);
39void nv10_fb_tile_fini(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
40void nv10_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
41
af793b8c 42u32 nv20_fb_tags(struct nvkm_fb *);
03c8952f
BS
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 *);
2854ab8d 65int gf100_fb_init_page(struct nvkm_fb *);
7ff51f82 66
2854ab8d 67int gm200_fb_init_page(struct nvkm_fb *);
dceef5d8 68#endif