18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * 48c2ecf20Sopenharmony_ci * Copyright IBM Corp. 2008 58c2ecf20Sopenharmony_ci * 68c2ecf20Sopenharmony_ci * Authors: Hollis Blanchard <hollisb@us.ibm.com> 78c2ecf20Sopenharmony_ci */ 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_ci#ifndef __POWERPC_KVM_ASM_H__ 108c2ecf20Sopenharmony_ci#define __POWERPC_KVM_ASM_H__ 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_ci#ifdef __ASSEMBLY__ 138c2ecf20Sopenharmony_ci#ifdef CONFIG_64BIT 148c2ecf20Sopenharmony_ci#define PPC_STD(sreg, offset, areg) std sreg, (offset)(areg) 158c2ecf20Sopenharmony_ci#define PPC_LD(treg, offset, areg) ld treg, (offset)(areg) 168c2ecf20Sopenharmony_ci#else 178c2ecf20Sopenharmony_ci#define PPC_STD(sreg, offset, areg) stw sreg, (offset+4)(areg) 188c2ecf20Sopenharmony_ci#define PPC_LD(treg, offset, areg) lwz treg, (offset+4)(areg) 198c2ecf20Sopenharmony_ci#endif 208c2ecf20Sopenharmony_ci#endif 218c2ecf20Sopenharmony_ci 228c2ecf20Sopenharmony_ci/* IVPR must be 64KiB-aligned. */ 238c2ecf20Sopenharmony_ci#define VCPU_SIZE_ORDER 4 248c2ecf20Sopenharmony_ci#define VCPU_SIZE_LOG (VCPU_SIZE_ORDER + 12) 258c2ecf20Sopenharmony_ci#define VCPU_SIZE_BYTES (1<<VCPU_SIZE_LOG) 268c2ecf20Sopenharmony_ci 278c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_CRITICAL 0 288c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_MACHINE_CHECK 1 298c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_DATA_STORAGE 2 308c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_INST_STORAGE 3 318c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_EXTERNAL 4 328c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_ALIGNMENT 5 338c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_PROGRAM 6 348c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_FP_UNAVAIL 7 358c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_SYSCALL 8 368c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_AP_UNAVAIL 9 378c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_DECREMENTER 10 388c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_FIT 11 398c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_WATCHDOG 12 408c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_DTLB_MISS 13 418c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_ITLB_MISS 14 428c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_DEBUG 15 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci/* E500 */ 458c2ecf20Sopenharmony_ci#ifdef CONFIG_SPE_POSSIBLE 468c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_SPE_UNAVAIL 32 478c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_SPE_FP_DATA 33 488c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_SPE_FP_ROUND 34 498c2ecf20Sopenharmony_ci#endif 508c2ecf20Sopenharmony_ci 518c2ecf20Sopenharmony_ci#ifdef CONFIG_PPC_E500MC 528c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_ALTIVEC_UNAVAIL 32 538c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_ALTIVEC_ASSIST 33 548c2ecf20Sopenharmony_ci#endif 558c2ecf20Sopenharmony_ci 568c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_PERFORMANCE_MONITOR 35 578c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_DOORBELL 36 588c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_DOORBELL_CRITICAL 37 598c2ecf20Sopenharmony_ci 608c2ecf20Sopenharmony_ci/* booke_hv */ 618c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_GUEST_DBELL 38 628c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_GUEST_DBELL_CRIT 39 638c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_HV_SYSCALL 40 648c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_HV_PRIV 41 658c2ecf20Sopenharmony_ci#define BOOKE_INTERRUPT_LRAT_ERROR 42 668c2ecf20Sopenharmony_ci 678c2ecf20Sopenharmony_ci/* book3s */ 688c2ecf20Sopenharmony_ci 698c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_SYSTEM_RESET 0x100 708c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_MACHINE_CHECK 0x200 718c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_DATA_STORAGE 0x300 728c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_DATA_SEGMENT 0x380 738c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_INST_STORAGE 0x400 748c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_INST_SEGMENT 0x480 758c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_EXTERNAL 0x500 768c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_EXTERNAL_HV 0x502 778c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_ALIGNMENT 0x600 788c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_PROGRAM 0x700 798c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_FP_UNAVAIL 0x800 808c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_DECREMENTER 0x900 818c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_HV_DECREMENTER 0x980 828c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_DOORBELL 0xa00 838c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_SYSCALL 0xc00 848c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_TRACE 0xd00 858c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_H_DATA_STORAGE 0xe00 868c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_H_INST_STORAGE 0xe20 878c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_H_EMUL_ASSIST 0xe40 888c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_HMI 0xe60 898c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_H_DOORBELL 0xe80 908c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_H_VIRT 0xea0 918c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_PERFMON 0xf00 928c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_ALTIVEC 0xf20 938c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_VSX 0xf40 948c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_FAC_UNAVAIL 0xf60 958c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_H_FAC_UNAVAIL 0xf80 968c2ecf20Sopenharmony_ci 978c2ecf20Sopenharmony_ci/* book3s_hv */ 988c2ecf20Sopenharmony_ci 998c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_HV_SOFTPATCH 0x1500 1008c2ecf20Sopenharmony_ci 1018c2ecf20Sopenharmony_ci/* 1028c2ecf20Sopenharmony_ci * Special trap used to indicate to host that this is a 1038c2ecf20Sopenharmony_ci * passthrough interrupt that could not be handled 1048c2ecf20Sopenharmony_ci * completely in the guest. 1058c2ecf20Sopenharmony_ci */ 1068c2ecf20Sopenharmony_ci#define BOOK3S_INTERRUPT_HV_RM_HARD 0x5555 1078c2ecf20Sopenharmony_ci 1088c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_SYSTEM_RESET 0 1098c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_DATA_SEGMENT 1 1108c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_INST_SEGMENT 2 1118c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_DATA_STORAGE 3 1128c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_INST_STORAGE 4 1138c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_ALIGNMENT 5 1148c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_PROGRAM 6 1158c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_FP_UNAVAIL 7 1168c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_ALTIVEC 8 1178c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_VSX 9 1188c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_FAC_UNAVAIL 10 1198c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_SYSCALL 11 1208c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_MACHINE_CHECK 12 1218c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_DEBUG 13 1228c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_EXTERNAL 14 1238c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_DECREMENTER 15 1248c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_PERFORMANCE_MONITOR 16 1258c2ecf20Sopenharmony_ci#define BOOK3S_IRQPRIO_MAX 17 1268c2ecf20Sopenharmony_ci 1278c2ecf20Sopenharmony_ci#define BOOK3S_HFLAG_DCBZ32 0x1 1288c2ecf20Sopenharmony_ci#define BOOK3S_HFLAG_SLB 0x2 1298c2ecf20Sopenharmony_ci#define BOOK3S_HFLAG_PAIRED_SINGLE 0x4 1308c2ecf20Sopenharmony_ci#define BOOK3S_HFLAG_NATIVE_PS 0x8 1318c2ecf20Sopenharmony_ci#define BOOK3S_HFLAG_MULTI_PGSIZE 0x10 1328c2ecf20Sopenharmony_ci#define BOOK3S_HFLAG_NEW_TLBIE 0x20 1338c2ecf20Sopenharmony_ci#define BOOK3S_HFLAG_SPLIT_HACK 0x40 1348c2ecf20Sopenharmony_ci 1358c2ecf20Sopenharmony_ci#define RESUME_FLAG_NV (1<<0) /* Reload guest nonvolatile state? */ 1368c2ecf20Sopenharmony_ci#define RESUME_FLAG_HOST (1<<1) /* Resume host? */ 1378c2ecf20Sopenharmony_ci#define RESUME_FLAG_ARCH1 (1<<2) 1388c2ecf20Sopenharmony_ci#define RESUME_FLAG_ARCH2 (1<<3) 1398c2ecf20Sopenharmony_ci 1408c2ecf20Sopenharmony_ci#define RESUME_GUEST 0 1418c2ecf20Sopenharmony_ci#define RESUME_GUEST_NV RESUME_FLAG_NV 1428c2ecf20Sopenharmony_ci#define RESUME_HOST RESUME_FLAG_HOST 1438c2ecf20Sopenharmony_ci#define RESUME_HOST_NV (RESUME_FLAG_HOST|RESUME_FLAG_NV) 1448c2ecf20Sopenharmony_ci 1458c2ecf20Sopenharmony_ci#define KVM_GUEST_MODE_NONE 0 1468c2ecf20Sopenharmony_ci#define KVM_GUEST_MODE_GUEST 1 1478c2ecf20Sopenharmony_ci#define KVM_GUEST_MODE_SKIP 2 1488c2ecf20Sopenharmony_ci#define KVM_GUEST_MODE_GUEST_HV 3 1498c2ecf20Sopenharmony_ci#define KVM_GUEST_MODE_HOST_HV 4 1508c2ecf20Sopenharmony_ci 1518c2ecf20Sopenharmony_ci#define KVM_INST_FETCH_FAILED -1 1528c2ecf20Sopenharmony_ci 1538c2ecf20Sopenharmony_ci/* Extract PO and XOP opcode fields */ 1548c2ecf20Sopenharmony_ci#define PO_XOP_OPCODE_MASK 0xfc0007fe 1558c2ecf20Sopenharmony_ci 1568c2ecf20Sopenharmony_ci#endif /* __POWERPC_KVM_ASM_H__ */ 157