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:
Ohad Sharabi 2022-02-06 08:50:43 +02:00 committed by Oded Gabbay
parent 100fcf1e11
commit e8458e20e0
1 changed files with 14 additions and 5 deletions

View File

@ -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");