|
@@ -509,8 +509,6 @@ static void unmap_hyp_range(pgd_t *pgdp, phys_addr_t start, u64 size)
|
|
*/
|
|
*/
|
|
void free_hyp_pgds(void)
|
|
void free_hyp_pgds(void)
|
|
{
|
|
{
|
|
- unsigned long addr;
|
|
|
|
-
|
|
|
|
mutex_lock(&kvm_hyp_pgd_mutex);
|
|
mutex_lock(&kvm_hyp_pgd_mutex);
|
|
|
|
|
|
if (boot_hyp_pgd) {
|
|
if (boot_hyp_pgd) {
|
|
@@ -521,10 +519,10 @@ void free_hyp_pgds(void)
|
|
|
|
|
|
if (hyp_pgd) {
|
|
if (hyp_pgd) {
|
|
unmap_hyp_range(hyp_pgd, hyp_idmap_start, PAGE_SIZE);
|
|
unmap_hyp_range(hyp_pgd, hyp_idmap_start, PAGE_SIZE);
|
|
- for (addr = PAGE_OFFSET; virt_addr_valid(addr); addr += PGDIR_SIZE)
|
|
|
|
- unmap_hyp_range(hyp_pgd, kern_hyp_va(addr), PGDIR_SIZE);
|
|
|
|
- for (addr = VMALLOC_START; is_vmalloc_addr((void*)addr); addr += PGDIR_SIZE)
|
|
|
|
- unmap_hyp_range(hyp_pgd, kern_hyp_va(addr), PGDIR_SIZE);
|
|
|
|
|
|
+ unmap_hyp_range(hyp_pgd, kern_hyp_va(PAGE_OFFSET),
|
|
|
|
+ (uintptr_t)high_memory - PAGE_OFFSET);
|
|
|
|
+ unmap_hyp_range(hyp_pgd, kern_hyp_va(VMALLOC_START),
|
|
|
|
+ VMALLOC_END - VMALLOC_START);
|
|
|
|
|
|
free_pages((unsigned long)hyp_pgd, hyp_pgd_order);
|
|
free_pages((unsigned long)hyp_pgd, hyp_pgd_order);
|
|
hyp_pgd = NULL;
|
|
hyp_pgd = NULL;
|