- Timestamp:
- Mar 29, 2017 6:23:28 AM (8 years ago)
- Location:
- trunk
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/include/VBox/vmm/hm.h
r66301 r66318 154 154 VMM_INT_DECL(VBOXSTRICTRC) HMSvmVmmcall(PVMCPU pVCpu, PCPUMCTX pCtx, bool *pfRipUpdated); 155 155 VMM_INT_DECL(VBOXSTRICTRC) HMSvmVmrun(PVMCPU pVCpu, PCPUMCTX pCtx, RTGCPHYS GCPhysVmcb); 156 VMM_INT_DECL(int) HMSvmNstGstGetInterrupt(P VMCPU pVCpu, PCCPUMCTX pCtx, uint8_t *pu8Interrupt);157 VMM_INT_DECL(bool) HMSvmNstGstIsInterruptPending(P VMCPU pVCpu, PCCPUMCTX pCtx);156 VMM_INT_DECL(int) HMSvmNstGstGetInterrupt(PCCPUMCTX pCtx, uint8_t *pu8Interrupt); 157 VMM_INT_DECL(bool) HMSvmNstGstIsInterruptPending(PCCPUMCTX pCtx); 158 158 159 159 #ifndef IN_RC -
trunk/src/VBox/VMM/VMMAll/HMSVMAll.cpp
r66301 r66318 21 21 *********************************************************************************************************************************/ 22 22 #define LOG_GROUP LOG_GROUP_HM 23 #define VMCPU_INCL_CPUM_GST_CTX 23 24 #include "HMInternal.h" 24 25 #include <VBox/vmm/apic.h> … … 699 700 700 701 701 VMM_INT_DECL(bool) HMSvmNstGstIsInterruptPending(PVMCPU pVCpu, PCCPUMCTX pCtx) 702 /** 703 * Checks whether an interrupt is pending for the nested-guest. 704 * 705 * @returns VBox status code. 706 * @retval true if there's a pending interrupt, false otherwise. 707 * 708 * @param pCtx The guest-CPU context. 709 */ 710 VMM_INT_DECL(bool) HMSvmNstGstIsInterruptPending(PCCPUMCTX pCtx) 702 711 { 703 RT_NOREF1(pVCpu);704 712 PCSVMVMCBCTRL pVmcbCtrl = &pCtx->hwvirt.svm.VmcbCtrl; 705 706 if ( !CPUMIsGuestInNestedHwVirtMode(pCtx) 707 || !pCtx->hwvirt.svm.fGif) 713 if (!CPUMIsGuestInNestedHwVirtMode(pCtx)) 708 714 return false; 709 715 … … 721 727 722 728 723 VMM_INT_DECL(int) HMSvmNstGstGetInterrupt(PVMCPU pVCpu, PCCPUMCTX pCtx, uint8_t *pu8Interrupt) 729 /** 730 * Gets the pending nested-guest interrupt. 731 * 732 * @returns VBox status code. 733 * @retval VINF_SUCCESS on success. 734 * @retval VERR_APIC_INTR_MASKED_BY_TPR when an APIC interrupt is pending but 735 * can't be delivered due to TPR priority. 736 * @retval VERR_NO_DATA if there is no interrupt to be delivered (either APIC 737 * has been software-disabled since it flagged something was pending, 738 * or other reasons). 739 * 740 * @param pCtx The guest-CPU context. 741 * @param pu8Interrupt Where to store the interrupt. 742 */ 743 VMM_INT_DECL(int) HMSvmNstGstGetInterrupt(PCCPUMCTX pCtx, uint8_t *pu8Interrupt) 724 744 { 725 RT_NOREF1(pVCpu);726 745 PCSVMVMCBCTRL pVmcbCtrl = &pCtx->hwvirt.svm.VmcbCtrl; 727 728 746 /** @todo remove later, paranoia for now. */ 729 747 #ifdef DEBUG_ramshankar 730 Assert(HMSvmNstGstIsInterruptPending );748 Assert(HMSvmNstGstIsInterruptPending(pCtx)); 731 749 #endif 732 750
Note:
See TracChangeset
for help on using the changeset viewer.