/* $Id: HWACCMAll.cpp 9115 2008-05-26 11:18:34Z vboxsync $ */ /** @file * HWACCM - All contexts. */ /* * Copyright (C) 2006-2007 Sun Microsystems, Inc. * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 USA or visit http://www.sun.com if you need * additional information or have any questions. */ /******************************************************************************* * Header Files * *******************************************************************************/ #define LOG_GROUP LOG_GROUP_HWACCM #include #include "HWACCMInternal.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /** * Invalidates a guest page * * @returns VBox status code. * @param pVM The VM to operate on. * @param GCVirt Page to invalidate */ HWACCMDECL(int) HWACCMInvalidatePage(PVM pVM, RTGCPTR GCVirt) { /* @todo Intel for nested paging */ #ifdef IN_RING0 if (pVM->hwaccm.s.svm.fSupported) return SVMR0InvalidatePage(pVM, GCVirt); #endif return VINF_SUCCESS; } /** * Flushes the guest TLB * * @returns VBox status code. * @param pVM The VM to operate on. */ HWACCMDECL(int) HWACCMFlushTLB(PVM pVM) { /* @todo Intel for nested paging */ if (pVM->hwaccm.s.svm.fSupported) { pVM->hwaccm.s.svm.fForceTLBFlush = true; STAM_COUNTER_INC(&pVM->hwaccm.s.StatFlushTLBManual); } return VINF_SUCCESS; } /** * Checks if nested paging is enabled * * @returns boolean * @param pVM The VM to operate on. */ HWACCMDECL(bool) HWACCMIsNestedPagingActive(PVM pVM) { return HWACCMIsEnabled(pVM) && pVM->hwaccm.s.fNestedPaging; } /** * Invalidates a guest page by physical address * * NOTE: Assumes the current instruction references this physical page though a virtual address!! * * @returns VBox status code. * @param pVM The VM to operate on. * @param GCPhys Page to invalidate */ HWACCMDECL(int) HWACCMInvalidatePhysPage(PVM pVM, RTGCPHYS GCPhys) { if (!HWACCMIsNestedPagingActive(pVM)) return VINF_SUCCESS; #ifdef IN_RING0 /* @todo Intel for nested paging */ if (pVM->hwaccm.s.svm.fSupported) { SVMR0InvalidatePhysPage(pVM, GCPhys); } #else HWACCMFlushTLB(pVM); #endif return VINF_SUCCESS; }