]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blame - drivers/gpu/drm/nouveau/nvkm/subdev/fb/priv.h
drm/nouveau/imem/gp100: initial implementation
[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 *);
917d95a8 9 int (*oneinit)(struct nvkm_fb *);
03c8952f 10 void (*init)(struct nvkm_fb *);
c73baa83 11 void (*init_page)(struct nvkm_fb *);
03c8952f
BS
12 void (*intr)(struct nvkm_fb *);
13
14 struct {
15 int regions;
16 void (*init)(struct nvkm_fb *, int i, u32 addr, u32 size,
17 u32 pitch, u32 flags, struct nvkm_fb_tile *);
18 void (*comp)(struct nvkm_fb *, int i, u32 size, u32 flags,
19 struct nvkm_fb_tile *);
20 void (*fini)(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
21 void (*prog)(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
22 } tile;
23
d36a99d2 24 int (*ram_new)(struct nvkm_fb *, struct nvkm_ram **);
03c8952f
BS
25
26 bool (*memtype_valid)(struct nvkm_fb *, u32 memtype);
8613e731
BS
27};
28
03c8952f
BS
29void nvkm_fb_ctor(const struct nvkm_fb_func *, struct nvkm_device *device,
30 int index, struct nvkm_fb *);
31int nvkm_fb_new_(const struct nvkm_fb_func *, struct nvkm_device *device,
32 int index, struct nvkm_fb **);
33int nvkm_fb_bios_memtype(struct nvkm_bios *);
34
639c308e 35bool nv04_fb_memtype_valid(struct nvkm_fb *, u32 memtype);
dceef5d8 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
42void nv20_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
43 u32 pitch, u32 flags, struct nvkm_fb_tile *);
44void nv20_fb_tile_fini(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
45void nv20_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
46
47void nv30_fb_init(struct nvkm_fb *);
48void nv30_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
49 u32 pitch, u32 flags, struct nvkm_fb_tile *);
50
51void nv40_fb_tile_comp(struct nvkm_fb *, int i, u32 size, u32 flags,
52 struct nvkm_fb_tile *);
53
54void nv41_fb_init(struct nvkm_fb *);
55void nv41_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
56
57void nv44_fb_init(struct nvkm_fb *);
58void nv44_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
59
60void nv46_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
61 u32 pitch, u32 flags, struct nvkm_fb_tile *);
62
99c59172 63int gf100_fb_oneinit(struct nvkm_fb *);
c73baa83 64void gf100_fb_init_page(struct nvkm_fb *);
03c8952f 65bool gf100_fb_memtype_valid(struct nvkm_fb *, u32);
dceef5d8 66#endif