2005-04-17 02:20:36 +04:00
/*
* Copyright ( C ) 2001 Mike Corrigan IBM Corporation
2005-06-22 04:15:33 +04:00
*
2005-04-17 02:20:36 +04:00
* 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 .
2005-06-22 04:15:33 +04:00
*
2005-04-17 02:20:36 +04:00
* 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 .
2005-06-22 04:15:33 +04:00
*
2005-04-17 02:20:36 +04:00
* 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
*/
2005-10-14 11:09:16 +04:00
# ifndef _PLATFORMS_ISERIES_CALL_HPT_H
# define _PLATFORMS_ISERIES_CALL_HPT_H
2005-04-17 02:20:36 +04:00
2005-06-22 04:15:33 +04:00
/*
* This file contains the " hypervisor call " interface which is used to
* drive the hypervisor from the OS .
*/
2005-04-17 02:20:36 +04:00
2005-11-02 03:37:22 +03:00
# include <asm/iseries/hv_call_sc.h>
2005-11-02 05:46:07 +03:00
# include <asm/iseries/hv_types.h>
2005-04-17 02:20:36 +04:00
# 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
2005-06-22 04:15:33 +04:00
static inline u64 HvCallHpt_getHptAddress ( void )
2005-04-17 02:20:36 +04:00
{
2005-06-22 04:15:35 +04:00
return HvCall0 ( HvCallHptGetHptAddress ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
static inline u64 HvCallHpt_getHptPages ( void )
{
2005-06-22 04:15:35 +04:00
return HvCall0 ( HvCallHptGetHptPages ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
static inline void HvCallHpt_setPp ( u32 hpteIndex , u8 value )
2005-04-17 02:20:36 +04:00
{
2005-06-22 04:15:33 +04:00
HvCall2 ( HvCallHptSetPp , hpteIndex , value ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
static inline void HvCallHpt_setSwBits ( u32 hpteIndex , u8 bitson , u8 bitsoff )
2005-04-17 02:20:36 +04:00
{
2005-06-22 04:15:33 +04:00
HvCall3 ( HvCallHptSetSwBits , hpteIndex , bitson , bitsoff ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
static inline void HvCallHpt_invalidateNoSyncICache ( u32 hpteIndex )
2005-04-17 02:20:36 +04:00
{
2005-06-22 04:15:33 +04:00
HvCall1 ( HvCallHptInvalidateNoSyncICache , hpteIndex ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
static inline u64 HvCallHpt_invalidateSetSwBitsGet ( u32 hpteIndex , u8 bitson ,
u8 bitsoff )
2005-04-17 02:20:36 +04:00
{
u64 compressedStatus ;
2005-06-22 04:15:33 +04:00
compressedStatus = HvCall4 ( HvCallHptInvalidateSetSwBitsGet ,
hpteIndex , bitson , bitsoff , 1 ) ;
HvCall1 ( HvCallHptInvalidateNoSyncICache , hpteIndex ) ;
2005-04-17 02:20:36 +04:00
return compressedStatus ;
}
2005-06-22 04:15:33 +04:00
2007-06-13 08:52:56 +04:00
static inline u64 HvCallHpt_findValid ( struct hash_pte * hpte , u64 vpn )
2005-04-17 02:20:36 +04:00
{
2005-06-22 04:15:35 +04:00
return HvCall3Ret16 ( HvCallHptFindValid , hpte , vpn , 0 , 0 ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
2007-06-13 08:52:56 +04:00
static inline u64 HvCallHpt_findNextValid ( struct hash_pte * hpte , u32 hpteIndex ,
2005-06-22 04:15:33 +04:00
u8 bitson , u8 bitsoff )
2005-04-17 02:20:36 +04:00
{
2005-06-22 04:15:35 +04:00
return HvCall3Ret16 ( HvCallHptFindNextValid , hpte , hpteIndex ,
bitson , bitsoff ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
2007-06-13 08:52:56 +04:00
static inline void HvCallHpt_get ( struct hash_pte * hpte , u32 hpteIndex )
2005-04-17 02:20:36 +04:00
{
2005-06-22 04:15:33 +04:00
HvCall2Ret16 ( HvCallHptGet , hpte , hpteIndex , 0 ) ;
2005-04-17 02:20:36 +04:00
}
2005-06-22 04:15:33 +04:00
2007-06-13 08:52:56 +04:00
static inline void HvCallHpt_addValidate ( u32 hpteIndex , u32 hBit ,
struct hash_pte * hpte )
2005-04-17 02:20:36 +04:00
{
2005-07-13 12:11:42 +04:00
HvCall4 ( HvCallHptAddValidate , hpteIndex , hBit , hpte - > v , hpte - > r ) ;
2005-04-17 02:20:36 +04:00
}
2005-10-14 11:09:16 +04:00
# endif /* _PLATFORMS_ISERIES_CALL_HPT_H */