aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/drm/nouveau/nouveau_bo.c41
-rw-r--r--drivers/gpu/drm/nouveau/nouveau_mem.c3
2 files changed, 25 insertions, 19 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c
index 203e75de4128..bc28aeada8c3 100644
--- a/drivers/gpu/drm/nouveau/nouveau_bo.c
+++ b/drivers/gpu/drm/nouveau/nouveau_bo.c
@@ -54,39 +54,45 @@ nouveau_bo_del_ttm(struct ttm_buffer_object *bo)
54} 54}
55 55
56static void 56static void
57nouveau_bo_fixup_align(struct drm_device *dev, 57nouveau_bo_fixup_align(struct nouveau_bo *nvbo, int *align, int *size,
58 uint32_t tile_mode, uint32_t tile_flags, 58 int *page_shift)
59 int *align, int *size)
60{ 59{
61 struct drm_nouveau_private *dev_priv = dev->dev_private; 60 struct drm_nouveau_private *dev_priv = nouveau_bdev(nvbo->bo.bdev);
62 61
63 if (dev_priv->card_type < NV_50) { 62 if (dev_priv->card_type < NV_50) {
64 if (tile_mode) { 63 if (nvbo->tile_mode) {
65 if (dev_priv->chipset >= 0x40) { 64 if (dev_priv->chipset >= 0x40) {
66 *align = 65536; 65 *align = 65536;
67 *size = roundup(*size, 64 * tile_mode); 66 *size = roundup(*size, 64 * nvbo->tile_mode);
68 67
69 } else if (dev_priv->chipset >= 0x30) { 68 } else if (dev_priv->chipset >= 0x30) {
70 *align = 32768; 69 *align = 32768;
71 *size = roundup(*size, 64 * tile_mode); 70 *size = roundup(*size, 64 * nvbo->tile_mode);
72 71
73 } else if (dev_priv->chipset >= 0x20) { 72 } else if (dev_priv->chipset >= 0x20) {
74 *align = 16384; 73 *align = 16384;
75 *size = roundup(*size, 64 * tile_mode); 74 *size = roundup(*size, 64 * nvbo->tile_mode);
76 75
77 } else if (dev_priv->chipset >= 0x10) { 76 } else if (dev_priv->chipset >= 0x10) {
78 *align = 16384; 77 *align = 16384;
79 *size = roundup(*size, 32 * tile_mode); 78 *size = roundup(*size, 32 * nvbo->tile_mode);
80 } 79 }
81 } 80 }
81 } else {
82 if (likely(dev_priv->chan_vm)) {
83 if (*size > 256 * 1024)
84 *page_shift = dev_priv->chan_vm->lpg_shift;
85 else
86 *page_shift = dev_priv->chan_vm->spg_shift;
87 } else {
88 *page_shift = 12;
89 }
90
91 *size = roundup(*size, (1 << *page_shift));
92 *align = max((1 << *page_shift), *align);
82 } 93 }
83 94
84 /* ALIGN works only on powers of two. */
85 *size = roundup(*size, PAGE_SIZE); 95 *size = roundup(*size, PAGE_SIZE);
86 if (dev_priv->card_type == NV_50) {
87 *size = roundup(*size, 65536);
88 *align = max(65536, *align);
89 }
90} 96}
91 97
92int 98int
@@ -97,7 +103,7 @@ nouveau_bo_new(struct drm_device *dev, struct nouveau_channel *chan,
97{ 103{
98 struct drm_nouveau_private *dev_priv = dev->dev_private; 104 struct drm_nouveau_private *dev_priv = dev->dev_private;
99 struct nouveau_bo *nvbo; 105 struct nouveau_bo *nvbo;
100 int ret = 0; 106 int ret = 0, page_shift = 0;
101 107
102 nvbo = kzalloc(sizeof(struct nouveau_bo), GFP_KERNEL); 108 nvbo = kzalloc(sizeof(struct nouveau_bo), GFP_KERNEL);
103 if (!nvbo) 109 if (!nvbo)
@@ -110,12 +116,11 @@ nouveau_bo_new(struct drm_device *dev, struct nouveau_channel *chan,
110 nvbo->tile_flags = tile_flags; 116 nvbo->tile_flags = tile_flags;
111 nvbo->bo.bdev = &dev_priv->ttm.bdev; 117 nvbo->bo.bdev = &dev_priv->ttm.bdev;
112 118
113 nouveau_bo_fixup_align(dev, tile_mode, nouveau_bo_tile_layout(nvbo), 119 nouveau_bo_fixup_align(nvbo, &align, &size, &page_shift);
114 &align, &size);
115 align >>= PAGE_SHIFT; 120 align >>= PAGE_SHIFT;
116 121
117 if (!nvbo->no_vm && dev_priv->chan_vm) { 122 if (!nvbo->no_vm && dev_priv->chan_vm) {
118 ret = nouveau_vm_get(dev_priv->chan_vm, size, 16, 123 ret = nouveau_vm_get(dev_priv->chan_vm, size, page_shift,
119 NV_MEM_ACCESS_RW, &nvbo->vma); 124 NV_MEM_ACCESS_RW, &nvbo->vma);
120 if (ret) { 125 if (ret) {
121 kfree(nvbo); 126 kfree(nvbo);
diff --git a/drivers/gpu/drm/nouveau/nouveau_mem.c b/drivers/gpu/drm/nouveau/nouveau_mem.c
index 4d2d3de97ee9..3a531d53de4d 100644
--- a/drivers/gpu/drm/nouveau/nouveau_mem.c
+++ b/drivers/gpu/drm/nouveau/nouveau_mem.c
@@ -715,7 +715,8 @@ nouveau_vram_manager_new(struct ttm_mem_type_manager *man,
715 struct nouveau_vram *vram; 715 struct nouveau_vram *vram;
716 int ret; 716 int ret;
717 717
718 ret = nv50_vram_new(dev, mem->num_pages << PAGE_SHIFT, 65536, 0, 718 ret = nv50_vram_new(dev, mem->num_pages << PAGE_SHIFT,
719 mem->page_alignment << PAGE_SHIFT, 0,
719 (nvbo->tile_flags >> 8) & 0x7f, &vram); 720 (nvbo->tile_flags >> 8) & 0x7f, &vram);
720 if (ret) 721 if (ret)
721 return ret; 722 return ret;