License cleanup: add SPDX GPL-2.0 license identifier to files with no license
[linux-block.git] / drivers / gpu / drm / nouveau / nvkm / subdev / fb / priv.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
dceef5d8
BS
2#ifndef __NVKM_FB_PRIV_H__
3#define __NVKM_FB_PRIV_H__
03c8952f 4#define nvkm_fb(p) container_of((p), struct nvkm_fb, subdev)
dceef5d8 5#include <subdev/fb.h>
639c308e 6struct nvkm_bios;
dceef5d8 7
03c8952f
BS
8struct nvkm_fb_func {
9 void *(*dtor)(struct nvkm_fb *);
917d95a8 10 int (*oneinit)(struct nvkm_fb *);
03c8952f 11 void (*init)(struct nvkm_fb *);
c73baa83 12 void (*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
BS
27
28 bool (*memtype_valid)(struct nvkm_fb *, u32 memtype);
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
639c308e 37bool nv04_fb_memtype_valid(struct nvkm_fb *, u32 memtype);
dceef5d8 38
03c8952f
BS
39void nv10_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
40 u32 pitch, u32 flags, struct nvkm_fb_tile *);
41void nv10_fb_tile_fini(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
42void nv10_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
43
44void nv20_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
45 u32 pitch, u32 flags, struct nvkm_fb_tile *);
46void nv20_fb_tile_fini(struct nvkm_fb *, int i, struct nvkm_fb_tile *);
47void nv20_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
48
49void nv30_fb_init(struct nvkm_fb *);
50void nv30_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
51 u32 pitch, u32 flags, struct nvkm_fb_tile *);
52
53void nv40_fb_tile_comp(struct nvkm_fb *, int i, u32 size, u32 flags,
54 struct nvkm_fb_tile *);
55
56void nv41_fb_init(struct nvkm_fb *);
57void nv41_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
58
59void nv44_fb_init(struct nvkm_fb *);
60void nv44_fb_tile_prog(struct nvkm_fb *, int, struct nvkm_fb_tile *);
61
62void nv46_fb_tile_init(struct nvkm_fb *, int i, u32 addr, u32 size,
63 u32 pitch, u32 flags, struct nvkm_fb_tile *);
64
99c59172 65int gf100_fb_oneinit(struct nvkm_fb *);
c73baa83 66void gf100_fb_init_page(struct nvkm_fb *);
03c8952f 67bool gf100_fb_memtype_valid(struct nvkm_fb *, u32);
7ff51f82
BS
68
69void gm200_fb_init_page(struct nvkm_fb *);
dceef5d8 70#endif