int host_stage2_set_owner_locked(phys_addr_t addr, u64 size, u8 owner_id)
{
- int ret;
+ int ret = -EINVAL;
if (!range_is_memory(addr, addr + size))
return -EPERM;
- ret = host_stage2_try(kvm_pgtable_stage2_set_owner, &host_mmu.pgt,
- addr, size, &host_s2_pool, owner_id);
- if (ret)
- return ret;
-
- /* Don't forget to update the vmemmap tracking for the host */
- if (owner_id == PKVM_ID_HOST)
- __host_update_page_state(addr, size, PKVM_PAGE_OWNED);
- else
- __host_update_page_state(addr, size, PKVM_NOPAGE);
+ switch (owner_id) {
+ case PKVM_ID_HOST:
+ ret = host_stage2_idmap_locked(addr, size, PKVM_HOST_MEM_PROT);
+ if (!ret)
+ __host_update_page_state(addr, size, PKVM_PAGE_OWNED);
+ break;
+ case PKVM_ID_GUEST:
+ case PKVM_ID_HYP:
+ ret = host_stage2_try(kvm_pgtable_stage2_set_owner, &host_mmu.pgt,
+ addr, size, &host_s2_pool, owner_id);
+ if (!ret)
+ __host_update_page_state(addr, size, PKVM_NOPAGE);
+ break;
+ }
- return 0;
+ return ret;
}
static bool host_stage2_force_pte_cb(u64 addr, u64 end, enum kvm_pgtable_prot prot)