nv04_fb.c 1.2 KB

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