Commit 03b9a6e1 authored by Zhao Liu's avatar Zhao Liu Committed by Wei Liu

x86/hyperv: Remove BUG_ON() for kmap_local_page()

The commit 154fb14d ("x86/hyperv: Replace kmap() with
kmap_local_page()") keeps the BUG_ON() to check if kmap_local_page()
fails.

But in fact, kmap_local_page() always returns a valid kernel address
and won't return NULL here. It will BUG on its own if it fails. [1]

So directly use memcpy_to_page() which creates local mapping to copy.

[1]: https://lore.kernel.org/lkml/YztFEyUA48et0yTt@iweiny-mobl/Suggested-by: default avatarFabio M. De Francesco <fmdefrancesco@gmail.com>
Suggested-by: default avatarIra Weiny <ira.weiny@intel.com>
Reviewed-by: default avatarIra Weiny <ira.weiny@intel.com>
Signed-off-by: default avatarZhao Liu <zhao1.liu@intel.com>
Link: https://lore.kernel.org/r/20221020083820.2341088-1-zhao1.liu@linux.intel.comSigned-off-by: default avatarWei Liu <wei.liu@kernel.org>
parent 247f34f7
...@@ -444,7 +444,7 @@ void __init hyperv_init(void) ...@@ -444,7 +444,7 @@ void __init hyperv_init(void)
if (hv_root_partition) { if (hv_root_partition) {
struct page *pg; struct page *pg;
void *src, *dst; void *src;
/* /*
* For the root partition, the hypervisor will set up its * For the root partition, the hypervisor will set up its
...@@ -459,13 +459,11 @@ void __init hyperv_init(void) ...@@ -459,13 +459,11 @@ void __init hyperv_init(void)
wrmsrl(HV_X64_MSR_HYPERCALL, hypercall_msr.as_uint64); wrmsrl(HV_X64_MSR_HYPERCALL, hypercall_msr.as_uint64);
pg = vmalloc_to_page(hv_hypercall_pg); pg = vmalloc_to_page(hv_hypercall_pg);
dst = kmap_local_page(pg);
src = memremap(hypercall_msr.guest_physical_address << PAGE_SHIFT, PAGE_SIZE, src = memremap(hypercall_msr.guest_physical_address << PAGE_SHIFT, PAGE_SIZE,
MEMREMAP_WB); MEMREMAP_WB);
BUG_ON(!(src && dst)); BUG_ON(!src);
memcpy(dst, src, HV_HYP_PAGE_SIZE); memcpy_to_page(pg, 0, src, HV_HYP_PAGE_SIZE);
memunmap(src); memunmap(src);
kunmap_local(dst);
} else { } else {
hypercall_msr.guest_physical_address = vmalloc_to_pfn(hv_hypercall_pg); hypercall_msr.guest_physical_address = vmalloc_to_pfn(hv_hypercall_pg);
wrmsrl(HV_X64_MSR_HYPERCALL, hypercall_msr.as_uint64); wrmsrl(HV_X64_MSR_HYPERCALL, hypercall_msr.as_uint64);
......
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