/* * HvCallHpt.h * Copyright (C) 2001 Mike Corrigan IBM Corporation * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _HVCALLHPT_H #define _HVCALLHPT_H //============================================================================ // // This file contains the "hypervisor call" interface which is used to // drive the hypervisor from the OS. // //============================================================================ #include #include #include //----------------------------------------------------------------------------- // Constants //----------------------------------------------------------------------------- #define HvCallHptGetHptAddress HvCallHpt + 0 #define HvCallHptGetHptPages HvCallHpt + 1 #define HvCallHptSetPp HvCallHpt + 5 #define HvCallHptSetSwBits HvCallHpt + 6 #define HvCallHptUpdate HvCallHpt + 7 #define HvCallHptInvalidateNoSyncICache HvCallHpt + 8 #define HvCallHptGet HvCallHpt + 11 #define HvCallHptFindNextValid HvCallHpt + 12 #define HvCallHptFindValid HvCallHpt + 13 #define HvCallHptAddValidate HvCallHpt + 16 #define HvCallHptInvalidateSetSwBitsGet HvCallHpt + 18 //============================================================================ static inline u64 HvCallHpt_getHptAddress(void) { u64 retval = HvCall0(HvCallHptGetHptAddress); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retval; } //============================================================================ static inline u64 HvCallHpt_getHptPages(void) { u64 retval = HvCall0(HvCallHptGetHptPages); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retval; } //============================================================================= static inline void HvCallHpt_setPp(u32 hpteIndex, u8 value) { HvCall2( HvCallHptSetPp, hpteIndex, value ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); } //============================================================================= static inline void HvCallHpt_setSwBits(u32 hpteIndex, u8 bitson, u8 bitsoff ) { HvCall3( HvCallHptSetSwBits, hpteIndex, bitson, bitsoff ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); } //============================================================================= static inline void HvCallHpt_invalidateNoSyncICache(u32 hpteIndex) { HvCall1( HvCallHptInvalidateNoSyncICache, hpteIndex ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); } //============================================================================= static inline u64 HvCallHpt_invalidateSetSwBitsGet(u32 hpteIndex, u8 bitson, u8 bitsoff ) { u64 compressedStatus; compressedStatus = HvCall4( HvCallHptInvalidateSetSwBitsGet, hpteIndex, bitson, bitsoff, 1 ); HvCall1( HvCallHptInvalidateNoSyncICache, hpteIndex ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return compressedStatus; } //============================================================================= static inline u64 HvCallHpt_findValid( HPTE *hpte, u64 vpn ) { u64 retIndex = HvCall3Ret16( HvCallHptFindValid, hpte, vpn, 0, 0 ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retIndex; } //============================================================================= static inline u64 HvCallHpt_findNextValid( HPTE *hpte, u32 hpteIndex, u8 bitson, u8 bitsoff ) { u64 retIndex = HvCall3Ret16( HvCallHptFindNextValid, hpte, hpteIndex, bitson, bitsoff ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retIndex; } //============================================================================= static inline void HvCallHpt_get( HPTE *hpte, u32 hpteIndex ) { HvCall2Ret16( HvCallHptGet, hpte, hpteIndex, 0 ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); } //============================================================================ static inline void HvCallHpt_addValidate( u32 hpteIndex, u32 hBit, HPTE *hpte ) { HvCall4( HvCallHptAddValidate, hpteIndex, hBit, (*((u64 *)hpte)), (*(((u64 *)hpte)+1)) ); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); } //============================================================================= #endif /* _HVCALLHPT_H */