blob: db16c47fd9229a59aee61f3c36065537b1494213 [file] [log] [blame]
Ben Skeggs6ee73862009-12-11 19:24:15 +10001#include "drmP.h"
2#include "drm.h"
3#include "nouveau_drv.h"
4#include "nouveau_drm.h"
5
6int
Ben Skeggs7ad2d312011-12-11 00:30:05 +10007nv04_fb_vram_init(struct drm_device *dev)
8{
9 struct drm_nouveau_private *dev_priv = dev->dev_private;
10 u32 boot0 = nv_rd32(dev, NV04_PFB_BOOT_0);
11
12 if (boot0 & 0x00000100) {
13 dev_priv->vram_size = ((boot0 >> 12) & 0xf) * 2 + 2;
14 dev_priv->vram_size *= 1024 * 1024;
15 } else {
16 switch (boot0 & NV04_PFB_BOOT_0_RAM_AMOUNT) {
17 case NV04_PFB_BOOT_0_RAM_AMOUNT_32MB:
18 dev_priv->vram_size = 32 * 1024 * 1024;
19 break;
20 case NV04_PFB_BOOT_0_RAM_AMOUNT_16MB:
21 dev_priv->vram_size = 16 * 1024 * 1024;
22 break;
23 case NV04_PFB_BOOT_0_RAM_AMOUNT_8MB:
24 dev_priv->vram_size = 8 * 1024 * 1024;
25 break;
26 case NV04_PFB_BOOT_0_RAM_AMOUNT_4MB:
27 dev_priv->vram_size = 4 * 1024 * 1024;
28 break;
29 }
30 }
31
32 return 0;
33}
34
35int
Ben Skeggs6ee73862009-12-11 19:24:15 +100036nv04_fb_init(struct drm_device *dev)
37{
38 /* This is what the DDX did for NV_ARCH_04, but a mmio-trace shows
39 * nvidia reading PFB_CFG_0, then writing back its original value.
40 * (which was 0x701114 in this case)
41 */
42
43 nv_wr32(dev, NV04_PFB_CFG0, 0x1114);
44 return 0;
45}
46
47void
48nv04_fb_takedown(struct drm_device *dev)
49{
50}