drm/nouveau/bar: add noncached ioremap property
Some BARs (like GK20A's) do not support being ioremapped write-combined. Add a boolean property to the BAR structure and handle that case in the Nouveau BO implementation. Signed-off-by: Alexandre Courbot <acourbot@nvidia.com>
This commit is contained in:
parent
8ba9ff1163
commit
e2a4e78cdc
|
@ -20,6 +20,9 @@ struct nouveau_bar {
|
||||||
u32 flags, struct nouveau_vma *);
|
u32 flags, struct nouveau_vma *);
|
||||||
void (*unmap)(struct nouveau_bar *, struct nouveau_vma *);
|
void (*unmap)(struct nouveau_bar *, struct nouveau_vma *);
|
||||||
void (*flush)(struct nouveau_bar *);
|
void (*flush)(struct nouveau_bar *);
|
||||||
|
|
||||||
|
/* whether the BAR supports to be ioremapped WC or should be uncached */
|
||||||
|
bool iomap_uncached;
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline struct nouveau_bar *
|
static inline struct nouveau_bar *
|
||||||
|
|
|
@ -500,18 +500,25 @@ nouveau_bo_init_mem_type(struct ttm_bo_device *bdev, uint32_t type,
|
||||||
man->default_caching = TTM_PL_FLAG_CACHED;
|
man->default_caching = TTM_PL_FLAG_CACHED;
|
||||||
break;
|
break;
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
|
man->flags = TTM_MEMTYPE_FLAG_FIXED |
|
||||||
|
TTM_MEMTYPE_FLAG_MAPPABLE;
|
||||||
|
man->available_caching = TTM_PL_FLAG_UNCACHED |
|
||||||
|
TTM_PL_FLAG_WC;
|
||||||
|
man->default_caching = TTM_PL_FLAG_WC;
|
||||||
|
|
||||||
if (nv_device(drm->device)->card_type >= NV_50) {
|
if (nv_device(drm->device)->card_type >= NV_50) {
|
||||||
|
/* Some BARs do not support being ioremapped WC */
|
||||||
|
if (nouveau_bar(drm->device)->iomap_uncached) {
|
||||||
|
man->available_caching = TTM_PL_FLAG_UNCACHED;
|
||||||
|
man->default_caching = TTM_PL_FLAG_UNCACHED;
|
||||||
|
}
|
||||||
|
|
||||||
man->func = &nouveau_vram_manager;
|
man->func = &nouveau_vram_manager;
|
||||||
man->io_reserve_fastpath = false;
|
man->io_reserve_fastpath = false;
|
||||||
man->use_io_reserve_lru = true;
|
man->use_io_reserve_lru = true;
|
||||||
} else {
|
} else {
|
||||||
man->func = &ttm_bo_manager_func;
|
man->func = &ttm_bo_manager_func;
|
||||||
}
|
}
|
||||||
man->flags = TTM_MEMTYPE_FLAG_FIXED |
|
|
||||||
TTM_MEMTYPE_FLAG_MAPPABLE;
|
|
||||||
man->available_caching = TTM_PL_FLAG_UNCACHED |
|
|
||||||
TTM_PL_FLAG_WC;
|
|
||||||
man->default_caching = TTM_PL_FLAG_WC;
|
|
||||||
break;
|
break;
|
||||||
case TTM_PL_TT:
|
case TTM_PL_TT:
|
||||||
if (nv_device(drm->device)->card_type >= NV_50)
|
if (nv_device(drm->device)->card_type >= NV_50)
|
||||||
|
|
Loading…
Reference in New Issue