Commit ed47c5cb authored by Zhao Yakui's avatar Zhao Yakui Committed by Zhenyu Wang

drm/i915/gvt: Refine the combined intel_vgpu_oos_page struct to save memory

The intel_vgpu_oos_page uses the combined structure, which embeds the
tracked page. As it is allocated by kmalloc, the size(4140) is aligned
to 8192. The 8192 oos_pages will waste about 32M memory.
So the tracked page is split from the intel_vgpu_oos_page. And this will
help to assure that the access of tracked page is cache aligned.

Another minor change is that it doesn't need to be cleared to zero as
it is writen firstly when one page is added to oos_page list.
Signed-off-by: default avatarZhao Yakui <yakui.zhao@intel.com>
Reviewed-by: default avatarZhenyu Wang <zhenyuw@linux.intel.com>
Signed-off-by: default avatarZhenyu Wang <zhenyuw@linux.intel.com>
parent f74a6d9a
...@@ -2488,6 +2488,7 @@ static void clean_spt_oos(struct intel_gvt *gvt) ...@@ -2488,6 +2488,7 @@ static void clean_spt_oos(struct intel_gvt *gvt)
list_for_each_safe(pos, n, &gtt->oos_page_free_list_head) { list_for_each_safe(pos, n, &gtt->oos_page_free_list_head) {
oos_page = container_of(pos, struct intel_vgpu_oos_page, list); oos_page = container_of(pos, struct intel_vgpu_oos_page, list);
list_del(&oos_page->list); list_del(&oos_page->list);
free_page((unsigned long)oos_page->mem);
kfree(oos_page); kfree(oos_page);
} }
} }
...@@ -2508,6 +2509,12 @@ static int setup_spt_oos(struct intel_gvt *gvt) ...@@ -2508,6 +2509,12 @@ static int setup_spt_oos(struct intel_gvt *gvt)
ret = -ENOMEM; ret = -ENOMEM;
goto fail; goto fail;
} }
oos_page->mem = (void *)__get_free_pages(GFP_KERNEL, 0);
if (!oos_page->mem) {
ret = -ENOMEM;
kfree(oos_page);
goto fail;
}
INIT_LIST_HEAD(&oos_page->list); INIT_LIST_HEAD(&oos_page->list);
INIT_LIST_HEAD(&oos_page->vm_list); INIT_LIST_HEAD(&oos_page->vm_list);
......
...@@ -221,7 +221,7 @@ struct intel_vgpu_oos_page { ...@@ -221,7 +221,7 @@ struct intel_vgpu_oos_page {
struct list_head list; struct list_head list;
struct list_head vm_list; struct list_head vm_list;
int id; int id;
unsigned char mem[I915_GTT_PAGE_SIZE]; void *mem;
}; };
#define GTT_ENTRY_NUM_IN_ONE_PAGE 512 #define GTT_ENTRY_NUM_IN_ONE_PAGE 512
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment