diff options
-rw-r--r-- | drivers/gpu/drm/nouveau/nouveau_bo.c | 41 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nouveau_mem.c | 3 |
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 | ||
56 | static void | 56 | static void |
57 | nouveau_bo_fixup_align(struct drm_device *dev, | 57 | nouveau_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 | ||
92 | int | 98 | int |
@@ -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; |