diff options
Diffstat (limited to 'drivers/gpu/drm/nouveau/nouveau_bo.c')
-rw-r--r-- | drivers/gpu/drm/nouveau/nouveau_bo.c | 62 |
1 files changed, 24 insertions, 38 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c index bf260af18b31..897c55509a6b 100644 --- a/drivers/gpu/drm/nouveau/nouveau_bo.c +++ b/drivers/gpu/drm/nouveau/nouveau_bo.c | |||
@@ -98,8 +98,7 @@ nouveau_bo_fixup_align(struct nouveau_bo *nvbo, int *align, int *size, | |||
98 | int | 98 | int |
99 | nouveau_bo_new(struct drm_device *dev, struct nouveau_channel *chan, | 99 | nouveau_bo_new(struct drm_device *dev, struct nouveau_channel *chan, |
100 | int size, int align, uint32_t flags, uint32_t tile_mode, | 100 | int size, int align, uint32_t flags, uint32_t tile_mode, |
101 | uint32_t tile_flags, bool no_vm, bool mappable, | 101 | uint32_t tile_flags, struct nouveau_bo **pnvbo) |
102 | struct nouveau_bo **pnvbo) | ||
103 | { | 102 | { |
104 | struct drm_nouveau_private *dev_priv = dev->dev_private; | 103 | struct drm_nouveau_private *dev_priv = dev->dev_private; |
105 | struct nouveau_bo *nvbo; | 104 | struct nouveau_bo *nvbo; |
@@ -110,8 +109,6 @@ nouveau_bo_new(struct drm_device *dev, struct nouveau_channel *chan, | |||
110 | return -ENOMEM; | 109 | return -ENOMEM; |
111 | INIT_LIST_HEAD(&nvbo->head); | 110 | INIT_LIST_HEAD(&nvbo->head); |
112 | INIT_LIST_HEAD(&nvbo->entry); | 111 | INIT_LIST_HEAD(&nvbo->entry); |
113 | nvbo->mappable = mappable; | ||
114 | nvbo->no_vm = no_vm; | ||
115 | nvbo->tile_mode = tile_mode; | 112 | nvbo->tile_mode = tile_mode; |
116 | nvbo->tile_flags = tile_flags; | 113 | nvbo->tile_flags = tile_flags; |
117 | nvbo->bo.bdev = &dev_priv->ttm.bdev; | 114 | nvbo->bo.bdev = &dev_priv->ttm.bdev; |
@@ -119,7 +116,7 @@ nouveau_bo_new(struct drm_device *dev, struct nouveau_channel *chan, | |||
119 | nouveau_bo_fixup_align(nvbo, &align, &size, &page_shift); | 116 | nouveau_bo_fixup_align(nvbo, &align, &size, &page_shift); |
120 | align >>= PAGE_SHIFT; | 117 | align >>= PAGE_SHIFT; |
121 | 118 | ||
122 | if (!nvbo->no_vm && dev_priv->chan_vm) { | 119 | if (dev_priv->chan_vm) { |
123 | ret = nouveau_vm_get(dev_priv->chan_vm, size, page_shift, | 120 | ret = nouveau_vm_get(dev_priv->chan_vm, size, page_shift, |
124 | NV_MEM_ACCESS_RW, &nvbo->vma); | 121 | NV_MEM_ACCESS_RW, &nvbo->vma); |
125 | if (ret) { | 122 | if (ret) { |
@@ -504,14 +501,6 @@ static inline uint32_t | |||
504 | nouveau_bo_mem_ctxdma(struct ttm_buffer_object *bo, | 501 | nouveau_bo_mem_ctxdma(struct ttm_buffer_object *bo, |
505 | struct nouveau_channel *chan, struct ttm_mem_reg *mem) | 502 | struct nouveau_channel *chan, struct ttm_mem_reg *mem) |
506 | { | 503 | { |
507 | struct nouveau_bo *nvbo = nouveau_bo(bo); | ||
508 | |||
509 | if (nvbo->no_vm) { | ||
510 | if (mem->mem_type == TTM_PL_TT) | ||
511 | return NvDmaGART; | ||
512 | return NvDmaVRAM; | ||
513 | } | ||
514 | |||
515 | if (mem->mem_type == TTM_PL_TT) | 504 | if (mem->mem_type == TTM_PL_TT) |
516 | return chan->gart_handle; | 505 | return chan->gart_handle; |
517 | return chan->vram_handle; | 506 | return chan->vram_handle; |
@@ -523,22 +512,21 @@ nvc0_bo_move_m2mf(struct nouveau_channel *chan, struct ttm_buffer_object *bo, | |||
523 | { | 512 | { |
524 | struct drm_nouveau_private *dev_priv = nouveau_bdev(bo->bdev); | 513 | struct drm_nouveau_private *dev_priv = nouveau_bdev(bo->bdev); |
525 | struct nouveau_bo *nvbo = nouveau_bo(bo); | 514 | struct nouveau_bo *nvbo = nouveau_bo(bo); |
526 | u64 src_offset = old_mem->start << PAGE_SHIFT; | ||
527 | u64 dst_offset = new_mem->start << PAGE_SHIFT; | ||
528 | u32 page_count = new_mem->num_pages; | 515 | u32 page_count = new_mem->num_pages; |
516 | u64 src_offset, dst_offset; | ||
529 | int ret; | 517 | int ret; |
530 | 518 | ||
531 | if (!nvbo->no_vm) { | 519 | src_offset = old_mem->start << PAGE_SHIFT; |
532 | if (old_mem->mem_type == TTM_PL_VRAM) | 520 | if (old_mem->mem_type == TTM_PL_VRAM) |
533 | src_offset = nvbo->vma.offset; | 521 | src_offset = nvbo->vma.offset; |
534 | else | 522 | else |
535 | src_offset += dev_priv->gart_info.aper_base; | 523 | src_offset += dev_priv->gart_info.aper_base; |
536 | 524 | ||
537 | if (new_mem->mem_type == TTM_PL_VRAM) | 525 | dst_offset = new_mem->start << PAGE_SHIFT; |
538 | dst_offset = nvbo->vma.offset; | 526 | if (new_mem->mem_type == TTM_PL_VRAM) |
539 | else | 527 | dst_offset = nvbo->vma.offset; |
540 | dst_offset += dev_priv->gart_info.aper_base; | 528 | else |
541 | } | 529 | dst_offset += dev_priv->gart_info.aper_base; |
542 | 530 | ||
543 | page_count = new_mem->num_pages; | 531 | page_count = new_mem->num_pages; |
544 | while (page_count) { | 532 | while (page_count) { |
@@ -580,18 +568,16 @@ nv50_bo_move_m2mf(struct nouveau_channel *chan, struct ttm_buffer_object *bo, | |||
580 | int ret; | 568 | int ret; |
581 | 569 | ||
582 | src_offset = old_mem->start << PAGE_SHIFT; | 570 | src_offset = old_mem->start << PAGE_SHIFT; |
583 | dst_offset = new_mem->start << PAGE_SHIFT; | 571 | if (old_mem->mem_type == TTM_PL_VRAM) |
584 | if (!nvbo->no_vm) { | 572 | src_offset = nvbo->vma.offset; |
585 | if (old_mem->mem_type == TTM_PL_VRAM) | 573 | else |
586 | src_offset = nvbo->vma.offset; | 574 | src_offset += dev_priv->gart_info.aper_base; |
587 | else | ||
588 | src_offset += dev_priv->gart_info.aper_base; | ||
589 | 575 | ||
590 | if (new_mem->mem_type == TTM_PL_VRAM) | 576 | dst_offset = new_mem->start << PAGE_SHIFT; |
591 | dst_offset = nvbo->vma.offset; | 577 | if (new_mem->mem_type == TTM_PL_VRAM) |
592 | else | 578 | dst_offset = nvbo->vma.offset; |
593 | dst_offset += dev_priv->gart_info.aper_base; | 579 | else |
594 | } | 580 | dst_offset += dev_priv->gart_info.aper_base; |
595 | 581 | ||
596 | ret = RING_SPACE(chan, 3); | 582 | ret = RING_SPACE(chan, 3); |
597 | if (ret) | 583 | if (ret) |
@@ -737,7 +723,7 @@ nouveau_bo_move_m2mf(struct ttm_buffer_object *bo, int evict, bool intr, | |||
737 | int ret; | 723 | int ret; |
738 | 724 | ||
739 | chan = nvbo->channel; | 725 | chan = nvbo->channel; |
740 | if (!chan || nvbo->no_vm) { | 726 | if (!chan) { |
741 | chan = dev_priv->channel; | 727 | chan = dev_priv->channel; |
742 | mutex_lock_nested(&chan->mutex, NOUVEAU_KCHANNEL_MUTEX); | 728 | mutex_lock_nested(&chan->mutex, NOUVEAU_KCHANNEL_MUTEX); |
743 | } | 729 | } |
@@ -836,7 +822,7 @@ nouveau_bo_vm_bind(struct ttm_buffer_object *bo, struct ttm_mem_reg *new_mem, | |||
836 | struct nouveau_bo *nvbo = nouveau_bo(bo); | 822 | struct nouveau_bo *nvbo = nouveau_bo(bo); |
837 | uint64_t offset; | 823 | uint64_t offset; |
838 | 824 | ||
839 | if (nvbo->no_vm || new_mem->mem_type != TTM_PL_VRAM) { | 825 | if (new_mem->mem_type != TTM_PL_VRAM) { |
840 | /* Nothing to do. */ | 826 | /* Nothing to do. */ |
841 | *new_tile = NULL; | 827 | *new_tile = NULL; |
842 | return 0; | 828 | return 0; |