mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-09 14:14:00 +08:00
044ac37d12
So far, we've implemented the new world switch with a completely different namespace, so that we could have both implementation compiled in. Let's take things one step further by adding weak aliases that have the same names as the original implementation. The weak attributes allows the new implementation to be overriden by the old one, and everything still work. At a later point, we'll be able to simply drop the old code, and everything will hopefully keep working, thanks to the aliases we have just added. This also saves us repainting all the callers. Signed-off-by: Marc Zyngier <marc.zyngier@arm.com> Acked-by: Christoffer Dall <christoffer.dall@linaro.org>
83 lines
2.1 KiB
C
83 lines
2.1 KiB
C
/*
|
|
* Copyright (C) 2015 - ARM Ltd
|
|
* Author: Marc Zyngier <marc.zyngier@arm.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "hyp.h"
|
|
|
|
void __hyp_text __tlb_flush_vmid_ipa(struct kvm *kvm, phys_addr_t ipa)
|
|
{
|
|
dsb(ishst);
|
|
|
|
/* Switch to requested VMID */
|
|
kvm = kern_hyp_va(kvm);
|
|
write_sysreg(kvm->arch.vttbr, vttbr_el2);
|
|
isb();
|
|
|
|
/*
|
|
* We could do so much better if we had the VA as well.
|
|
* Instead, we invalidate Stage-2 for this IPA, and the
|
|
* whole of Stage-1. Weep...
|
|
*/
|
|
ipa >>= 12;
|
|
asm volatile("tlbi ipas2e1is, %0" : : "r" (ipa));
|
|
|
|
/*
|
|
* We have to ensure completion of the invalidation at Stage-2,
|
|
* since a table walk on another CPU could refill a TLB with a
|
|
* complete (S1 + S2) walk based on the old Stage-2 mapping if
|
|
* the Stage-1 invalidation happened first.
|
|
*/
|
|
dsb(ish);
|
|
asm volatile("tlbi vmalle1is" : : );
|
|
dsb(ish);
|
|
isb();
|
|
|
|
write_sysreg(0, vttbr_el2);
|
|
}
|
|
|
|
__alias(__tlb_flush_vmid_ipa)
|
|
void __weak __kvm_tlb_flush_vmid_ipa(struct kvm *kvm, phys_addr_t ipa);
|
|
|
|
void __hyp_text __tlb_flush_vmid(struct kvm *kvm)
|
|
{
|
|
dsb(ishst);
|
|
|
|
/* Switch to requested VMID */
|
|
kvm = kern_hyp_va(kvm);
|
|
write_sysreg(kvm->arch.vttbr, vttbr_el2);
|
|
isb();
|
|
|
|
asm volatile("tlbi vmalls12e1is" : : );
|
|
dsb(ish);
|
|
isb();
|
|
|
|
write_sysreg(0, vttbr_el2);
|
|
}
|
|
|
|
__alias(__tlb_flush_vmid)
|
|
void __weak __kvm_tlb_flush_vmid(struct kvm *kvm);
|
|
|
|
void __hyp_text __tlb_flush_vm_context(void)
|
|
{
|
|
dsb(ishst);
|
|
asm volatile("tlbi alle1is \n"
|
|
"ic ialluis ": : );
|
|
dsb(ish);
|
|
}
|
|
|
|
__alias(__tlb_flush_vm_context)
|
|
void __weak __kvm_flush_vm_context(void);
|