kvm_vcpu_insn.h 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2022 Ventana Micro Systems Inc.
  4. */
  5. #ifndef __KVM_VCPU_RISCV_INSN_H
  6. #define __KVM_VCPU_RISCV_INSN_H
  7. struct kvm_vcpu;
  8. struct kvm_run;
  9. struct kvm_cpu_trap;
  10. struct kvm_mmio_decode {
  11. unsigned long insn;
  12. int insn_len;
  13. int len;
  14. int shift;
  15. int return_handled;
  16. };
  17. struct kvm_csr_decode {
  18. unsigned long insn;
  19. int return_handled;
  20. };
  21. /* Return values used by function emulating a particular instruction */
  22. enum kvm_insn_return {
  23. KVM_INSN_EXIT_TO_USER_SPACE = 0,
  24. KVM_INSN_CONTINUE_NEXT_SEPC,
  25. KVM_INSN_CONTINUE_SAME_SEPC,
  26. KVM_INSN_ILLEGAL_TRAP,
  27. KVM_INSN_VIRTUAL_TRAP
  28. };
  29. void kvm_riscv_vcpu_wfi(struct kvm_vcpu *vcpu);
  30. int kvm_riscv_vcpu_csr_return(struct kvm_vcpu *vcpu, struct kvm_run *run);
  31. int kvm_riscv_vcpu_virtual_insn(struct kvm_vcpu *vcpu, struct kvm_run *run,
  32. struct kvm_cpu_trap *trap);
  33. int kvm_riscv_vcpu_mmio_load(struct kvm_vcpu *vcpu, struct kvm_run *run,
  34. unsigned long fault_addr,
  35. unsigned long htinst);
  36. int kvm_riscv_vcpu_mmio_store(struct kvm_vcpu *vcpu, struct kvm_run *run,
  37. unsigned long fault_addr,
  38. unsigned long htinst);
  39. int kvm_riscv_vcpu_mmio_return(struct kvm_vcpu *vcpu, struct kvm_run *run);
  40. #endif