| /* |
| * 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 <asm/iSeries/HvCallSc.h> |
| #include <asm/iSeries/HvTypes.h> |
| #include <asm/mmu.h> |
| |
| #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 */ |