]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - drivers/gpu/drm/nouveau/nvkm/subdev/fb/priv.h
Merge tag 'mac80211-next-for-davem-2015-05-19' of git://git.kernel.org/pub/scm/linux...
[mirror_ubuntu-artful-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__
dceef5d8 3#include <subdev/fb.h>
639c308e 4struct nvkm_bios;
dceef5d8 5
639c308e
BS
6#define nvkm_ram_create(p,e,o,d) \
7 nvkm_object_create_((p), (e), (o), 0, sizeof(**d), (void **)d)
8#define nvkm_ram_destroy(p) \
9 nvkm_object_destroy(&(p)->base)
10#define nvkm_ram_init(p) \
11 nvkm_object_init(&(p)->base)
12#define nvkm_ram_fini(p,s) \
13 nvkm_object_fini(&(p)->base, (s))
dceef5d8 14
639c308e
BS
15#define nvkm_ram_create_(p,e,o,s,d) \
16 nvkm_object_create_((p), (e), (o), 0, (s), (void **)d)
17#define _nvkm_ram_dtor nvkm_object_destroy
18#define _nvkm_ram_init nvkm_object_init
19#define _nvkm_ram_fini nvkm_object_fini
dceef5d8 20
639c308e
BS
21extern struct nvkm_oclass nv04_ram_oclass;
22extern struct nvkm_oclass nv10_ram_oclass;
23extern struct nvkm_oclass nv1a_ram_oclass;
24extern struct nvkm_oclass nv20_ram_oclass;
25extern struct nvkm_oclass nv40_ram_oclass;
26extern struct nvkm_oclass nv41_ram_oclass;
27extern struct nvkm_oclass nv44_ram_oclass;
28extern struct nvkm_oclass nv49_ram_oclass;
29extern struct nvkm_oclass nv4e_ram_oclass;
30extern struct nvkm_oclass nv50_ram_oclass;
31extern struct nvkm_oclass gt215_ram_oclass;
32extern struct nvkm_oclass mcp77_ram_oclass;
33extern struct nvkm_oclass gf100_ram_oclass;
34extern struct nvkm_oclass gk104_ram_oclass;
639c308e 35extern struct nvkm_oclass gm107_ram_oclass;
aae95ca7 36
639c308e
BS
37int nvkm_sddr2_calc(struct nvkm_ram *ram);
38int nvkm_sddr3_calc(struct nvkm_ram *ram);
39int nvkm_gddr3_calc(struct nvkm_ram *ram);
40int nvkm_gddr5_calc(struct nvkm_ram *ram, bool nuts);
dceef5d8 41
639c308e
BS
42#define nvkm_fb_create(p,e,c,d) \
43 nvkm_fb_create_((p), (e), (c), sizeof(**d), (void **)d)
44#define nvkm_fb_destroy(p) ({ \
45 struct nvkm_fb *pfb = (p); \
46 _nvkm_fb_dtor(nv_object(pfb)); \
dceef5d8 47})
639c308e
BS
48#define nvkm_fb_init(p) ({ \
49 struct nvkm_fb *pfb = (p); \
50 _nvkm_fb_init(nv_object(pfb)); \
dceef5d8 51})
639c308e
BS
52#define nvkm_fb_fini(p,s) ({ \
53 struct nvkm_fb *pfb = (p); \
54 _nvkm_fb_fini(nv_object(pfb), (s)); \
dceef5d8
BS
55})
56
639c308e
BS
57int nvkm_fb_create_(struct nvkm_object *, struct nvkm_object *,
58 struct nvkm_oclass *, int, void **);
59void _nvkm_fb_dtor(struct nvkm_object *);
60int _nvkm_fb_init(struct nvkm_object *);
61int _nvkm_fb_fini(struct nvkm_object *, bool);
dceef5d8 62
639c308e
BS
63struct nvkm_fb_impl {
64 struct nvkm_oclass base;
65 struct nvkm_oclass *ram;
66 bool (*memtype)(struct nvkm_fb *, u32);
8613e731
BS
67};
68
639c308e
BS
69bool nv04_fb_memtype_valid(struct nvkm_fb *, u32 memtype);
70bool nv50_fb_memtype_valid(struct nvkm_fb *, u32 memtype);
dceef5d8 71
639c308e 72int nvkm_fb_bios_memtype(struct nvkm_bios *);
dceef5d8 73#endif