Lines Matching refs:GPR_K0

199 	UASM_i_LA(&p, GPR_K0, ST0_EXL | KSU_USER | ST0_BEV | ST0_KX_IF_64);  in kvm_mips_build_vcpu_run()
200 uasm_i_mtc0(&p, GPR_K0, C0_STATUS); in kvm_mips_build_vcpu_run()
204 UASM_i_LW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, guest_ebase), GPR_K1); in kvm_mips_build_vcpu_run()
205 build_set_exc_base(&p, GPR_K0); in kvm_mips_build_vcpu_run()
212 uasm_i_addiu(&p, GPR_K0, GPR_ZERO, ST0_EXL | KSU_USER | ST0_IE | ST0_KX_IF_64); in kvm_mips_build_vcpu_run()
214 uasm_i_or(&p, GPR_K0, GPR_K0, GPR_V0); in kvm_mips_build_vcpu_run()
215 uasm_i_mtc0(&p, GPR_K0, C0_STATUS); in kvm_mips_build_vcpu_run()
251 UASM_i_MFC0(&p, GPR_K0, C0_PWBASE); in kvm_mips_build_enter_guest()
253 UASM_i_MFC0(&p, GPR_K0, c0_kscratch(), pgd_reg); in kvm_mips_build_enter_guest()
254 UASM_i_SW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, host_pgd), GPR_K1); in kvm_mips_build_enter_guest()
277 uasm_i_mfc0(&p, GPR_K0, C0_GUESTCTL0); in kvm_mips_build_enter_guest()
278 uasm_i_ins(&p, GPR_K0, GPR_V1, MIPS_GCTL0_GM_SHIFT, 1); in kvm_mips_build_enter_guest()
279 uasm_i_mtc0(&p, GPR_K0, C0_GUESTCTL0); in kvm_mips_build_enter_guest()
303 UASM_i_MFC0(&p, GPR_K0, C0_ENTRYHI); in kvm_mips_build_enter_guest()
304 UASM_i_SW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, host_entryhi), in kvm_mips_build_enter_guest()
317 UASM_i_LW(&p, GPR_K0, 0, GPR_T3); in kvm_mips_build_enter_guest()
329 uasm_i_and(&p, GPR_K0, GPR_K0, GPR_T2); in kvm_mips_build_enter_guest()
331 uasm_i_andi(&p, GPR_K0, GPR_K0, MIPS_ENTRYHI_ASID); in kvm_mips_build_enter_guest()
335 uasm_i_mtc0(&p, GPR_K0, C0_ENTRYHI); in kvm_mips_build_enter_guest()
345 if (i == GPR_K0 || i == GPR_K1) in kvm_mips_build_enter_guest()
352 UASM_i_LW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, hi), GPR_K1); in kvm_mips_build_enter_guest()
353 uasm_i_mthi(&p, GPR_K0); in kvm_mips_build_enter_guest()
355 UASM_i_LW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, lo), GPR_K1); in kvm_mips_build_enter_guest()
356 uasm_i_mtlo(&p, GPR_K0); in kvm_mips_build_enter_guest()
360 UASM_i_LW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, gprs[GPR_K0]), GPR_K1); in kvm_mips_build_enter_guest()
400 UASM_i_SW(&p, GPR_K0, offsetof(struct kvm_vcpu, arch.gprs[GPR_K0]), GPR_K1); in kvm_mips_build_tlb_refill_exception()
410 uasm_i_lddir(&p, GPR_K0, GPR_K1, 3); /* global page dir */ in kvm_mips_build_tlb_refill_exception()
412 uasm_i_lddir(&p, GPR_K1, GPR_K0, 1); /* middle page dir */ in kvm_mips_build_tlb_refill_exception()
430 build_get_pmde64(&p, &l, &r, GPR_K0, GPR_K1); /* get pmd in GPR_K1 */ in kvm_mips_build_tlb_refill_exception()
432 build_get_pgde32(&p, GPR_K0, GPR_K1); /* get pgd in GPR_K1 */ in kvm_mips_build_tlb_refill_exception()
437 build_get_ptep(&p, GPR_K0, GPR_K1); in kvm_mips_build_tlb_refill_exception()
438 build_update_entries(&p, GPR_K0, GPR_K1); in kvm_mips_build_tlb_refill_exception()
448 UASM_i_LW(&p, GPR_K0, offsetof(struct kvm_vcpu, arch.gprs[GPR_K0]), GPR_K1); in kvm_mips_build_tlb_refill_exception()
487 UASM_i_SW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, gprs[GPR_K0]), GPR_K1); in kvm_mips_build_exception()
535 if (i == GPR_K0 || i == GPR_K1) in kvm_mips_build_exit()
563 UASM_i_MFC0(&p, GPR_K0, C0_EPC); in kvm_mips_build_exit()
564 UASM_i_SW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, pc), GPR_K1); in kvm_mips_build_exit()
566 UASM_i_MFC0(&p, GPR_K0, C0_BADVADDR); in kvm_mips_build_exit()
567 UASM_i_SW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, host_cp0_badvaddr), in kvm_mips_build_exit()
570 uasm_i_mfc0(&p, GPR_K0, C0_CAUSE); in kvm_mips_build_exit()
571 uasm_i_sw(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, host_cp0_cause), GPR_K1); in kvm_mips_build_exit()
574 uasm_i_mfc0(&p, GPR_K0, C0_BADINSTR); in kvm_mips_build_exit()
575 uasm_i_sw(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, in kvm_mips_build_exit()
580 uasm_i_mfc0(&p, GPR_K0, C0_BADINSTRP); in kvm_mips_build_exit()
581 uasm_i_sw(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, in kvm_mips_build_exit()
592 uasm_i_or(&p, GPR_K0, GPR_V0, GPR_AT); in kvm_mips_build_exit()
594 uasm_i_mtc0(&p, GPR_K0, C0_STATUS); in kvm_mips_build_exit()
597 UASM_i_LA_mostly(&p, GPR_K0, (long)&ebase); in kvm_mips_build_exit()
598 UASM_i_LW(&p, GPR_K0, uasm_rel_lo((long)&ebase), GPR_K0); in kvm_mips_build_exit()
599 build_set_exc_base(&p, GPR_K0); in kvm_mips_build_exit()
635 UASM_i_LW(&p, GPR_K0, offsetof(struct kvm_vcpu_arch, host_entryhi), in kvm_mips_build_exit()
637 UASM_i_MTC0(&p, GPR_K0, C0_ENTRYHI); in kvm_mips_build_exit()
657 uasm_i_mfc0(&p, GPR_K0, C0_GUESTCTL0); in kvm_mips_build_exit()
658 uasm_i_ins(&p, GPR_K0, GPR_ZERO, MIPS_GCTL0_GM_SHIFT, 1); in kvm_mips_build_exit()
659 uasm_i_mtc0(&p, GPR_K0, C0_GUESTCTL0); in kvm_mips_build_exit()
662 uasm_i_sw(&p, GPR_K0, in kvm_mips_build_exit()
703 kvm_mips_build_restore_scratch(&p, GPR_K0, GPR_SP); in kvm_mips_build_exit()
706 UASM_i_LA_mostly(&p, GPR_K0, (long)&hwrena); in kvm_mips_build_exit()
707 uasm_i_lw(&p, GPR_K0, uasm_rel_lo((long)&hwrena), GPR_K0); in kvm_mips_build_exit()
708 uasm_i_mtc0(&p, GPR_K0, C0_HWRENA); in kvm_mips_build_exit()
801 uasm_i_or(&p, GPR_K0, GPR_V1, GPR_AT); in kvm_mips_build_ret_to_guest()
802 uasm_i_mtc0(&p, GPR_K0, C0_STATUS); in kvm_mips_build_ret_to_guest()
841 uasm_i_sra(&p, GPR_K0, GPR_V0, 2); in kvm_mips_build_ret_to_host()
842 uasm_i_move(&p, GPR_V0, GPR_K0); in kvm_mips_build_ret_to_host()
852 UASM_i_LA_mostly(&p, GPR_K0, (long)&hwrena); in kvm_mips_build_ret_to_host()
853 uasm_i_lw(&p, GPR_K0, uasm_rel_lo((long)&hwrena), GPR_K0); in kvm_mips_build_ret_to_host()
854 uasm_i_mtc0(&p, GPR_K0, C0_HWRENA); in kvm_mips_build_ret_to_host()