nv40_mc.c 718 B

1234567891011121314151617181920212223242526272829303132333435363738
  1. #include "drmP.h"
  2. #include "drm.h"
  3. #include "nouveau_drv.h"
  4. #include "nouveau_drm.h"
  5. int
  6. nv40_mc_init(struct drm_device *dev)
  7. {
  8. struct drm_nouveau_private *dev_priv = dev->dev_private;
  9. uint32_t tmp;
  10. /* Power up everything, resetting each individual unit will
  11. * be done later if needed.
  12. */
  13. nv_wr32(dev, NV03_PMC_ENABLE, 0xFFFFFFFF);
  14. switch (dev_priv->chipset) {
  15. case 0x44:
  16. case 0x46: /* G72 */
  17. case 0x4e:
  18. case 0x4c: /* C51_G7X */
  19. tmp = nv_rd32(dev, NV40_PFB_020C);
  20. nv_wr32(dev, NV40_PMC_1700, tmp);
  21. nv_wr32(dev, NV40_PMC_1704, 0);
  22. nv_wr32(dev, NV40_PMC_1708, 0);
  23. nv_wr32(dev, NV40_PMC_170C, tmp);
  24. break;
  25. default:
  26. break;
  27. }
  28. return 0;
  29. }
  30. void
  31. nv40_mc_takedown(struct drm_device *dev)
  32. {
  33. }