habanalabs: make sure device mem alloc is page aligned
Working with MMU that supports multiple page sizes requires that mapping of a page of a certain size will be aligned to the same size (e.g. the physical address of 32MB page shall be aligned to 32MB). To achieve this the gen_poll allocation is now using the "align" variant to comply with the alignment requirements. Signed-off-by: Ohad Sharabi <osharabi@habana.ai> Reviewed-by: Oded Gabbay <ogabbay@kernel.org> Signed-off-by: Oded Gabbay <ogabbay@kernel.org>
This commit is contained in:
parent
100fcf1e11
commit
e8458e20e0
|
@ -90,8 +90,8 @@ static int alloc_device_memory(struct hl_ctx *ctx, struct hl_mem_in *args,
|
||||||
struct hl_vm_phys_pg_pack *phys_pg_pack;
|
struct hl_vm_phys_pg_pack *phys_pg_pack;
|
||||||
u64 paddr = 0, total_size, num_pgs, i;
|
u64 paddr = 0, total_size, num_pgs, i;
|
||||||
u32 num_curr_pgs, page_size;
|
u32 num_curr_pgs, page_size;
|
||||||
int handle, rc;
|
|
||||||
bool contiguous;
|
bool contiguous;
|
||||||
|
int handle, rc;
|
||||||
|
|
||||||
num_curr_pgs = 0;
|
num_curr_pgs = 0;
|
||||||
|
|
||||||
|
@ -110,7 +110,11 @@ static int alloc_device_memory(struct hl_ctx *ctx, struct hl_mem_in *args,
|
||||||
contiguous = args->flags & HL_MEM_CONTIGUOUS;
|
contiguous = args->flags & HL_MEM_CONTIGUOUS;
|
||||||
|
|
||||||
if (contiguous) {
|
if (contiguous) {
|
||||||
paddr = (u64) gen_pool_alloc(vm->dram_pg_pool, total_size);
|
if (is_power_of_2(page_size))
|
||||||
|
paddr = (u64) (uintptr_t) gen_pool_dma_alloc_align(vm->dram_pg_pool,
|
||||||
|
total_size, NULL, page_size);
|
||||||
|
else
|
||||||
|
paddr = (u64) (uintptr_t) gen_pool_alloc(vm->dram_pg_pool, total_size);
|
||||||
if (!paddr) {
|
if (!paddr) {
|
||||||
dev_err(hdev->dev,
|
dev_err(hdev->dev,
|
||||||
"failed to allocate %llu contiguous pages with total size of %llu\n",
|
"failed to allocate %llu contiguous pages with total size of %llu\n",
|
||||||
|
@ -144,9 +148,14 @@ static int alloc_device_memory(struct hl_ctx *ctx, struct hl_mem_in *args,
|
||||||
phys_pg_pack->pages[i] = paddr + i * page_size;
|
phys_pg_pack->pages[i] = paddr + i * page_size;
|
||||||
} else {
|
} else {
|
||||||
for (i = 0 ; i < num_pgs ; i++) {
|
for (i = 0 ; i < num_pgs ; i++) {
|
||||||
phys_pg_pack->pages[i] = (u64) gen_pool_alloc(
|
if (is_power_of_2(page_size))
|
||||||
vm->dram_pg_pool,
|
phys_pg_pack->pages[i] =
|
||||||
page_size);
|
(u64) gen_pool_dma_alloc_align(vm->dram_pg_pool,
|
||||||
|
page_size, NULL,
|
||||||
|
page_size);
|
||||||
|
else
|
||||||
|
phys_pg_pack->pages[i] = (u64) gen_pool_alloc(vm->dram_pg_pool,
|
||||||
|
page_size);
|
||||||
if (!phys_pg_pack->pages[i]) {
|
if (!phys_pg_pack->pages[i]) {
|
||||||
dev_err(hdev->dev,
|
dev_err(hdev->dev,
|
||||||
"Failed to allocate device memory (out of memory)\n");
|
"Failed to allocate device memory (out of memory)\n");
|
||||||
|
|
Loading…
Reference in New Issue