KVM: ia64: Implement a uniform vps interface
An uniform entry kvm_vps_entry is added for vps_sync_write/read, vps_resume_handler/guest, and branches to differnt PAL service according to the offset. Singed-off-by: Anthony Xu <anthony.xu@intel.com> Signed-off-by: Xiantao Zhang <xiantao.zhang@intel.com> Signed-off-by: Avi Kivity <avi@redhat.com>
This commit is contained in:
parent
271b05281f
commit
81aec5227e
@ -50,27 +50,18 @@
|
|||||||
|
|
||||||
#define PAL_VSA_SYNC_READ \
|
#define PAL_VSA_SYNC_READ \
|
||||||
/* begin to call pal vps sync_read */ \
|
/* begin to call pal vps sync_read */ \
|
||||||
|
{.mii; \
|
||||||
add r25 = VMM_VPD_BASE_OFFSET, r21; \
|
add r25 = VMM_VPD_BASE_OFFSET, r21; \
|
||||||
adds r20 = VMM_VCPU_VSA_BASE_OFFSET, r21; /* entry point */ \
|
|
||||||
;; \
|
|
||||||
ld8 r25 = [r25]; /* read vpd base */ \
|
|
||||||
ld8 r20 = [r20]; \
|
|
||||||
;; \
|
|
||||||
add r20 = PAL_VPS_SYNC_READ,r20; \
|
|
||||||
;; \
|
|
||||||
{ .mii; \
|
|
||||||
nop 0x0; \
|
nop 0x0; \
|
||||||
mov r24 = ip; \
|
mov r24=ip; \
|
||||||
mov b0 = r20; \
|
;; \
|
||||||
|
} \
|
||||||
|
{.mmb \
|
||||||
|
add r24=0x20, r24; \
|
||||||
|
ld8 r25 = [r25]; /* read vpd base */ \
|
||||||
|
br.cond.sptk kvm_vps_sync_read; /*call the service*/ \
|
||||||
;; \
|
;; \
|
||||||
}; \
|
}; \
|
||||||
{ .mmb; \
|
|
||||||
add r24 = 0x20, r24; \
|
|
||||||
nop 0x0; \
|
|
||||||
br.cond.sptk b0; /* call the service */ \
|
|
||||||
;; \
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define KVM_MINSTATE_GET_CURRENT(reg) mov reg=r21
|
#define KVM_MINSTATE_GET_CURRENT(reg) mov reg=r21
|
||||||
|
@ -20,6 +20,75 @@
|
|||||||
#define ACCE_MOV_TO_PSR
|
#define ACCE_MOV_TO_PSR
|
||||||
#define ACCE_THASH
|
#define ACCE_THASH
|
||||||
|
|
||||||
|
ENTRY(kvm_vps_entry)
|
||||||
|
adds r29 = VMM_VCPU_VSA_BASE_OFFSET,r21
|
||||||
|
;;
|
||||||
|
ld8 r29 = [r29]
|
||||||
|
;;
|
||||||
|
add r29 = r29, r30
|
||||||
|
;;
|
||||||
|
mov b0 = r29
|
||||||
|
br.sptk.many b0
|
||||||
|
END(kvm_vps_entry)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Inputs:
|
||||||
|
* r24 : return address
|
||||||
|
* r25 : vpd
|
||||||
|
* r29 : scratch
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
GLOBAL_ENTRY(kvm_vps_sync_read)
|
||||||
|
movl r30 = PAL_VPS_SYNC_READ
|
||||||
|
;;
|
||||||
|
br.sptk.many kvm_vps_entry
|
||||||
|
END(kvm_vps_sync_read)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Inputs:
|
||||||
|
* r24 : return address
|
||||||
|
* r25 : vpd
|
||||||
|
* r29 : scratch
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
GLOBAL_ENTRY(kvm_vps_sync_write)
|
||||||
|
movl r30 = PAL_VPS_SYNC_WRITE
|
||||||
|
;;
|
||||||
|
br.sptk.many kvm_vps_entry
|
||||||
|
END(kvm_vps_sync_write)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Inputs:
|
||||||
|
* r23 : pr
|
||||||
|
* r24 : guest b0
|
||||||
|
* r25 : vpd
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
GLOBAL_ENTRY(kvm_vps_resume_normal)
|
||||||
|
movl r30 = PAL_VPS_RESUME_NORMAL
|
||||||
|
;;
|
||||||
|
mov pr=r23,-2
|
||||||
|
br.sptk.many kvm_vps_entry
|
||||||
|
END(kvm_vps_resume_normal)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Inputs:
|
||||||
|
* r23 : pr
|
||||||
|
* r24 : guest b0
|
||||||
|
* r25 : vpd
|
||||||
|
* r17 : isr
|
||||||
|
*/
|
||||||
|
GLOBAL_ENTRY(kvm_vps_resume_handler)
|
||||||
|
movl r30 = PAL_VPS_RESUME_HANDLER
|
||||||
|
;;
|
||||||
|
ld8 r27=[r25]
|
||||||
|
shr r17=r17,IA64_ISR_IR_BIT
|
||||||
|
;;
|
||||||
|
dep r27=r17,r27,63,1 // bit 63 of r27 indicate whether enable CFLE
|
||||||
|
mov pr=r23,-2
|
||||||
|
br.sptk.many kvm_vps_entry
|
||||||
|
END(kvm_vps_resume_handler)
|
||||||
|
|
||||||
//mov r1=ar3
|
//mov r1=ar3
|
||||||
GLOBAL_ENTRY(kvm_asm_mov_from_ar)
|
GLOBAL_ENTRY(kvm_asm_mov_from_ar)
|
||||||
#ifndef ACCE_MOV_FROM_AR
|
#ifndef ACCE_MOV_FROM_AR
|
||||||
|
@ -962,9 +962,9 @@ static void kvm_do_resume_op(struct kvm_vcpu *vcpu)
|
|||||||
void vmm_transition(struct kvm_vcpu *vcpu)
|
void vmm_transition(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
ia64_call_vsa(PAL_VPS_SAVE, (unsigned long)vcpu->arch.vpd,
|
ia64_call_vsa(PAL_VPS_SAVE, (unsigned long)vcpu->arch.vpd,
|
||||||
0, 0, 0, 0, 0, 0);
|
1, 0, 0, 0, 0, 0);
|
||||||
vmm_trampoline(&vcpu->arch.guest, &vcpu->arch.host);
|
vmm_trampoline(&vcpu->arch.guest, &vcpu->arch.host);
|
||||||
ia64_call_vsa(PAL_VPS_RESTORE, (unsigned long)vcpu->arch.vpd,
|
ia64_call_vsa(PAL_VPS_RESTORE, (unsigned long)vcpu->arch.vpd,
|
||||||
0, 0, 0, 0, 0, 0);
|
1, 0, 0, 0, 0, 0);
|
||||||
kvm_do_resume_op(vcpu);
|
kvm_do_resume_op(vcpu);
|
||||||
}
|
}
|
||||||
|
@ -1261,11 +1261,6 @@ kvm_rse_clear_invalid:
|
|||||||
adds r19=VMM_VPD_VPSR_OFFSET,r18
|
adds r19=VMM_VPD_VPSR_OFFSET,r18
|
||||||
;;
|
;;
|
||||||
ld8 r19=[r19] //vpsr
|
ld8 r19=[r19] //vpsr
|
||||||
adds r20=VMM_VCPU_VSA_BASE_OFFSET,r21
|
|
||||||
;;
|
|
||||||
ld8 r20=[r20]
|
|
||||||
;;
|
|
||||||
//vsa_sync_write_start
|
|
||||||
mov r25=r18
|
mov r25=r18
|
||||||
adds r16= VMM_VCPU_GP_OFFSET,r21
|
adds r16= VMM_VCPU_GP_OFFSET,r21
|
||||||
;;
|
;;
|
||||||
@ -1274,10 +1269,7 @@ kvm_rse_clear_invalid:
|
|||||||
;;
|
;;
|
||||||
add r24=r24,r16
|
add r24=r24,r16
|
||||||
;;
|
;;
|
||||||
add r16=PAL_VPS_SYNC_WRITE,r20
|
br.sptk.many kvm_vps_sync_write // call the service
|
||||||
;;
|
|
||||||
mov b0=r16
|
|
||||||
br.cond.sptk b0 // call the service
|
|
||||||
;;
|
;;
|
||||||
END(ia64_leave_hypervisor)
|
END(ia64_leave_hypervisor)
|
||||||
// fall through
|
// fall through
|
||||||
@ -1288,28 +1280,15 @@ GLOBAL_ENTRY(ia64_vmm_entry)
|
|||||||
* r17:cr.isr
|
* r17:cr.isr
|
||||||
* r18:vpd
|
* r18:vpd
|
||||||
* r19:vpsr
|
* r19:vpsr
|
||||||
* r20:__vsa_base
|
|
||||||
* r22:b0
|
* r22:b0
|
||||||
* r23:predicate
|
* r23:predicate
|
||||||
*/
|
*/
|
||||||
mov r24=r22
|
mov r24=r22
|
||||||
mov r25=r18
|
mov r25=r18
|
||||||
tbit.nz p1,p2 = r19,IA64_PSR_IC_BIT // p1=vpsr.ic
|
tbit.nz p1,p2 = r19,IA64_PSR_IC_BIT // p1=vpsr.ic
|
||||||
|
(p1) br.cond.sptk.few kvm_vps_resume_normal
|
||||||
|
(p2) br.cond.sptk.many kvm_vps_resume_handler
|
||||||
;;
|
;;
|
||||||
(p1) add r29=PAL_VPS_RESUME_NORMAL,r20
|
|
||||||
(p1) br.sptk.many ia64_vmm_entry_out
|
|
||||||
;;
|
|
||||||
tbit.nz p1,p2 = r17,IA64_ISR_IR_BIT //p1=cr.isr.ir
|
|
||||||
;;
|
|
||||||
(p1) add r29=PAL_VPS_RESUME_NORMAL,r20
|
|
||||||
(p2) add r29=PAL_VPS_RESUME_HANDLER,r20
|
|
||||||
(p2) ld8 r26=[r25]
|
|
||||||
;;
|
|
||||||
ia64_vmm_entry_out:
|
|
||||||
mov pr=r23,-2
|
|
||||||
mov b0=r29
|
|
||||||
;;
|
|
||||||
br.cond.sptk b0 // call pal service
|
|
||||||
END(ia64_vmm_entry)
|
END(ia64_vmm_entry)
|
||||||
|
|
||||||
|
|
||||||
@ -1376,6 +1355,9 @@ GLOBAL_ENTRY(vmm_reset_entry)
|
|||||||
//set up ipsr, iip, vpd.vpsr, dcr
|
//set up ipsr, iip, vpd.vpsr, dcr
|
||||||
// For IPSR: it/dt/rt=1, i/ic=1, si=1, vm/bn=1
|
// For IPSR: it/dt/rt=1, i/ic=1, si=1, vm/bn=1
|
||||||
// For DCR: all bits 0
|
// For DCR: all bits 0
|
||||||
|
bsw.0
|
||||||
|
;;
|
||||||
|
mov r21 =r13
|
||||||
adds r14=-VMM_PT_REGS_SIZE, r12
|
adds r14=-VMM_PT_REGS_SIZE, r12
|
||||||
;;
|
;;
|
||||||
movl r6=0x501008826000 // IPSR dt/rt/it:1;i/ic:1, si:1, vm/bn:1
|
movl r6=0x501008826000 // IPSR dt/rt/it:1;i/ic:1, si:1, vm/bn:1
|
||||||
@ -1387,12 +1369,6 @@ GLOBAL_ENTRY(vmm_reset_entry)
|
|||||||
;;
|
;;
|
||||||
srlz.i
|
srlz.i
|
||||||
;;
|
;;
|
||||||
bsw.0
|
|
||||||
;;
|
|
||||||
mov r21 =r13
|
|
||||||
;;
|
|
||||||
bsw.1
|
|
||||||
;;
|
|
||||||
mov ar.rsc = 0
|
mov ar.rsc = 0
|
||||||
;;
|
;;
|
||||||
flushrs
|
flushrs
|
||||||
@ -1406,12 +1382,9 @@ GLOBAL_ENTRY(vmm_reset_entry)
|
|||||||
ld8 r1 = [r20]
|
ld8 r1 = [r20]
|
||||||
;;
|
;;
|
||||||
mov cr.iip=r4
|
mov cr.iip=r4
|
||||||
;;
|
|
||||||
adds r16=VMM_VPD_BASE_OFFSET,r13
|
adds r16=VMM_VPD_BASE_OFFSET,r13
|
||||||
adds r20=VMM_VCPU_VSA_BASE_OFFSET,r13
|
|
||||||
;;
|
;;
|
||||||
ld8 r18=[r16]
|
ld8 r18=[r16]
|
||||||
ld8 r20=[r20]
|
|
||||||
;;
|
;;
|
||||||
adds r19=VMM_VPD_VPSR_OFFSET,r18
|
adds r19=VMM_VPD_VPSR_OFFSET,r18
|
||||||
;;
|
;;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user