From 58dd20f86b3b9faef89b24f2b4ec6b62a183fe9d Mon Sep 17 00:00:00 2001 From: Terje Bergstrom Date: Tue, 7 Nov 2017 09:56:40 -0800 Subject: gpu: nvgpu: Introduce queries for big page sizes Introduce query functions for default big page size and available big page sizes. Move initialization of GPU characteristics big page sizes to the GPU characteristics query function. JIRA NVGPU-259 Change-Id: Ie66cc2fbfcd88205593056f8d5010ac2539c8bc2 Signed-off-by: Terje Bergstrom Reviewed-on: https://git-master.nvidia.com/r/1593685 Reviewed-by: mobile promotions Tested-by: mobile promotions --- drivers/gpu/nvgpu/common/as.c | 2 +- drivers/gpu/nvgpu/common/linux/ioctl_ctrl.c | 5 +++++ drivers/gpu/nvgpu/common/mm/mm.c | 26 ++++++++++++++++++++++++++ drivers/gpu/nvgpu/gk20a/gk20a.c | 12 ------------ drivers/gpu/nvgpu/include/nvgpu/mm.h | 2 ++ 5 files changed, 34 insertions(+), 13 deletions(-) (limited to 'drivers/gpu') diff --git a/drivers/gpu/nvgpu/common/as.c b/drivers/gpu/nvgpu/common/as.c index 31cdd0b6..f4f00fba 100644 --- a/drivers/gpu/nvgpu/common/as.c +++ b/drivers/gpu/nvgpu/common/as.c @@ -62,7 +62,7 @@ static int gk20a_vm_alloc_share(struct gk20a_as_share *as_share, if (!is_power_of_2(big_page_size)) return -EINVAL; - if (!(big_page_size & g->gpu_characteristics.available_big_page_sizes)) + if (!(big_page_size & nvgpu_mm_get_available_big_page_sizes(g))) return -EINVAL; } diff --git a/drivers/gpu/nvgpu/common/linux/ioctl_ctrl.c b/drivers/gpu/nvgpu/common/linux/ioctl_ctrl.c index d3961f79..02dedc9f 100644 --- a/drivers/gpu/nvgpu/common/linux/ioctl_ctrl.c +++ b/drivers/gpu/nvgpu/common/linux/ioctl_ctrl.c @@ -211,6 +211,11 @@ gk20a_ctrl_ioctl_gpu_characteristics( pgpu->vbios_version = g->bios.vbios_version; pgpu->vbios_oem_version = g->bios.vbios_oem_version; + pgpu->big_page_size = nvgpu_mm_get_default_big_page_size(g); + pgpu->pde_coverage_bit_count = + g->ops.mm.get_mmu_levels(g, pgpu->big_page_size)[0].lo_bit[0]; + pgpu->available_big_page_sizes = nvgpu_mm_get_available_big_page_sizes(g); + if (request->gpu_characteristics_buf_size > 0) { size_t write_size = sizeof(*pgpu); diff --git a/drivers/gpu/nvgpu/common/mm/mm.c b/drivers/gpu/nvgpu/common/mm/mm.c index 73af31c9..86dc46c5 100644 --- a/drivers/gpu/nvgpu/common/mm/mm.c +++ b/drivers/gpu/nvgpu/common/mm/mm.c @@ -423,3 +423,29 @@ int nvgpu_init_mm_support(struct gk20a *g) return err; } + +u32 nvgpu_mm_get_default_big_page_size(struct gk20a *g) +{ + u32 big_page_size; + + big_page_size = g->ops.mm.get_default_big_page_size(); + + if (g->mm.disable_bigpage) + big_page_size = 0; + + return big_page_size; +} + +u32 nvgpu_mm_get_available_big_page_sizes(struct gk20a *g) +{ + u32 available_big_page_sizes = 0; + + if (!g->mm.disable_bigpage) { + available_big_page_sizes = + g->ops.mm.get_default_big_page_size(); + if (g->ops.mm.get_big_page_sizes) + available_big_page_sizes |= g->ops.mm.get_big_page_sizes(); + } + + return available_big_page_sizes; +} diff --git a/drivers/gpu/nvgpu/gk20a/gk20a.c b/drivers/gpu/nvgpu/gk20a/gk20a.c index 756db415..a9ee65d0 100644 --- a/drivers/gpu/nvgpu/gk20a/gk20a.c +++ b/drivers/gpu/nvgpu/gk20a/gk20a.c @@ -394,18 +394,6 @@ int gk20a_init_gpu_characteristics(struct gk20a *g) gpu->bus_type = NVGPU_GPU_BUS_TYPE_AXI; /* always AXI for now */ gpu->compression_page_size = g->ops.fb.compression_page_size(g); - gpu->big_page_size = g->ops.mm.get_default_big_page_size(); - gpu->pde_coverage_bit_count = - g->ops.mm.get_mmu_levels(g, gpu->big_page_size)[0].lo_bit[0]; - - if (g->mm.disable_bigpage) { - gpu->big_page_size = 0; - gpu->available_big_page_sizes = 0; - } else { - gpu->available_big_page_sizes = gpu->big_page_size; - if (g->ops.mm.get_big_page_sizes) - gpu->available_big_page_sizes |= g->ops.mm.get_big_page_sizes(); - } __nvgpu_set_enabled(g, NVGPU_SUPPORT_PARTIAL_MAPPINGS, true); __nvgpu_set_enabled(g, NVGPU_SUPPORT_MAP_DIRECT_KIND_CTRL, true); diff --git a/drivers/gpu/nvgpu/include/nvgpu/mm.h b/drivers/gpu/nvgpu/include/nvgpu/mm.h index 13b33d9f..9882b31e 100644 --- a/drivers/gpu/nvgpu/include/nvgpu/mm.h +++ b/drivers/gpu/nvgpu/include/nvgpu/mm.h @@ -216,5 +216,7 @@ u64 nvgpu_inst_block_addr(struct gk20a *g, struct nvgpu_mem *mem); void nvgpu_free_inst_block(struct gk20a *g, struct nvgpu_mem *inst_block); int nvgpu_mm_suspend(struct gk20a *g); +u32 nvgpu_mm_get_default_big_page_size(struct gk20a *g); +u32 nvgpu_mm_get_available_big_page_sizes(struct gk20a *g); #endif -- cgit v1.2.2