diff options
Diffstat (limited to 'drivers/gpu/drm/nouveau/nouveau_mem.c')
-rw-r--r-- | drivers/gpu/drm/nouveau/nouveau_mem.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_mem.c b/drivers/gpu/drm/nouveau/nouveau_mem.c index fb9bdd6edf1f..186f34b01f2e 100644 --- a/drivers/gpu/drm/nouveau/nouveau_mem.c +++ b/drivers/gpu/drm/nouveau/nouveau_mem.c | |||
@@ -383,10 +383,10 @@ void nouveau_mem_close(struct drm_device *dev) | |||
383 | { | 383 | { |
384 | struct drm_nouveau_private *dev_priv = dev->dev_private; | 384 | struct drm_nouveau_private *dev_priv = dev->dev_private; |
385 | 385 | ||
386 | if (dev_priv->ttm.bdev.man[TTM_PL_PRIV0].has_type) | 386 | nouveau_bo_unpin(dev_priv->vga_ram); |
387 | ttm_bo_clean_mm(&dev_priv->ttm.bdev, TTM_PL_PRIV0); | 387 | nouveau_bo_ref(NULL, &dev_priv->vga_ram); |
388 | ttm_bo_clean_mm(&dev_priv->ttm.bdev, TTM_PL_VRAM); | ||
389 | 388 | ||
389 | ttm_bo_clean_mm(&dev_priv->ttm.bdev, TTM_PL_VRAM); | ||
390 | ttm_bo_device_release(&dev_priv->ttm.bdev); | 390 | ttm_bo_device_release(&dev_priv->ttm.bdev); |
391 | 391 | ||
392 | nouveau_ttm_global_release(dev_priv); | 392 | nouveau_ttm_global_release(dev_priv); |
@@ -622,6 +622,15 @@ nouveau_mem_init(struct drm_device *dev) | |||
622 | return ret; | 622 | return ret; |
623 | } | 623 | } |
624 | 624 | ||
625 | ret = nouveau_bo_new(dev, NULL, 256*1024, 0, TTM_PL_FLAG_VRAM, | ||
626 | 0, 0, true, true, &dev_priv->vga_ram); | ||
627 | if (ret == 0) | ||
628 | ret = nouveau_bo_pin(dev_priv->vga_ram, TTM_PL_FLAG_VRAM); | ||
629 | if (ret) { | ||
630 | NV_WARN(dev, "failed to reserve VGA memory\n"); | ||
631 | nouveau_bo_ref(NULL, &dev_priv->vga_ram); | ||
632 | } | ||
633 | |||
625 | /* GART */ | 634 | /* GART */ |
626 | #if !defined(__powerpc__) && !defined(__ia64__) | 635 | #if !defined(__powerpc__) && !defined(__ia64__) |
627 | if (drm_device_is_agp(dev) && dev->agp) { | 636 | if (drm_device_is_agp(dev) && dev->agp) { |
@@ -653,6 +662,7 @@ nouveau_mem_init(struct drm_device *dev) | |||
653 | dev_priv->fb_mtrr = drm_mtrr_add(drm_get_resource_start(dev, 1), | 662 | dev_priv->fb_mtrr = drm_mtrr_add(drm_get_resource_start(dev, 1), |
654 | drm_get_resource_len(dev, 1), | 663 | drm_get_resource_len(dev, 1), |
655 | DRM_MTRR_WC); | 664 | DRM_MTRR_WC); |
665 | |||
656 | return 0; | 666 | return 0; |
657 | } | 667 | } |
658 | 668 | ||