/* * HvCallCfg.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 */ //===================================================================================== // // This file contains the "hypervisor call" interface which is used to // drive the hypervisor from the OS. // //===================================================================================== #ifndef _HVCALLCFG_H #define _HVCALLCFG_H //------------------------------------------------------------------- // Standard Includes //------------------------------------------------------------------- #include <asm/iSeries/HvCallSc.h> #include <asm/iSeries/HvTypes.h> //------------------------------------------------------------------------------------- // Constants //------------------------------------------------------------------------------------- enum HvCallCfg_ReqQual { HvCallCfg_Cur = 0, HvCallCfg_Init = 1, HvCallCfg_Max = 2, HvCallCfg_Min = 3 }; #define HvCallCfgGetLps HvCallCfg + 0 #define HvCallCfgGetActiveLpMap HvCallCfg + 1 #define HvCallCfgGetLpVrmIndex HvCallCfg + 2 #define HvCallCfgGetLpMinSupportedPlicVrmIndex HvCallCfg + 3 #define HvCallCfgGetLpMinCompatablePlicVrmIndex HvCallCfg + 4 #define HvCallCfgGetLpVrmName HvCallCfg + 5 #define HvCallCfgGetSystemPhysicalProcessors HvCallCfg + 6 #define HvCallCfgGetPhysicalProcessors HvCallCfg + 7 #define HvCallCfgGetSystemMsChunks HvCallCfg + 8 #define HvCallCfgGetMsChunks HvCallCfg + 9 #define HvCallCfgGetInteractivePercentage HvCallCfg + 10 #define HvCallCfgIsBusDedicated HvCallCfg + 11 #define HvCallCfgGetBusOwner HvCallCfg + 12 #define HvCallCfgGetBusAllocation HvCallCfg + 13 #define HvCallCfgGetBusUnitOwner HvCallCfg + 14 #define HvCallCfgGetBusUnitAllocation HvCallCfg + 15 #define HvCallCfgGetVirtualBusPool HvCallCfg + 16 #define HvCallCfgGetBusUnitInterruptProc HvCallCfg + 17 #define HvCallCfgGetConfiguredBusUnitsForIntProc HvCallCfg + 18 #define HvCallCfgGetRioSanBusPool HvCallCfg + 19 #define HvCallCfgGetSharedPoolIndex HvCallCfg + 20 #define HvCallCfgGetSharedProcUnits HvCallCfg + 21 #define HvCallCfgGetNumProcsInSharedPool HvCallCfg + 22 #define HvCallCfgRouter23 HvCallCfg + 23 #define HvCallCfgRouter24 HvCallCfg + 24 #define HvCallCfgRouter25 HvCallCfg + 25 #define HvCallCfgRouter26 HvCallCfg + 26 #define HvCallCfgRouter27 HvCallCfg + 27 #define HvCallCfgGetMinRuntimeMsChunks HvCallCfg + 28 #define HvCallCfgSetMinRuntimeMsChunks HvCallCfg + 29 #define HvCallCfgGetVirtualLanIndexMap HvCallCfg + 30 #define HvCallCfgGetLpExecutionMode HvCallCfg + 31 #define HvCallCfgGetHostingLpIndex HvCallCfg + 32 //==================================================================== static inline HvLpIndex HvCallCfg_getLps(void) { HvLpIndex retVal = HvCall0(HvCallCfgGetLps); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //==================================================================== static inline int HvCallCfg_isBusDedicated(u64 busIndex) { int retVal = HvCall1(HvCallCfgIsBusDedicated,busIndex); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //==================================================================== static inline HvLpIndex HvCallCfg_getBusOwner(u64 busIndex) { HvLpIndex retVal = HvCall1(HvCallCfgGetBusOwner,busIndex); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //==================================================================== static inline HvLpIndexMap HvCallCfg_getBusAllocation(u64 busIndex) { HvLpIndexMap retVal = HvCall1(HvCallCfgGetBusAllocation,busIndex); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //==================================================================== static inline HvLpIndexMap HvCallCfg_getActiveLpMap(void) { HvLpIndexMap retVal = HvCall0(HvCallCfgGetActiveLpMap); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //==================================================================== static inline HvLpVirtualLanIndexMap HvCallCfg_getVirtualLanIndexMap(HvLpIndex lp) { // This is a new function in V5R1 so calls to this on older // hypervisors will return -1 u64 retVal = HvCall1(HvCallCfgGetVirtualLanIndexMap, lp); if(retVal == -1) retVal = 0; // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //=================================================================== static inline u64 HvCallCfg_getSystemMsChunks(void) { u64 retVal = HvCall0(HvCallCfgGetSystemMsChunks); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //=================================================================== static inline u64 HvCallCfg_getMsChunks(HvLpIndex lp,enum HvCallCfg_ReqQual qual) { u64 retVal = HvCall2(HvCallCfgGetMsChunks,lp,qual); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //=================================================================== static inline u64 HvCallCfg_getMinRuntimeMsChunks(HvLpIndex lp) { // NOTE: This function was added in v5r1 so older hypervisors will return a -1 value u64 retVal = HvCall1(HvCallCfgGetMinRuntimeMsChunks,lp); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //=================================================================== static inline u64 HvCallCfg_setMinRuntimeMsChunks(u64 chunks) { u64 retVal = HvCall1(HvCallCfgSetMinRuntimeMsChunks,chunks); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //=================================================================== static inline u64 HvCallCfg_getSystemPhysicalProcessors(void) { u64 retVal = HvCall0(HvCallCfgGetSystemPhysicalProcessors); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //=================================================================== static inline u64 HvCallCfg_getPhysicalProcessors(HvLpIndex lp,enum HvCallCfg_ReqQual qual) { u64 retVal = HvCall2(HvCallCfgGetPhysicalProcessors,lp,qual); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //=================================================================== static inline u64 HvCallCfg_getConfiguredBusUnitsForInterruptProc(HvLpIndex lp, u16 hvLogicalProcIndex) { u64 retVal = HvCall2(HvCallCfgGetConfiguredBusUnitsForIntProc,lp,hvLogicalProcIndex); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //================================================================== static inline HvLpSharedPoolIndex HvCallCfg_getSharedPoolIndex(HvLpIndex lp) { HvLpSharedPoolIndex retVal = HvCall1(HvCallCfgGetSharedPoolIndex,lp); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //================================================================== static inline u64 HvCallCfg_getSharedProcUnits(HvLpIndex lp,enum HvCallCfg_ReqQual qual) { u64 retVal = HvCall2(HvCallCfgGetSharedProcUnits,lp,qual); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //================================================================== static inline u64 HvCallCfg_getNumProcsInSharedPool(HvLpSharedPoolIndex sPI) { u16 retVal = HvCall1(HvCallCfgGetNumProcsInSharedPool,sPI); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } //================================================================== static inline HvLpIndex HvCallCfg_getHostingLpIndex(HvLpIndex lp) { u64 retVal = HvCall1(HvCallCfgGetHostingLpIndex,lp); // getPaca()->adjustHmtForNoOfSpinLocksHeld(); return retVal; } #endif /* _HVCALLCFG_H */