[PATCH] ppc64 iSeries: header file white space cleanups
This patch just contains white space and comment cleanups in the iSeries headers files. There are no semantic changes. Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
0e3e4a1c4d
commit
45dc76aaf6
@ -1,34 +1,28 @@
|
|||||||
/*
|
/*
|
||||||
* HvCall.h
|
* HvCall.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* 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.
|
||||||
// This file contains the "hypervisor call" interface which is used to
|
*/
|
||||||
// drive the hypervisor from the OS.
|
|
||||||
//
|
|
||||||
//===========================================================================
|
|
||||||
#ifndef _HVCALL_H
|
#ifndef _HVCALL_H
|
||||||
#define _HVCALL_H
|
#define _HVCALL_H
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
// Standard Includes
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
#include <asm/iSeries/HvCallSc.h>
|
#include <asm/iSeries/HvCallSc.h>
|
||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
#include <asm/paca.h>
|
#include <asm/paca.h>
|
||||||
@ -76,9 +70,9 @@ enum HvCall_VaryOffChunkRc
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* Type of yield for HvCallBaseYieldProcessor */
|
/* Type of yield for HvCallBaseYieldProcessor */
|
||||||
#define HvCall_YieldTimed 0 // Yield until specified time (tb)
|
#define HvCall_YieldTimed 0 /* Yield until specified time (tb) */
|
||||||
#define HvCall_YieldToActive 1 // Yield until all active procs have run
|
#define HvCall_YieldToActive 1 /* Yield until all active procs have run */
|
||||||
#define HvCall_YieldToProc 2 // Yield until the specified processor has run
|
#define HvCall_YieldToProc 2 /* Yield until the specified processor has run */
|
||||||
|
|
||||||
/* interrupt masks for setEnabledInterrupts */
|
/* interrupt masks for setEnabledInterrupts */
|
||||||
#define HvCall_MaskIPI 0x00000001
|
#define HvCall_MaskIPI 0x00000001
|
||||||
@ -86,7 +80,7 @@ enum HvCall_VaryOffChunkRc
|
|||||||
#define HvCall_MaskLpProd 0x00000004
|
#define HvCall_MaskLpProd 0x00000004
|
||||||
#define HvCall_MaskTimeout 0x00000008
|
#define HvCall_MaskTimeout 0x00000008
|
||||||
|
|
||||||
/* Log buffer formats */
|
/* Log buffer formats */
|
||||||
#define HvCall_LogBuffer_ASCII 0
|
#define HvCall_LogBuffer_ASCII 0
|
||||||
#define HvCall_LogBuffer_EBCDIC 1
|
#define HvCall_LogBuffer_EBCDIC 1
|
||||||
|
|
||||||
@ -95,7 +89,7 @@ enum HvCall_VaryOffChunkRc
|
|||||||
#define HvCallBaseGetHwPatch HvCallBase + 2
|
#define HvCallBaseGetHwPatch HvCallBase + 2
|
||||||
#define HvCallBaseReIplSpAttn HvCallBase + 3
|
#define HvCallBaseReIplSpAttn HvCallBase + 3
|
||||||
#define HvCallBaseSetASR HvCallBase + 4
|
#define HvCallBaseSetASR HvCallBase + 4
|
||||||
#define HvCallBaseSetASRAndRfi HvCallBase + 5
|
#define HvCallBaseSetASRAndRfi HvCallBase + 5
|
||||||
#define HvCallBaseSetIMR HvCallBase + 6
|
#define HvCallBaseSetIMR HvCallBase + 6
|
||||||
#define HvCallBaseSendIPI HvCallBase + 7
|
#define HvCallBaseSendIPI HvCallBase + 7
|
||||||
#define HvCallBaseTerminateMachine HvCallBase + 8
|
#define HvCallBaseTerminateMachine HvCallBase + 8
|
||||||
@ -115,81 +109,75 @@ enum HvCall_VaryOffChunkRc
|
|||||||
#define HvCallBaseGetLogBufferCodePage HvCallBase + 22
|
#define HvCallBaseGetLogBufferCodePage HvCallBase + 22
|
||||||
#define HvCallBaseGetLogBufferFormat HvCallBase + 23
|
#define HvCallBaseGetLogBufferFormat HvCallBase + 23
|
||||||
#define HvCallBaseGetLogBufferLength HvCallBase + 24
|
#define HvCallBaseGetLogBufferLength HvCallBase + 24
|
||||||
#define HvCallBaseReadLogBuffer HvCallBase + 25
|
#define HvCallBaseReadLogBuffer HvCallBase + 25
|
||||||
#define HvCallBaseSetLogBufferFormatAndCodePage HvCallBase + 26
|
#define HvCallBaseSetLogBufferFormatAndCodePage HvCallBase + 26
|
||||||
#define HvCallBaseWriteLogBuffer HvCallBase + 27
|
#define HvCallBaseWriteLogBuffer HvCallBase + 27
|
||||||
#define HvCallBaseRouter28 HvCallBase + 28
|
#define HvCallBaseRouter28 HvCallBase + 28
|
||||||
#define HvCallBaseRouter29 HvCallBase + 29
|
#define HvCallBaseRouter29 HvCallBase + 29
|
||||||
#define HvCallBaseRouter30 HvCallBase + 30
|
#define HvCallBaseRouter30 HvCallBase + 30
|
||||||
#define HvCallBaseSetDebugBus HvCallBase + 31
|
#define HvCallBaseSetDebugBus HvCallBase + 31
|
||||||
|
|
||||||
#define HvCallCcSetDABR HvCallCc + 7
|
#define HvCallCcSetDABR HvCallCc + 7
|
||||||
|
|
||||||
//=====================================================================================
|
static inline void HvCall_setVirtualDecr(void)
|
||||||
static inline void HvCall_setVirtualDecr(void)
|
|
||||||
{
|
{
|
||||||
/* Ignore any error return codes - most likely means that the target value for the
|
/*
|
||||||
* LP has been increased and this vary off would bring us below the new target. */
|
* Ignore any error return codes - most likely means that the
|
||||||
|
* target value for the LP has been increased and this vary off
|
||||||
|
* would bring us below the new target.
|
||||||
|
*/
|
||||||
HvCall0(HvCallBaseSetVirtualDecr);
|
HvCall0(HvCallBaseSetVirtualDecr);
|
||||||
}
|
}
|
||||||
//=====================================================================
|
|
||||||
static inline void HvCall_yieldProcessor(unsigned typeOfYield, u64 yieldParm)
|
static inline void HvCall_yieldProcessor(unsigned typeOfYield, u64 yieldParm)
|
||||||
{
|
{
|
||||||
HvCall2( HvCallBaseYieldProcessor, typeOfYield, yieldParm );
|
HvCall2(HvCallBaseYieldProcessor, typeOfYield, yieldParm);
|
||||||
}
|
|
||||||
//=====================================================================
|
|
||||||
static inline void HvCall_setEnabledInterrupts(u64 enabledInterrupts)
|
|
||||||
{
|
|
||||||
HvCall1(HvCallBaseSetEnabledInterrupts,enabledInterrupts);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================================
|
static inline void HvCall_setEnabledInterrupts(u64 enabledInterrupts)
|
||||||
static inline void HvCall_clearLogBuffer(HvLpIndex lpindex)
|
|
||||||
{
|
{
|
||||||
HvCall1(HvCallBaseClearLogBuffer,lpindex);
|
HvCall1(HvCallBaseSetEnabledInterrupts, enabledInterrupts);
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================================
|
static inline void HvCall_clearLogBuffer(HvLpIndex lpindex)
|
||||||
static inline u32 HvCall_getLogBufferCodePage(HvLpIndex lpindex)
|
|
||||||
{
|
{
|
||||||
u32 retVal = HvCall1(HvCallBaseGetLogBufferCodePage,lpindex);
|
HvCall1(HvCallBaseClearLogBuffer, lpindex);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline u32 HvCall_getLogBufferCodePage(HvLpIndex lpindex)
|
||||||
|
{
|
||||||
|
u32 retVal = HvCall1(HvCallBaseGetLogBufferCodePage, lpindex);
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================================
|
static inline int HvCall_getLogBufferFormat(HvLpIndex lpindex)
|
||||||
static inline int HvCall_getLogBufferFormat(HvLpIndex lpindex)
|
|
||||||
{
|
{
|
||||||
int retVal = HvCall1(HvCallBaseGetLogBufferFormat,lpindex);
|
int retVal = HvCall1(HvCallBaseGetLogBufferFormat, lpindex);
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================================
|
static inline u32 HvCall_getLogBufferLength(HvLpIndex lpindex)
|
||||||
static inline u32 HvCall_getLogBufferLength(HvLpIndex lpindex)
|
|
||||||
{
|
{
|
||||||
u32 retVal = HvCall1(HvCallBaseGetLogBufferLength,lpindex);
|
u32 retVal = HvCall1(HvCallBaseGetLogBufferLength, lpindex);
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================================
|
static inline void HvCall_setLogBufferFormatAndCodepage(int format, u32 codePage)
|
||||||
static inline void HvCall_setLogBufferFormatAndCodepage(int format, u32 codePage)
|
|
||||||
{
|
{
|
||||||
HvCall2(HvCallBaseSetLogBufferFormatAndCodePage,format, codePage);
|
HvCall2(HvCallBaseSetLogBufferFormatAndCodePage, format, codePage);
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================================
|
extern int HvCall_readLogBuffer(HvLpIndex lpindex, void *buffer, u64 bufLen);
|
||||||
int HvCall_readLogBuffer(HvLpIndex lpindex, void *buffer, u64 bufLen);
|
extern void HvCall_writeLogBuffer(const void *buffer, u64 bufLen);
|
||||||
void HvCall_writeLogBuffer(const void *buffer, u64 bufLen);
|
|
||||||
|
|
||||||
//=====================================================================
|
static inline void HvCall_sendIPI(struct paca_struct *targetPaca)
|
||||||
static inline void HvCall_sendIPI(struct paca_struct * targetPaca)
|
|
||||||
{
|
{
|
||||||
HvCall1( HvCallBaseSendIPI, targetPaca->paca_index );
|
HvCall1(HvCallBaseSendIPI, targetPaca->paca_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================================
|
static inline void HvCall_terminateMachineSrc(void)
|
||||||
static inline void HvCall_terminateMachineSrc(void)
|
|
||||||
{
|
{
|
||||||
HvCall0( HvCallBaseTerminateMachineSrc );
|
HvCall0(HvCallBaseTerminateMachineSrc);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void HvCall_setDABR(unsigned long val)
|
static inline void HvCall_setDABR(unsigned long val)
|
||||||
|
@ -1,43 +1,32 @@
|
|||||||
/*
|
/*
|
||||||
* HvCallCfg.h
|
* HvCallCfg.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* 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.
|
||||||
// This file contains the "hypervisor call" interface which is used to
|
*/
|
||||||
// drive the hypervisor from the OS.
|
|
||||||
//
|
|
||||||
//=====================================================================================
|
|
||||||
#ifndef _HVCALLCFG_H
|
#ifndef _HVCALLCFG_H
|
||||||
#define _HVCALLCFG_H
|
#define _HVCALLCFG_H
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
// Standard Includes
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
#include <asm/iSeries/HvCallSc.h>
|
#include <asm/iSeries/HvCallSc.h>
|
||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
|
|
||||||
//-------------------------------------------------------------------------------------
|
enum HvCallCfg_ReqQual {
|
||||||
// Constants
|
|
||||||
//-------------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
enum HvCallCfg_ReqQual
|
|
||||||
{
|
|
||||||
HvCallCfg_Cur = 0,
|
HvCallCfg_Cur = 0,
|
||||||
HvCallCfg_Init = 1,
|
HvCallCfg_Init = 1,
|
||||||
HvCallCfg_Max = 2,
|
HvCallCfg_Max = 2,
|
||||||
@ -49,7 +38,7 @@ enum HvCallCfg_ReqQual
|
|||||||
#define HvCallCfgGetLpVrmIndex HvCallCfg + 2
|
#define HvCallCfgGetLpVrmIndex HvCallCfg + 2
|
||||||
#define HvCallCfgGetLpMinSupportedPlicVrmIndex HvCallCfg + 3
|
#define HvCallCfgGetLpMinSupportedPlicVrmIndex HvCallCfg + 3
|
||||||
#define HvCallCfgGetLpMinCompatablePlicVrmIndex HvCallCfg + 4
|
#define HvCallCfgGetLpMinCompatablePlicVrmIndex HvCallCfg + 4
|
||||||
#define HvCallCfgGetLpVrmName HvCallCfg + 5
|
#define HvCallCfgGetLpVrmName HvCallCfg + 5
|
||||||
#define HvCallCfgGetSystemPhysicalProcessors HvCallCfg + 6
|
#define HvCallCfgGetSystemPhysicalProcessors HvCallCfg + 6
|
||||||
#define HvCallCfgGetPhysicalProcessors HvCallCfg + 7
|
#define HvCallCfgGetPhysicalProcessors HvCallCfg + 7
|
||||||
#define HvCallCfgGetSystemMsChunks HvCallCfg + 8
|
#define HvCallCfgGetSystemMsChunks HvCallCfg + 8
|
||||||
@ -76,108 +65,113 @@ enum HvCallCfg_ReqQual
|
|||||||
#define HvCallCfgSetMinRuntimeMsChunks HvCallCfg + 29
|
#define HvCallCfgSetMinRuntimeMsChunks HvCallCfg + 29
|
||||||
#define HvCallCfgGetVirtualLanIndexMap HvCallCfg + 30
|
#define HvCallCfgGetVirtualLanIndexMap HvCallCfg + 30
|
||||||
#define HvCallCfgGetLpExecutionMode HvCallCfg + 31
|
#define HvCallCfgGetLpExecutionMode HvCallCfg + 31
|
||||||
#define HvCallCfgGetHostingLpIndex HvCallCfg + 32
|
#define HvCallCfgGetHostingLpIndex HvCallCfg + 32
|
||||||
|
|
||||||
//====================================================================
|
|
||||||
static inline HvLpIndex HvCallCfg_getLps(void)
|
static inline HvLpIndex HvCallCfg_getLps(void)
|
||||||
{
|
{
|
||||||
HvLpIndex retVal = HvCall0(HvCallCfgGetLps);
|
HvLpIndex retVal = HvCall0(HvCallCfgGetLps);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//====================================================================
|
|
||||||
static inline int HvCallCfg_isBusDedicated(u64 busIndex)
|
static inline int HvCallCfg_isBusDedicated(u64 busIndex)
|
||||||
{
|
{
|
||||||
int retVal = HvCall1(HvCallCfgIsBusDedicated,busIndex);
|
int retVal = HvCall1(HvCallCfgIsBusDedicated,busIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//====================================================================
|
|
||||||
static inline HvLpIndex HvCallCfg_getBusOwner(u64 busIndex)
|
static inline HvLpIndex HvCallCfg_getBusOwner(u64 busIndex)
|
||||||
{
|
{
|
||||||
HvLpIndex retVal = HvCall1(HvCallCfgGetBusOwner,busIndex);
|
HvLpIndex retVal = HvCall1(HvCallCfgGetBusOwner,busIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//====================================================================
|
|
||||||
static inline HvLpIndexMap HvCallCfg_getBusAllocation(u64 busIndex)
|
static inline HvLpIndexMap HvCallCfg_getBusAllocation(u64 busIndex)
|
||||||
{
|
{
|
||||||
HvLpIndexMap retVal = HvCall1(HvCallCfgGetBusAllocation,busIndex);
|
HvLpIndexMap retVal = HvCall1(HvCallCfgGetBusAllocation,busIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//====================================================================
|
|
||||||
static inline HvLpIndexMap HvCallCfg_getActiveLpMap(void)
|
static inline HvLpIndexMap HvCallCfg_getActiveLpMap(void)
|
||||||
{
|
{
|
||||||
HvLpIndexMap retVal = HvCall0(HvCallCfgGetActiveLpMap);
|
HvLpIndexMap retVal = HvCall0(HvCallCfgGetActiveLpMap);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//====================================================================
|
|
||||||
static inline HvLpVirtualLanIndexMap HvCallCfg_getVirtualLanIndexMap(HvLpIndex lp)
|
static inline HvLpVirtualLanIndexMap HvCallCfg_getVirtualLanIndexMap(
|
||||||
|
HvLpIndex lp)
|
||||||
{
|
{
|
||||||
// This is a new function in V5R1 so calls to this on older
|
/*
|
||||||
// hypervisors will return -1
|
* This is a new function in V5R1 so calls to this on older
|
||||||
|
* hypervisors will return -1
|
||||||
|
*/
|
||||||
u64 retVal = HvCall1(HvCallCfgGetVirtualLanIndexMap, lp);
|
u64 retVal = HvCall1(HvCallCfgGetVirtualLanIndexMap, lp);
|
||||||
if(retVal == -1)
|
if (retVal == -1)
|
||||||
retVal = 0;
|
retVal = 0;
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline u64 HvCallCfg_getSystemMsChunks(void)
|
static inline u64 HvCallCfg_getSystemMsChunks(void)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall0(HvCallCfgGetSystemMsChunks);
|
u64 retVal = HvCall0(HvCallCfgGetSystemMsChunks);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline u64 HvCallCfg_getMsChunks(HvLpIndex lp,enum HvCallCfg_ReqQual qual)
|
static inline u64 HvCallCfg_getMsChunks(HvLpIndex lp,
|
||||||
|
enum HvCallCfg_ReqQual qual)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall2(HvCallCfgGetMsChunks,lp,qual);
|
u64 retVal = HvCall2(HvCallCfgGetMsChunks,lp,qual);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline u64 HvCallCfg_getMinRuntimeMsChunks(HvLpIndex lp)
|
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);
|
* NOTE: This function was added in v5r1 so older hypervisors
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
* will return a -1 value
|
||||||
return retVal;
|
*/
|
||||||
|
return HvCall1(HvCallCfgGetMinRuntimeMsChunks, lp);
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline u64 HvCallCfg_setMinRuntimeMsChunks(u64 chunks)
|
static inline u64 HvCallCfg_setMinRuntimeMsChunks(u64 chunks)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall1(HvCallCfgSetMinRuntimeMsChunks,chunks);
|
u64 retVal = HvCall1(HvCallCfgSetMinRuntimeMsChunks,chunks);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline u64 HvCallCfg_getSystemPhysicalProcessors(void)
|
static inline u64 HvCallCfg_getSystemPhysicalProcessors(void)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall0(HvCallCfgGetSystemPhysicalProcessors);
|
u64 retVal = HvCall0(HvCallCfgGetSystemPhysicalProcessors);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline u64 HvCallCfg_getPhysicalProcessors(HvLpIndex lp,enum HvCallCfg_ReqQual qual)
|
static inline u64 HvCallCfg_getPhysicalProcessors(HvLpIndex lp,
|
||||||
|
enum HvCallCfg_ReqQual qual)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall2(HvCallCfgGetPhysicalProcessors,lp,qual);
|
u64 retVal = HvCall2(HvCallCfgGetPhysicalProcessors,lp,qual);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline u64 HvCallCfg_getConfiguredBusUnitsForInterruptProc(HvLpIndex lp,
|
static inline u64 HvCallCfg_getConfiguredBusUnitsForInterruptProc(HvLpIndex lp,
|
||||||
u16 hvLogicalProcIndex)
|
u16 hvLogicalProcIndex)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall2(HvCallCfgGetConfiguredBusUnitsForIntProc,lp,hvLogicalProcIndex);
|
u64 retVal = HvCall2(HvCallCfgGetConfiguredBusUnitsForIntProc,lp,hvLogicalProcIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
|
|
||||||
}
|
}
|
||||||
//==================================================================
|
|
||||||
static inline HvLpSharedPoolIndex HvCallCfg_getSharedPoolIndex(HvLpIndex lp)
|
static inline HvLpSharedPoolIndex HvCallCfg_getSharedPoolIndex(HvLpIndex lp)
|
||||||
{
|
{
|
||||||
HvLpSharedPoolIndex retVal =
|
HvLpSharedPoolIndex retVal =
|
||||||
HvCall1(HvCallCfgGetSharedPoolIndex,lp);
|
HvCall1(HvCallCfgGetSharedPoolIndex,lp);
|
||||||
@ -185,29 +179,29 @@ static inline HvLpSharedPoolIndex HvCallCfg_getSharedPoolIndex(HvLpIndex lp)
|
|||||||
return retVal;
|
return retVal;
|
||||||
|
|
||||||
}
|
}
|
||||||
//==================================================================
|
|
||||||
static inline u64 HvCallCfg_getSharedProcUnits(HvLpIndex lp,enum HvCallCfg_ReqQual qual)
|
static inline u64 HvCallCfg_getSharedProcUnits(HvLpIndex lp,
|
||||||
|
enum HvCallCfg_ReqQual qual)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall2(HvCallCfgGetSharedProcUnits,lp,qual);
|
u64 retVal = HvCall2(HvCallCfgGetSharedProcUnits,lp,qual);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
|
|
||||||
}
|
}
|
||||||
//==================================================================
|
|
||||||
static inline u64 HvCallCfg_getNumProcsInSharedPool(HvLpSharedPoolIndex sPI)
|
static inline u64 HvCallCfg_getNumProcsInSharedPool(HvLpSharedPoolIndex sPI)
|
||||||
{
|
{
|
||||||
u16 retVal = HvCall1(HvCallCfgGetNumProcsInSharedPool,sPI);
|
u16 retVal = HvCall1(HvCallCfgGetNumProcsInSharedPool,sPI);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
|
|
||||||
}
|
}
|
||||||
//==================================================================
|
|
||||||
static inline HvLpIndex HvCallCfg_getHostingLpIndex(HvLpIndex lp)
|
static inline HvLpIndex HvCallCfg_getHostingLpIndex(HvLpIndex lp)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall1(HvCallCfgGetHostingLpIndex,lp);
|
u64 retVal = HvCall1(HvCallCfgGetHostingLpIndex,lp);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* _HVCALLCFG_H */
|
#endif /* _HVCALLCFG_H */
|
||||||
|
@ -1,32 +1,28 @@
|
|||||||
/*
|
/*
|
||||||
* HvCallEvent.h
|
* HvCallEvent.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This file contains the "hypervisor call" interface which is used to
|
* This file contains the "hypervisor call" interface which is used to
|
||||||
* drive the hypervisor from the OS.
|
* drive the hypervisor from the OS.
|
||||||
*/
|
*/
|
||||||
#ifndef _HVCALLEVENT_H
|
#ifndef _HVCALLEVENT_H
|
||||||
#define _HVCALLEVENT_H
|
#define _HVCALLEVENT_H
|
||||||
|
|
||||||
/*
|
|
||||||
* Standard Includes
|
|
||||||
*/
|
|
||||||
#include <asm/iSeries/HvCallSc.h>
|
#include <asm/iSeries/HvCallSc.h>
|
||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
#include <asm/abs_addr.h>
|
#include <asm/abs_addr.h>
|
||||||
@ -71,7 +67,7 @@ typedef u64 HvLpDma_Rc;
|
|||||||
#define HvCallEventCloseLpEventPath HvCallEvent + 2
|
#define HvCallEventCloseLpEventPath HvCallEvent + 2
|
||||||
#define HvCallEventDmaBufList HvCallEvent + 3
|
#define HvCallEventDmaBufList HvCallEvent + 3
|
||||||
#define HvCallEventDmaSingle HvCallEvent + 4
|
#define HvCallEventDmaSingle HvCallEvent + 4
|
||||||
#define HvCallEventDmaToSp HvCallEvent + 5
|
#define HvCallEventDmaToSp HvCallEvent + 5
|
||||||
#define HvCallEventGetOverflowLpEvents HvCallEvent + 6
|
#define HvCallEventGetOverflowLpEvents HvCallEvent + 6
|
||||||
#define HvCallEventGetSourceLpInstanceId HvCallEvent + 7
|
#define HvCallEventGetSourceLpInstanceId HvCallEvent + 7
|
||||||
#define HvCallEventGetTargetLpInstanceId HvCallEvent + 8
|
#define HvCallEventGetTargetLpInstanceId HvCallEvent + 8
|
||||||
@ -85,13 +81,13 @@ typedef u64 HvLpDma_Rc;
|
|||||||
|
|
||||||
static inline void HvCallEvent_getOverflowLpEvents(u8 queueIndex)
|
static inline void HvCallEvent_getOverflowLpEvents(u8 queueIndex)
|
||||||
{
|
{
|
||||||
HvCall1(HvCallEventGetOverflowLpEvents,queueIndex);
|
HvCall1(HvCallEventGetOverflowLpEvents, queueIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void HvCallEvent_setInterLpQueueIndex(u8 queueIndex)
|
static inline void HvCallEvent_setInterLpQueueIndex(u8 queueIndex)
|
||||||
{
|
{
|
||||||
HvCall1(HvCallEventSetInterLpQueueIndex,queueIndex);
|
HvCall1(HvCallEventSetInterLpQueueIndex, queueIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -138,7 +134,7 @@ static inline HvLpEvent_Rc HvCallEvent_signalLpEventFast(HvLpIndex targetLp,
|
|||||||
{
|
{
|
||||||
HvLpEvent_Rc retVal;
|
HvLpEvent_Rc retVal;
|
||||||
|
|
||||||
// Pack the misc bits into a single Dword to pass to PLIC
|
/* Pack the misc bits into a single Dword to pass to PLIC */
|
||||||
union {
|
union {
|
||||||
struct HvCallEvent_PackedParms parms;
|
struct HvCallEvent_PackedParms parms;
|
||||||
u64 dword;
|
u64 dword;
|
||||||
@ -225,7 +221,7 @@ static inline HvLpDma_Rc HvCallEvent_dmaBufList(HvLpEvent_Type type,
|
|||||||
u64 localBufList, u64 remoteBufList, u32 transferLength)
|
u64 localBufList, u64 remoteBufList, u32 transferLength)
|
||||||
{
|
{
|
||||||
HvLpDma_Rc retVal;
|
HvLpDma_Rc retVal;
|
||||||
// Pack the misc bits into a single Dword to pass to PLIC
|
/* Pack the misc bits into a single Dword to pass to PLIC */
|
||||||
union {
|
union {
|
||||||
struct HvCallEvent_PackedDmaParms parms;
|
struct HvCallEvent_PackedDmaParms parms;
|
||||||
u64 dword;
|
u64 dword;
|
||||||
@ -257,7 +253,7 @@ static inline HvLpDma_Rc HvCallEvent_dmaSingle(HvLpEvent_Type type,
|
|||||||
u64 localAddrOrTce, u64 remoteAddrOrTce, u32 transferLength)
|
u64 localAddrOrTce, u64 remoteAddrOrTce, u32 transferLength)
|
||||||
{
|
{
|
||||||
HvLpDma_Rc retVal;
|
HvLpDma_Rc retVal;
|
||||||
// Pack the misc bits into a single Dword to pass to PLIC
|
/* Pack the misc bits into a single Dword to pass to PLIC */
|
||||||
union {
|
union {
|
||||||
struct HvCallEvent_PackedDmaParms parms;
|
struct HvCallEvent_PackedDmaParms parms;
|
||||||
u64 dword;
|
u64 dword;
|
||||||
@ -280,7 +276,7 @@ static inline HvLpDma_Rc HvCallEvent_dmaSingle(HvLpEvent_Type type,
|
|||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline HvLpDma_Rc HvCallEvent_dmaToSp(void* local, u32 remote,
|
static inline HvLpDma_Rc HvCallEvent_dmaToSp(void *local, u32 remote,
|
||||||
u32 length, HvLpDma_Direction dir)
|
u32 length, HvLpDma_Direction dir)
|
||||||
{
|
{
|
||||||
u64 abs_addr;
|
u64 abs_addr;
|
||||||
@ -293,5 +289,4 @@ static inline HvLpDma_Rc HvCallEvent_dmaToSp(void* local, u32 remote,
|
|||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif /* _HVCALLEVENT_H */
|
#endif /* _HVCALLEVENT_H */
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
/*
|
/*
|
||||||
* HvCallHpt.h
|
* HvCallHpt.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
@ -19,21 +19,15 @@
|
|||||||
#ifndef _HVCALLHPT_H
|
#ifndef _HVCALLHPT_H
|
||||||
#define _HVCALLHPT_H
|
#define _HVCALLHPT_H
|
||||||
|
|
||||||
//============================================================================
|
/*
|
||||||
//
|
* This file contains the "hypervisor call" interface which is used to
|
||||||
// This file contains the "hypervisor call" interface which is used to
|
* drive the hypervisor from the OS.
|
||||||
// drive the hypervisor from the OS.
|
*/
|
||||||
//
|
|
||||||
//============================================================================
|
|
||||||
|
|
||||||
#include <asm/iSeries/HvCallSc.h>
|
#include <asm/iSeries/HvCallSc.h>
|
||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
#include <asm/mmu.h>
|
#include <asm/mmu.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Constants
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#define HvCallHptGetHptAddress HvCallHpt + 0
|
#define HvCallHptGetHptAddress HvCallHpt + 0
|
||||||
#define HvCallHptGetHptPages HvCallHpt + 1
|
#define HvCallHptGetHptPages HvCallHpt + 1
|
||||||
#define HvCallHptSetPp HvCallHpt + 5
|
#define HvCallHptSetPp HvCallHpt + 5
|
||||||
@ -47,81 +41,76 @@
|
|||||||
#define HvCallHptInvalidateSetSwBitsGet HvCallHpt + 18
|
#define HvCallHptInvalidateSetSwBitsGet HvCallHpt + 18
|
||||||
|
|
||||||
|
|
||||||
//============================================================================
|
static inline u64 HvCallHpt_getHptAddress(void)
|
||||||
static inline u64 HvCallHpt_getHptAddress(void)
|
|
||||||
{
|
{
|
||||||
u64 retval = HvCall0(HvCallHptGetHptAddress);
|
u64 retval = HvCall0(HvCallHptGetHptAddress);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallHpt_getHptPages(void)
|
static inline u64 HvCallHpt_getHptPages(void)
|
||||||
{
|
{
|
||||||
u64 retval = HvCall0(HvCallHptGetHptPages);
|
u64 retval = HvCall0(HvCallHptGetHptPages);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline void HvCallHpt_setPp(u32 hpteIndex, u8 value)
|
static inline void HvCallHpt_setPp(u32 hpteIndex, u8 value)
|
||||||
{
|
{
|
||||||
HvCall2( HvCallHptSetPp, hpteIndex, value );
|
HvCall2(HvCallHptSetPp, hpteIndex, value);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline void HvCallHpt_setSwBits(u32 hpteIndex, u8 bitson, u8 bitsoff )
|
static inline void HvCallHpt_setSwBits(u32 hpteIndex, u8 bitson, u8 bitsoff)
|
||||||
{
|
{
|
||||||
HvCall3( HvCallHptSetSwBits, hpteIndex, bitson, bitsoff );
|
HvCall3(HvCallHptSetSwBits, hpteIndex, bitson, bitsoff);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline void HvCallHpt_invalidateNoSyncICache(u32 hpteIndex)
|
static inline void HvCallHpt_invalidateNoSyncICache(u32 hpteIndex)
|
||||||
|
|
||||||
{
|
{
|
||||||
HvCall1( HvCallHptInvalidateNoSyncICache, hpteIndex );
|
HvCall1(HvCallHptInvalidateNoSyncICache, hpteIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline u64 HvCallHpt_invalidateSetSwBitsGet(u32 hpteIndex, u8 bitson, u8 bitsoff )
|
static inline u64 HvCallHpt_invalidateSetSwBitsGet(u32 hpteIndex, u8 bitson,
|
||||||
|
u8 bitsoff)
|
||||||
{
|
{
|
||||||
u64 compressedStatus;
|
u64 compressedStatus;
|
||||||
compressedStatus = HvCall4( HvCallHptInvalidateSetSwBitsGet, hpteIndex, bitson, bitsoff, 1 );
|
|
||||||
HvCall1( HvCallHptInvalidateNoSyncICache, hpteIndex );
|
compressedStatus = HvCall4(HvCallHptInvalidateSetSwBitsGet,
|
||||||
|
hpteIndex, bitson, bitsoff, 1);
|
||||||
|
HvCall1(HvCallHptInvalidateNoSyncICache, hpteIndex);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return compressedStatus;
|
return compressedStatus;
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline u64 HvCallHpt_findValid( HPTE *hpte, u64 vpn )
|
static inline u64 HvCallHpt_findValid(HPTE *hpte, u64 vpn)
|
||||||
{
|
{
|
||||||
u64 retIndex = HvCall3Ret16( HvCallHptFindValid, hpte, vpn, 0, 0 );
|
u64 retIndex = HvCall3Ret16( HvCallHptFindValid, hpte, vpn, 0, 0 );
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retIndex;
|
return retIndex;
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline u64 HvCallHpt_findNextValid( HPTE *hpte, u32 hpteIndex, u8 bitson, u8 bitsoff )
|
static inline u64 HvCallHpt_findNextValid(HPTE *hpte, u32 hpteIndex,
|
||||||
|
u8 bitson, u8 bitsoff)
|
||||||
{
|
{
|
||||||
u64 retIndex = HvCall3Ret16( HvCallHptFindNextValid, hpte, hpteIndex, bitson, bitsoff );
|
u64 retIndex = HvCall3Ret16( HvCallHptFindNextValid, hpte, hpteIndex, bitson, bitsoff );
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retIndex;
|
return retIndex;
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline void HvCallHpt_get( HPTE *hpte, u32 hpteIndex )
|
static inline void HvCallHpt_get(HPTE *hpte, u32 hpteIndex)
|
||||||
{
|
{
|
||||||
HvCall2Ret16( HvCallHptGet, hpte, hpteIndex, 0 );
|
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();
|
// 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 */
|
#endif /* _HVCALLHPT_H */
|
||||||
|
@ -1,26 +1,26 @@
|
|||||||
/************************************************************************/
|
/*
|
||||||
/* Provides the Hypervisor PCI calls for iSeries Linux Parition. */
|
* Provides the Hypervisor PCI calls for iSeries Linux Parition.
|
||||||
/* Copyright (C) 2001 <Wayne G Holm> <IBM Corporation> */
|
* Copyright (C) 2001 <Wayne G Holm> <IBM Corporation>
|
||||||
/* */
|
*
|
||||||
/* This program is free software; you can redistribute it and/or modify */
|
* 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 */
|
* it under the terms of the GNU General Public License as published by
|
||||||
/* the Free Software Foundation; either version 2 of the License, or */
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
/* (at your option) any later version. */
|
* (at your option) any later version.
|
||||||
/* */
|
*
|
||||||
/* This program is distributed in the hope that it will be useful, */
|
* This program is distributed in the hope that it will be useful,
|
||||||
/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
/* GNU General Public License for more details. */
|
* GNU General Public License for more details.
|
||||||
/* */
|
*
|
||||||
/* You should have received a copy of the GNU General Public License */
|
* You should have received a copy of the GNU General Public License
|
||||||
/* along with this program; if not, write to the: */
|
* along with this program; if not, write to the:
|
||||||
/* Free Software Foundation, Inc., */
|
* Free Software Foundation, Inc.,
|
||||||
/* 59 Temple Place, Suite 330, */
|
* 59 Temple Place, Suite 330,
|
||||||
/* Boston, MA 02111-1307 USA */
|
* Boston, MA 02111-1307 USA
|
||||||
/************************************************************************/
|
*
|
||||||
/* Change Activity: */
|
* Change Activity:
|
||||||
/* Created, Jan 9, 2001 */
|
* Created, Jan 9, 2001
|
||||||
/************************************************************************/
|
*/
|
||||||
|
|
||||||
#ifndef _HVCALLPCI_H
|
#ifndef _HVCALLPCI_H
|
||||||
#define _HVCALLPCI_H
|
#define _HVCALLPCI_H
|
||||||
@ -34,8 +34,8 @@
|
|||||||
*/
|
*/
|
||||||
struct HvCallPci_DsaAddr {
|
struct HvCallPci_DsaAddr {
|
||||||
u16 busNumber; /* PHB index? */
|
u16 busNumber; /* PHB index? */
|
||||||
u8 subBusNumber; /* PCI bus number? */
|
u8 subBusNumber; /* PCI bus number? */
|
||||||
u8 deviceId; /* device and function? */
|
u8 deviceId; /* device and function? */
|
||||||
u8 barNumber;
|
u8 barNumber;
|
||||||
u8 reserved[3];
|
u8 reserved[3];
|
||||||
};
|
};
|
||||||
@ -52,34 +52,37 @@ struct HvCallPci_LoadReturn {
|
|||||||
|
|
||||||
enum HvCallPci_DeviceType {
|
enum HvCallPci_DeviceType {
|
||||||
HvCallPci_NodeDevice = 1,
|
HvCallPci_NodeDevice = 1,
|
||||||
HvCallPci_SpDevice = 2,
|
HvCallPci_SpDevice = 2,
|
||||||
HvCallPci_IopDevice = 3,
|
HvCallPci_IopDevice = 3,
|
||||||
HvCallPci_BridgeDevice = 4,
|
HvCallPci_BridgeDevice = 4,
|
||||||
HvCallPci_MultiFunctionDevice = 5,
|
HvCallPci_MultiFunctionDevice = 5,
|
||||||
HvCallPci_IoaDevice = 6
|
HvCallPci_IoaDevice = 6
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
struct HvCallPci_DeviceInfo {
|
struct HvCallPci_DeviceInfo {
|
||||||
u32 deviceType; // See DeviceType enum for values
|
u32 deviceType; /* See DeviceType enum for values */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct HvCallPci_BusUnitInfo {
|
struct HvCallPci_BusUnitInfo {
|
||||||
u32 sizeReturned; // length of data returned
|
u32 sizeReturned; /* length of data returned */
|
||||||
u32 deviceType; // see DeviceType enum for values
|
u32 deviceType; /* see DeviceType enum for values */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct HvCallPci_BridgeInfo {
|
struct HvCallPci_BridgeInfo {
|
||||||
struct HvCallPci_BusUnitInfo busUnitInfo; // Generic bus unit info
|
struct HvCallPci_BusUnitInfo busUnitInfo; /* Generic bus unit info */
|
||||||
u8 subBusNumber; // Bus number of secondary bus
|
u8 subBusNumber; /* Bus number of secondary bus */
|
||||||
u8 maxAgents; // Max idsels on secondary bus
|
u8 maxAgents; /* Max idsels on secondary bus */
|
||||||
u8 maxSubBusNumber; // Max Sub Bus
|
u8 maxSubBusNumber; /* Max Sub Bus */
|
||||||
u8 logicalSlotNumber; // Logical Slot Number for IOA
|
u8 logicalSlotNumber; /* Logical Slot Number for IOA */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// Maximum BusUnitInfo buffer size. Provided for clients so they can allocate
|
|
||||||
// a buffer big enough for any type of bus unit. Increase as needed.
|
/*
|
||||||
|
* Maximum BusUnitInfo buffer size. Provided for clients so
|
||||||
|
* they can allocate a buffer big enough for any type of bus
|
||||||
|
* unit. Increase as needed.
|
||||||
|
*/
|
||||||
enum {HvCallPci_MaxBusUnitInfoSize = 128};
|
enum {HvCallPci_MaxBusUnitInfoSize = 128};
|
||||||
|
|
||||||
struct HvCallPci_BarParms {
|
struct HvCallPci_BarParms {
|
||||||
@ -89,12 +92,12 @@ struct HvCallPci_BarParms {
|
|||||||
u64 protectStart;
|
u64 protectStart;
|
||||||
u64 protectEnd;
|
u64 protectEnd;
|
||||||
u64 relocationOffset;
|
u64 relocationOffset;
|
||||||
u64 pciAddress;
|
u64 pciAddress;
|
||||||
u64 reserved[3];
|
u64 reserved[3];
|
||||||
};
|
};
|
||||||
|
|
||||||
enum HvCallPci_VpdType {
|
enum HvCallPci_VpdType {
|
||||||
HvCallPci_BusVpd = 1,
|
HvCallPci_BusVpd = 1,
|
||||||
HvCallPci_BusAdapterVpd = 2
|
HvCallPci_BusAdapterVpd = 2
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -123,15 +126,13 @@ enum HvCallPci_VpdType {
|
|||||||
#define HvCallPciUnmaskInterrupts HvCallPci + 49
|
#define HvCallPciUnmaskInterrupts HvCallPci + 49
|
||||||
#define HvCallPciGetBusUnitInfo HvCallPci + 50
|
#define HvCallPciGetBusUnitInfo HvCallPci + 50
|
||||||
|
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_configLoad8(u16 busNumber, u8 subBusNumber,
|
static inline u64 HvCallPci_configLoad8(u16 busNumber, u8 subBusNumber,
|
||||||
u8 deviceId, u32 offset,
|
u8 deviceId, u32 offset, u8 *value)
|
||||||
u8 *value)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumber;
|
dsa.busNumber = busNumber;
|
||||||
dsa.subBusNumber = subBusNumber;
|
dsa.subBusNumber = subBusNumber;
|
||||||
@ -145,15 +146,14 @@ static inline u64 HvCallPci_configLoad8(u16 busNumber, u8 subBusNumber,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_configLoad16(u16 busNumber, u8 subBusNumber,
|
static inline u64 HvCallPci_configLoad16(u16 busNumber, u8 subBusNumber,
|
||||||
u8 deviceId, u32 offset,
|
u8 deviceId, u32 offset, u16 *value)
|
||||||
u16 *value)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumber;
|
dsa.busNumber = busNumber;
|
||||||
dsa.subBusNumber = subBusNumber;
|
dsa.subBusNumber = subBusNumber;
|
||||||
@ -167,15 +167,14 @@ static inline u64 HvCallPci_configLoad16(u16 busNumber, u8 subBusNumber,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_configLoad32(u16 busNumber, u8 subBusNumber,
|
static inline u64 HvCallPci_configLoad32(u16 busNumber, u8 subBusNumber,
|
||||||
u8 deviceId, u32 offset,
|
u8 deviceId, u32 offset, u32 *value)
|
||||||
u32 *value)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumber;
|
dsa.busNumber = busNumber;
|
||||||
dsa.subBusNumber = subBusNumber;
|
dsa.subBusNumber = subBusNumber;
|
||||||
@ -189,15 +188,14 @@ static inline u64 HvCallPci_configLoad32(u16 busNumber, u8 subBusNumber,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_configStore8(u16 busNumber, u8 subBusNumber,
|
static inline u64 HvCallPci_configStore8(u16 busNumber, u8 subBusNumber,
|
||||||
u8 deviceId, u32 offset,
|
u8 deviceId, u32 offset, u8 value)
|
||||||
u8 value)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumber;
|
dsa.busNumber = busNumber;
|
||||||
dsa.subBusNumber = subBusNumber;
|
dsa.subBusNumber = subBusNumber;
|
||||||
@ -209,15 +207,14 @@ static inline u64 HvCallPci_configStore8(u16 busNumber, u8 subBusNumber,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_configStore16(u16 busNumber, u8 subBusNumber,
|
static inline u64 HvCallPci_configStore16(u16 busNumber, u8 subBusNumber,
|
||||||
u8 deviceId, u32 offset,
|
u8 deviceId, u32 offset, u16 value)
|
||||||
u16 value)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumber;
|
dsa.busNumber = busNumber;
|
||||||
dsa.subBusNumber = subBusNumber;
|
dsa.subBusNumber = subBusNumber;
|
||||||
@ -229,15 +226,14 @@ static inline u64 HvCallPci_configStore16(u16 busNumber, u8 subBusNumber,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_configStore32(u16 busNumber, u8 subBusNumber,
|
static inline u64 HvCallPci_configStore32(u16 busNumber, u8 subBusNumber,
|
||||||
u8 deviceId, u32 offset,
|
u8 deviceId, u32 offset, u32 value)
|
||||||
u32 value)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumber;
|
dsa.busNumber = busNumber;
|
||||||
dsa.subBusNumber = subBusNumber;
|
dsa.subBusNumber = subBusNumber;
|
||||||
@ -249,18 +245,15 @@ static inline u64 HvCallPci_configStore32(u16 busNumber, u8 subBusNumber,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barLoad8(u16 busNumberParm,
|
static inline u64 HvCallPci_barLoad8(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u8 *valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u8* valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -275,18 +268,15 @@ static inline u64 HvCallPci_barLoad8(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barLoad16(u16 busNumberParm,
|
static inline u64 HvCallPci_barLoad16(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u16 *valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u16* valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -301,18 +291,15 @@ static inline u64 HvCallPci_barLoad16(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barLoad32(u16 busNumberParm,
|
static inline u64 HvCallPci_barLoad32(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u32 *valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u32* valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -327,18 +314,15 @@ static inline u64 HvCallPci_barLoad32(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barLoad64(u16 busNumberParm,
|
static inline u64 HvCallPci_barLoad64(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u64 *valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u64* valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -353,19 +337,16 @@ static inline u64 HvCallPci_barLoad64(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barStore8(u16 busNumberParm,
|
static inline u64 HvCallPci_barStore8(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u8 valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u8 valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
dsa.deviceId = deviceIdParm;
|
dsa.deviceId = deviceIdParm;
|
||||||
@ -377,19 +358,16 @@ static inline u64 HvCallPci_barStore8(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barStore16(u16 busNumberParm,
|
static inline u64 HvCallPci_barStore16(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u16 valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u16 valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
dsa.deviceId = deviceIdParm;
|
dsa.deviceId = deviceIdParm;
|
||||||
@ -401,19 +379,16 @@ static inline u64 HvCallPci_barStore16(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barStore32(u16 busNumberParm,
|
static inline u64 HvCallPci_barStore32(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u32 valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u32 valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
dsa.deviceId = deviceIdParm;
|
dsa.deviceId = deviceIdParm;
|
||||||
@ -425,19 +400,16 @@ static inline u64 HvCallPci_barStore32(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_barStore64(u16 busNumberParm,
|
static inline u64 HvCallPci_barStore64(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 offsetParm,
|
||||||
u8 deviceIdParm,
|
u64 valueParm)
|
||||||
u8 barNumberParm,
|
|
||||||
u64 offsetParm,
|
|
||||||
u64 valueParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
dsa.deviceId = deviceIdParm;
|
dsa.deviceId = deviceIdParm;
|
||||||
@ -449,10 +421,9 @@ static inline u64 HvCallPci_barStore64(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_eoi(u16 busNumberParm,
|
static inline u64 HvCallPci_eoi(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm)
|
||||||
u8 deviceIdParm)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
struct HvCallPci_LoadReturn retVal;
|
struct HvCallPci_LoadReturn retVal;
|
||||||
@ -469,13 +440,9 @@ static inline u64 HvCallPci_eoi(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal.rc;
|
return retVal.rc;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_getBarParms(u16 busNumberParm,
|
static inline u64 HvCallPci_getBarParms(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u8 barNumberParm, u64 parms, u32 sizeofParms)
|
||||||
u8 deviceIdParm,
|
|
||||||
u8 barNumberParm,
|
|
||||||
u64 parms,
|
|
||||||
u32 sizeofParms)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
@ -493,16 +460,14 @@ static inline u64 HvCallPci_getBarParms(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_maskFisr(u16 busNumberParm,
|
static inline u64 HvCallPci_maskFisr(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u64 fisrMask)
|
||||||
u8 deviceIdParm,
|
|
||||||
u64 fisrMask)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -514,16 +479,14 @@ static inline u64 HvCallPci_maskFisr(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_unmaskFisr(u16 busNumberParm,
|
static inline u64 HvCallPci_unmaskFisr(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u64 fisrMask)
|
||||||
u8 deviceIdParm,
|
|
||||||
u64 fisrMask)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -535,11 +498,9 @@ static inline u64 HvCallPci_unmaskFisr(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_setSlotReset(u16 busNumberParm,
|
static inline u64 HvCallPci_setSlotReset(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u64 onNotOff)
|
||||||
u8 deviceIdParm,
|
|
||||||
u64 onNotOff)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
@ -556,12 +517,9 @@ static inline u64 HvCallPci_setSlotReset(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_getDeviceInfo(u16 busNumberParm,
|
static inline u64 HvCallPci_getDeviceInfo(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceNumberParm, u64 parms, u32 sizeofParms)
|
||||||
u8 deviceNumberParm,
|
|
||||||
u64 parms,
|
|
||||||
u32 sizeofParms)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
@ -578,16 +536,14 @@ static inline u64 HvCallPci_getDeviceInfo(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_maskInterrupts(u16 busNumberParm,
|
static inline u64 HvCallPci_maskInterrupts(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u64 interruptMask)
|
||||||
u8 deviceIdParm,
|
|
||||||
u64 interruptMask)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -599,16 +555,14 @@ static inline u64 HvCallPci_maskInterrupts(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallPci_unmaskInterrupts(u16 busNumberParm,
|
static inline u64 HvCallPci_unmaskInterrupts(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u64 interruptMask)
|
||||||
u8 deviceIdParm,
|
|
||||||
u64 interruptMask)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -620,18 +574,14 @@ static inline u64 HvCallPci_unmaskInterrupts(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
|
|
||||||
static inline u64 HvCallPci_getBusUnitInfo(u16 busNumberParm,
|
static inline u64 HvCallPci_getBusUnitInfo(u16 busNumberParm, u8 subBusParm,
|
||||||
u8 subBusParm,
|
u8 deviceIdParm, u64 parms, u32 sizeofParms)
|
||||||
u8 deviceIdParm,
|
|
||||||
u64 parms,
|
|
||||||
u32 sizeofParms)
|
|
||||||
{
|
{
|
||||||
struct HvCallPci_DsaAddr dsa;
|
struct HvCallPci_DsaAddr dsa;
|
||||||
u64 retVal;
|
u64 retVal;
|
||||||
|
|
||||||
*((u64*)&dsa) = 0;
|
*((u64*)&dsa) = 0;
|
||||||
|
|
||||||
dsa.busNumber = busNumberParm;
|
dsa.busNumber = busNumberParm;
|
||||||
dsa.subBusNumber = subBusParm;
|
dsa.subBusNumber = subBusParm;
|
||||||
@ -643,9 +593,9 @@ static inline u64 HvCallPci_getBusUnitInfo(u16 busNumberParm,
|
|||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
|
|
||||||
static inline int HvCallPci_getBusVpd(u16 busNumParm, u64 destParm, u16 sizeParm)
|
static inline int HvCallPci_getBusVpd(u16 busNumParm, u64 destParm,
|
||||||
|
u16 sizeParm)
|
||||||
{
|
{
|
||||||
int xRetSize;
|
int xRetSize;
|
||||||
u64 xRc = HvCall4(HvCallPciGetCardVpd, busNumParm, destParm, sizeParm, HvCallPci_BusVpd);
|
u64 xRc = HvCall4(HvCallPciGetCardVpd, busNumParm, destParm, sizeParm, HvCallPci_BusVpd);
|
||||||
@ -656,9 +606,9 @@ static inline int HvCallPci_getBusVpd(u16 busNumParm, u64 destParm, u16 sizeParm
|
|||||||
xRetSize = xRc & 0xFFFF;
|
xRetSize = xRc & 0xFFFF;
|
||||||
return xRetSize;
|
return xRetSize;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
|
|
||||||
static inline int HvCallPci_getBusAdapterVpd(u16 busNumParm, u64 destParm, u16 sizeParm)
|
static inline int HvCallPci_getBusAdapterVpd(u16 busNumParm, u64 destParm,
|
||||||
|
u16 sizeParm)
|
||||||
{
|
{
|
||||||
int xRetSize;
|
int xRetSize;
|
||||||
u64 xRc = HvCall4(HvCallPciGetCardVpd, busNumParm, destParm, sizeParm, HvCallPci_BusAdapterVpd);
|
u64 xRc = HvCall4(HvCallPciGetCardVpd, busNumParm, destParm, sizeParm, HvCallPci_BusAdapterVpd);
|
||||||
@ -669,5 +619,5 @@ static inline int HvCallPci_getBusAdapterVpd(u16 busNumParm, u64 destParm, u16 s
|
|||||||
xRetSize = xRc & 0xFFFF;
|
xRetSize = xRc & 0xFFFF;
|
||||||
return xRetSize;
|
return xRetSize;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
#endif /* _HVCALLPCI_H */
|
#endif /* _HVCALLPCI_H */
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
/*
|
/*
|
||||||
* HvCallSc.h
|
* HvCallSc.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
@ -30,22 +30,22 @@
|
|||||||
#define HvCallSm 0x8007000000000000ul
|
#define HvCallSm 0x8007000000000000ul
|
||||||
#define HvCallXm 0x8009000000000000ul
|
#define HvCallXm 0x8009000000000000ul
|
||||||
|
|
||||||
u64 HvCall0( u64 );
|
u64 HvCall0(u64);
|
||||||
u64 HvCall1( u64, u64 );
|
u64 HvCall1(u64, u64);
|
||||||
u64 HvCall2( u64, u64, u64 );
|
u64 HvCall2(u64, u64, u64);
|
||||||
u64 HvCall3( u64, u64, u64, u64 );
|
u64 HvCall3(u64, u64, u64, u64);
|
||||||
u64 HvCall4( u64, u64, u64, u64, u64 );
|
u64 HvCall4(u64, u64, u64, u64, u64);
|
||||||
u64 HvCall5( u64, u64, u64, u64, u64, u64 );
|
u64 HvCall5(u64, u64, u64, u64, u64, u64);
|
||||||
u64 HvCall6( u64, u64, u64, u64, u64, u64, u64 );
|
u64 HvCall6(u64, u64, u64, u64, u64, u64, u64);
|
||||||
u64 HvCall7( u64, u64, u64, u64, u64, u64, u64, u64 );
|
u64 HvCall7(u64, u64, u64, u64, u64, u64, u64, u64);
|
||||||
|
|
||||||
u64 HvCall0Ret16( u64, void * );
|
u64 HvCall0Ret16(u64, void *);
|
||||||
u64 HvCall1Ret16( u64, void *, u64 );
|
u64 HvCall1Ret16(u64, void *, u64);
|
||||||
u64 HvCall2Ret16( u64, void *, u64, u64 );
|
u64 HvCall2Ret16(u64, void *, u64, u64);
|
||||||
u64 HvCall3Ret16( u64, void *, u64, u64, u64 );
|
u64 HvCall3Ret16(u64, void *, u64, u64, u64);
|
||||||
u64 HvCall4Ret16( u64, void *, u64, u64, u64, u64 );
|
u64 HvCall4Ret16(u64, void *, u64, u64, u64, u64);
|
||||||
u64 HvCall5Ret16( u64, void *, u64, u64, u64, u64, u64 );
|
u64 HvCall5Ret16(u64, void *, u64, u64, u64, u64, u64);
|
||||||
u64 HvCall6Ret16( u64, void *, u64, u64, u64, u64, u64, u64 );
|
u64 HvCall6Ret16(u64, void *, u64, u64, u64, u64, u64, u64);
|
||||||
u64 HvCall7Ret16( u64, void *, u64, u64 ,u64 ,u64 ,u64 ,u64 ,u64 );
|
u64 HvCall7Ret16(u64, void *, u64, u64 ,u64 ,u64 ,u64 ,u64 ,u64);
|
||||||
|
|
||||||
#endif /* _HVCALLSC_H */
|
#endif /* _HVCALLSC_H */
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
/*
|
/*
|
||||||
* HvCallSm.h
|
* HvCallSm.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
@ -19,34 +19,23 @@
|
|||||||
#ifndef _HVCALLSM_H
|
#ifndef _HVCALLSM_H
|
||||||
#define _HVCALLSM_H
|
#define _HVCALLSM_H
|
||||||
|
|
||||||
//============================================================================
|
/*
|
||||||
//
|
* This file contains the "hypervisor call" interface which is used to
|
||||||
// This file contains the "hypervisor call" interface which is used to
|
* drive the hypervisor from the OS.
|
||||||
// drive the hypervisor from the OS.
|
*/
|
||||||
//
|
|
||||||
//============================================================================
|
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
// Standard Includes
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
#include <asm/iSeries/HvCallSc.h>
|
#include <asm/iSeries/HvCallSc.h>
|
||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Constants
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#define HvCallSmGet64BitsOfAccessMap HvCallSm + 11
|
#define HvCallSmGet64BitsOfAccessMap HvCallSm + 11
|
||||||
|
|
||||||
|
static inline u64 HvCallSm_get64BitsOfAccessMap(HvLpIndex lpIndex,
|
||||||
//============================================================================
|
u64 indexIntoBitMap)
|
||||||
static inline u64 HvCallSm_get64BitsOfAccessMap(
|
|
||||||
HvLpIndex lpIndex, u64 indexIntoBitMap )
|
|
||||||
{
|
{
|
||||||
u64 retval = HvCall2(HvCallSmGet64BitsOfAccessMap, lpIndex,
|
u64 retval = HvCall2(HvCallSmGet64BitsOfAccessMap, lpIndex,
|
||||||
indexIntoBitMap );
|
indexIntoBitMap );
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
#endif /* _HVCALLSM_H */
|
#endif /* _HVCALLSM_H */
|
||||||
|
@ -1,30 +1,13 @@
|
|||||||
//============================================================================
|
/*
|
||||||
// Header File Id
|
* This file contains the "hypervisor call" interface which is used to
|
||||||
// Name______________: HvCallXm.H
|
* drive the hypervisor from SLIC.
|
||||||
//
|
*/
|
||||||
// Description_______:
|
|
||||||
//
|
|
||||||
// This file contains the "hypervisor call" interface which is used to
|
|
||||||
// drive the hypervisor from SLIC.
|
|
||||||
//
|
|
||||||
//============================================================================
|
|
||||||
#ifndef _HVCALLXM_H
|
#ifndef _HVCALLXM_H
|
||||||
#define _HVCALLXM_H
|
#define _HVCALLXM_H
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
// Forward declarations
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
// Standard Includes
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
#include <asm/iSeries/HvCallSc.h>
|
#include <asm/iSeries/HvCallSc.h>
|
||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Constants
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#define HvCallXmGetTceTableParms HvCallXm + 0
|
#define HvCallXmGetTceTableParms HvCallXm + 0
|
||||||
#define HvCallXmTestBus HvCallXm + 1
|
#define HvCallXmTestBus HvCallXm + 1
|
||||||
#define HvCallXmConnectBusUnit HvCallXm + 2
|
#define HvCallXmConnectBusUnit HvCallXm + 2
|
||||||
@ -33,47 +16,46 @@
|
|||||||
#define HvCallXmSetTce HvCallXm + 11
|
#define HvCallXmSetTce HvCallXm + 11
|
||||||
#define HvCallXmSetTces HvCallXm + 13
|
#define HvCallXmSetTces HvCallXm + 13
|
||||||
|
|
||||||
|
static inline void HvCallXm_getTceTableParms(u64 cb)
|
||||||
|
|
||||||
//============================================================================
|
|
||||||
static inline void HvCallXm_getTceTableParms(u64 cb)
|
|
||||||
{
|
{
|
||||||
HvCall1(HvCallXmGetTceTableParms, cb);
|
HvCall1(HvCallXmGetTceTableParms, cb);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallXm_setTce(u64 tceTableToken, u64 tceOffset, u64 tce)
|
static inline u64 HvCallXm_setTce(u64 tceTableToken, u64 tceOffset, u64 tce)
|
||||||
{
|
{
|
||||||
u64 retval = HvCall3(HvCallXmSetTce, tceTableToken, tceOffset, tce );
|
u64 retval = HvCall3(HvCallXmSetTce, tceTableToken, tceOffset, tce );
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
//============================================================================
|
|
||||||
static inline u64 HvCallXm_setTces(u64 tceTableToken, u64 tceOffset, u64 numTces, u64 tce1, u64 tce2, u64 tce3, u64 tce4)
|
static inline u64 HvCallXm_setTces(u64 tceTableToken, u64 tceOffset,
|
||||||
{
|
u64 numTces, u64 tce1, u64 tce2, u64 tce3, u64 tce4)
|
||||||
|
{
|
||||||
u64 retval = HvCall7(HvCallXmSetTces, tceTableToken, tceOffset, numTces,
|
u64 retval = HvCall7(HvCallXmSetTces, tceTableToken, tceOffset, numTces,
|
||||||
tce1, tce2, tce3, tce4 );
|
tce1, tce2, tce3, tce4 );
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
//=============================================================================
|
|
||||||
static inline u64 HvCallXm_testBus(u16 busNumber)
|
static inline u64 HvCallXm_testBus(u16 busNumber)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall1(HvCallXmTestBus, busNumber);
|
u64 retVal = HvCall1(HvCallXmTestBus, busNumber);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//=====================================================================================
|
|
||||||
static inline u64 HvCallXm_testBusUnit(u16 busNumber, u8 subBusNumber, u8 deviceId)
|
static inline u64 HvCallXm_testBusUnit(u16 busNumber, u8 subBusNumber,
|
||||||
|
u8 deviceId)
|
||||||
{
|
{
|
||||||
u64 busUnitNumber = (subBusNumber << 8) | deviceId;
|
u64 busUnitNumber = (subBusNumber << 8) | deviceId;
|
||||||
u64 retVal = HvCall2(HvCallXmTestBusUnit, busNumber, busUnitNumber);
|
u64 retVal = HvCall2(HvCallXmTestBusUnit, busNumber, busUnitNumber);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//=====================================================================================
|
|
||||||
static inline u64 HvCallXm_connectBusUnit(u16 busNumber, u8 subBusNumber, u8 deviceId,
|
static inline u64 HvCallXm_connectBusUnit(u16 busNumber, u8 subBusNumber,
|
||||||
u64 interruptToken)
|
u8 deviceId, u64 interruptToken)
|
||||||
{
|
{
|
||||||
u64 busUnitNumber = (subBusNumber << 8) | deviceId;
|
u64 busUnitNumber = (subBusNumber << 8) | deviceId;
|
||||||
u64 queueIndex = 0; // HvLpConfig::mapDsaToQueueIndex(HvLpDSA(busNumber, xBoard, xCard));
|
u64 queueIndex = 0; // HvLpConfig::mapDsaToQueueIndex(HvLpDSA(busNumber, xBoard, xCard));
|
||||||
@ -83,13 +65,12 @@ static inline u64 HvCallXm_connectBusUnit(u16 busNumber, u8 subBusNumber, u8 dev
|
|||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//=====================================================================================
|
|
||||||
static inline u64 HvCallXm_loadTod(void)
|
static inline u64 HvCallXm_loadTod(void)
|
||||||
{
|
{
|
||||||
u64 retVal = HvCall0(HvCallXmLoadTod);
|
u64 retVal = HvCall0(HvCallXmLoadTod);
|
||||||
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
// getPaca()->adjustHmtForNoOfSpinLocksHeld();
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
//=====================================================================================
|
|
||||||
|
|
||||||
#endif /* _HVCALLXM_H */
|
#endif /* _HVCALLXM_H */
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
/*
|
/*
|
||||||
* HvLpConfig.h
|
* HvLpConfig.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
@ -19,262 +19,285 @@
|
|||||||
#ifndef _HVLPCONFIG_H
|
#ifndef _HVLPCONFIG_H
|
||||||
#define _HVLPCONFIG_H
|
#define _HVLPCONFIG_H
|
||||||
|
|
||||||
//===========================================================================
|
/*
|
||||||
//
|
* This file contains the interface to the LPAR configuration data
|
||||||
// This file contains the interface to the LPAR configuration data
|
* to determine which resources should be allocated to each partition.
|
||||||
// to determine which resources should be allocated to each partition.
|
*/
|
||||||
//
|
|
||||||
//===========================================================================
|
|
||||||
|
|
||||||
#include <asm/iSeries/HvCallCfg.h>
|
#include <asm/iSeries/HvCallCfg.h>
|
||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
#include <asm/iSeries/ItLpNaca.h>
|
#include <asm/iSeries/ItLpNaca.h>
|
||||||
#include <asm/iSeries/LparData.h>
|
#include <asm/iSeries/LparData.h>
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
// Constants
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
|
|
||||||
extern HvLpIndex HvLpConfig_getLpIndex_outline(void);
|
extern HvLpIndex HvLpConfig_getLpIndex_outline(void);
|
||||||
|
|
||||||
//===================================================================
|
|
||||||
static inline HvLpIndex HvLpConfig_getLpIndex(void)
|
static inline HvLpIndex HvLpConfig_getLpIndex(void)
|
||||||
{
|
{
|
||||||
return itLpNaca.xLpIndex;
|
return itLpNaca.xLpIndex;
|
||||||
}
|
}
|
||||||
//===================================================================
|
|
||||||
static inline HvLpIndex HvLpConfig_getPrimaryLpIndex(void)
|
static inline HvLpIndex HvLpConfig_getPrimaryLpIndex(void)
|
||||||
{
|
{
|
||||||
return itLpNaca.xPrimaryLpIndex;
|
return itLpNaca.xPrimaryLpIndex;
|
||||||
}
|
}
|
||||||
//=================================================================
|
|
||||||
static inline HvLpIndex HvLpConfig_getLps(void)
|
static inline HvLpIndex HvLpConfig_getLps(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getLps();
|
return HvCallCfg_getLps();
|
||||||
}
|
}
|
||||||
//=================================================================
|
|
||||||
static inline HvLpIndexMap HvLpConfig_getActiveLpMap(void)
|
static inline HvLpIndexMap HvLpConfig_getActiveLpMap(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getActiveLpMap();
|
return HvCallCfg_getActiveLpMap();
|
||||||
}
|
}
|
||||||
//=================================================================
|
|
||||||
static inline u64 HvLpConfig_getSystemMsMegs(void)
|
static inline u64 HvLpConfig_getSystemMsMegs(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSystemMsChunks() / HVCHUNKSPERMEG;
|
return HvCallCfg_getSystemMsChunks() / HVCHUNKSPERMEG;
|
||||||
}
|
}
|
||||||
//=================================================================
|
|
||||||
static inline u64 HvLpConfig_getSystemMsChunks(void)
|
static inline u64 HvLpConfig_getSystemMsChunks(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSystemMsChunks();
|
return HvCallCfg_getSystemMsChunks();
|
||||||
}
|
}
|
||||||
//=================================================================
|
|
||||||
static inline u64 HvLpConfig_getSystemMsPages(void)
|
static inline u64 HvLpConfig_getSystemMsPages(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSystemMsChunks() * HVPAGESPERCHUNK;
|
return HvCallCfg_getSystemMsChunks() * HVPAGESPERCHUNK;
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getMsMegs(void)
|
static inline u64 HvLpConfig_getMsMegs(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Cur) / HVCHUNKSPERMEG;
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Cur)
|
||||||
|
/ HVCHUNKSPERMEG;
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getMsChunks(void)
|
static inline u64 HvLpConfig_getMsChunks(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Cur);
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Cur);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getMsPages(void)
|
static inline u64 HvLpConfig_getMsPages(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Cur) * HVPAGESPERCHUNK;
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Cur)
|
||||||
|
* HVPAGESPERCHUNK;
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getMinMsMegs(void)
|
static inline u64 HvLpConfig_getMinMsMegs(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Min) / HVCHUNKSPERMEG;
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Min)
|
||||||
|
/ HVCHUNKSPERMEG;
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getMinMsChunks(void)
|
static inline u64 HvLpConfig_getMinMsChunks(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Min);
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Min);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getMinMsPages(void)
|
static inline u64 HvLpConfig_getMinMsPages(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Min) * HVPAGESPERCHUNK;
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Min)
|
||||||
|
* HVPAGESPERCHUNK;
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getMinRuntimeMsMegs(void)
|
static inline u64 HvLpConfig_getMinRuntimeMsMegs(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMinRuntimeMsChunks(HvLpConfig_getLpIndex()) / HVCHUNKSPERMEG;
|
return HvCallCfg_getMinRuntimeMsChunks(HvLpConfig_getLpIndex())
|
||||||
|
/ HVCHUNKSPERMEG;
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMinRuntimeMsChunks(void)
|
static inline u64 HvLpConfig_getMinRuntimeMsChunks(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMinRuntimeMsChunks(HvLpConfig_getLpIndex());
|
return HvCallCfg_getMinRuntimeMsChunks(HvLpConfig_getLpIndex());
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMinRuntimeMsPages(void)
|
static inline u64 HvLpConfig_getMinRuntimeMsPages(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMinRuntimeMsChunks(HvLpConfig_getLpIndex()) * HVPAGESPERCHUNK;
|
return HvCallCfg_getMinRuntimeMsChunks(HvLpConfig_getLpIndex())
|
||||||
|
* HVPAGESPERCHUNK;
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMaxMsMegs(void)
|
static inline u64 HvLpConfig_getMaxMsMegs(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Max) / HVCHUNKSPERMEG;
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Max)
|
||||||
|
/ HVCHUNKSPERMEG;
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMaxMsChunks(void)
|
static inline u64 HvLpConfig_getMaxMsChunks(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Max);
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Max);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMaxMsPages(void)
|
static inline u64 HvLpConfig_getMaxMsPages(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Max) * HVPAGESPERCHUNK;
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Max)
|
||||||
|
* HVPAGESPERCHUNK;
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getInitMsMegs(void)
|
static inline u64 HvLpConfig_getInitMsMegs(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Init) / HVCHUNKSPERMEG;
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Init)
|
||||||
|
/ HVCHUNKSPERMEG;
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getInitMsChunks(void)
|
static inline u64 HvLpConfig_getInitMsChunks(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Init);
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Init);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getInitMsPages(void)
|
static inline u64 HvLpConfig_getInitMsPages(void)
|
||||||
{ return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(),HvCallCfg_Init) * HVPAGESPERCHUNK;
|
{
|
||||||
|
return HvCallCfg_getMsChunks(HvLpConfig_getLpIndex(), HvCallCfg_Init)
|
||||||
|
* HVPAGESPERCHUNK;
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getSystemPhysicalProcessors(void)
|
static inline u64 HvLpConfig_getSystemPhysicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSystemPhysicalProcessors();
|
return HvCallCfg_getSystemPhysicalProcessors();
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getSystemLogicalProcessors(void)
|
static inline u64 HvLpConfig_getSystemLogicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSystemPhysicalProcessors() * (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
return HvCallCfg_getSystemPhysicalProcessors()
|
||||||
|
* (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getNumProcsInSharedPool(HvLpSharedPoolIndex sPI)
|
static inline u64 HvLpConfig_getNumProcsInSharedPool(HvLpSharedPoolIndex sPI)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getNumProcsInSharedPool(sPI);
|
return HvCallCfg_getNumProcsInSharedPool(sPI);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getPhysicalProcessors(void)
|
static inline u64 HvLpConfig_getPhysicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Cur);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Cur);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getLogicalProcessors(void)
|
static inline u64 HvLpConfig_getLogicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Cur) * (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Cur)
|
||||||
|
* (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline HvLpSharedPoolIndex HvLpConfig_getSharedPoolIndex(void)
|
static inline HvLpSharedPoolIndex HvLpConfig_getSharedPoolIndex(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSharedPoolIndex(HvLpConfig_getLpIndex());
|
return HvCallCfg_getSharedPoolIndex(HvLpConfig_getLpIndex());
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getSharedProcUnits(void)
|
static inline u64 HvLpConfig_getSharedProcUnits(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSharedProcUnits(HvLpConfig_getLpIndex(),HvCallCfg_Cur);
|
return HvCallCfg_getSharedProcUnits(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Cur);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMinSharedProcUnits(void)
|
static inline u64 HvLpConfig_getMinSharedProcUnits(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSharedProcUnits(HvLpConfig_getLpIndex(),HvCallCfg_Min);
|
return HvCallCfg_getSharedProcUnits(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Min);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMaxSharedProcUnits(void)
|
static inline u64 HvLpConfig_getMaxSharedProcUnits(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getSharedProcUnits(HvLpConfig_getLpIndex(),HvCallCfg_Max);
|
return HvCallCfg_getSharedProcUnits(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Max);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMinPhysicalProcessors(void)
|
static inline u64 HvLpConfig_getMinPhysicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Min);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Min);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMinLogicalProcessors(void)
|
static inline u64 HvLpConfig_getMinLogicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Min) * (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Min)
|
||||||
|
* (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMaxPhysicalProcessors(void)
|
static inline u64 HvLpConfig_getMaxPhysicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Max);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Max);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getMaxLogicalProcessors(void)
|
static inline u64 HvLpConfig_getMaxLogicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Max) * (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Max)
|
||||||
|
* (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getInitPhysicalProcessors(void)
|
static inline u64 HvLpConfig_getInitPhysicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Init);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Init);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline u64 HvLpConfig_getInitLogicalProcessors(void)
|
static inline u64 HvLpConfig_getInitLogicalProcessors(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),HvCallCfg_Init) * (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
return HvCallCfg_getPhysicalProcessors(HvLpConfig_getLpIndex(),
|
||||||
|
HvCallCfg_Init)
|
||||||
|
* (/*getPaca()->getSecondaryThreadCount() +*/ 1);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline HvLpVirtualLanIndexMap HvLpConfig_getVirtualLanIndexMap(void)
|
static inline HvLpVirtualLanIndexMap HvLpConfig_getVirtualLanIndexMap(void)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getVirtualLanIndexMap(HvLpConfig_getLpIndex_outline());
|
return HvCallCfg_getVirtualLanIndexMap(HvLpConfig_getLpIndex_outline());
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline HvLpVirtualLanIndexMap HvLpConfig_getVirtualLanIndexMapForLp(HvLpIndex lp)
|
static inline HvLpVirtualLanIndexMap HvLpConfig_getVirtualLanIndexMapForLp(
|
||||||
|
HvLpIndex lp)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getVirtualLanIndexMap(lp);
|
return HvCallCfg_getVirtualLanIndexMap(lp);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline HvLpIndex HvLpConfig_getBusOwner(HvBusNumber busNumber)
|
static inline HvLpIndex HvLpConfig_getBusOwner(HvBusNumber busNumber)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getBusOwner(busNumber);
|
return HvCallCfg_getBusOwner(busNumber);
|
||||||
}
|
}
|
||||||
//===============================================================
|
|
||||||
static inline int HvLpConfig_isBusDedicated(HvBusNumber busNumber)
|
static inline int HvLpConfig_isBusDedicated(HvBusNumber busNumber)
|
||||||
{
|
{
|
||||||
return HvCallCfg_isBusDedicated(busNumber);
|
return HvCallCfg_isBusDedicated(busNumber);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline HvLpIndexMap HvLpConfig_getBusAllocation(HvBusNumber busNumber)
|
static inline HvLpIndexMap HvLpConfig_getBusAllocation(HvBusNumber busNumber)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getBusAllocation(busNumber);
|
return HvCallCfg_getBusAllocation(busNumber);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
// returns the absolute real address of the load area
|
/* returns the absolute real address of the load area */
|
||||||
static inline u64 HvLpConfig_getLoadAddress(void)
|
static inline u64 HvLpConfig_getLoadAddress(void)
|
||||||
{
|
{
|
||||||
return itLpNaca.xLoadAreaAddr & 0x7fffffffffffffff;
|
return itLpNaca.xLoadAreaAddr & 0x7fffffffffffffff;
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline u64 HvLpConfig_getLoadPages(void)
|
static inline u64 HvLpConfig_getLoadPages(void)
|
||||||
{
|
{
|
||||||
return itLpNaca.xLoadAreaChunks * HVPAGESPERCHUNK;
|
return itLpNaca.xLoadAreaChunks * HVPAGESPERCHUNK;
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline int HvLpConfig_isBusOwnedByThisLp(HvBusNumber busNumber)
|
static inline int HvLpConfig_isBusOwnedByThisLp(HvBusNumber busNumber)
|
||||||
{
|
{
|
||||||
HvLpIndex busOwner = HvLpConfig_getBusOwner(busNumber);
|
HvLpIndex busOwner = HvLpConfig_getBusOwner(busNumber);
|
||||||
return (busOwner == HvLpConfig_getLpIndex());
|
return (busOwner == HvLpConfig_getLpIndex());
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline int HvLpConfig_doLpsCommunicateOnVirtualLan(HvLpIndex lp1, HvLpIndex lp2)
|
static inline int HvLpConfig_doLpsCommunicateOnVirtualLan(HvLpIndex lp1,
|
||||||
|
HvLpIndex lp2)
|
||||||
{
|
{
|
||||||
HvLpVirtualLanIndexMap virtualLanIndexMap1 = HvCallCfg_getVirtualLanIndexMap( lp1 );
|
HvLpVirtualLanIndexMap virtualLanIndexMap1 =
|
||||||
HvLpVirtualLanIndexMap virtualLanIndexMap2 = HvCallCfg_getVirtualLanIndexMap( lp2 );
|
HvCallCfg_getVirtualLanIndexMap(lp1);
|
||||||
|
HvLpVirtualLanIndexMap virtualLanIndexMap2 =
|
||||||
|
HvCallCfg_getVirtualLanIndexMap(lp2);
|
||||||
return ((virtualLanIndexMap1 & virtualLanIndexMap2) != 0);
|
return ((virtualLanIndexMap1 & virtualLanIndexMap2) != 0);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
static inline HvLpIndex HvLpConfig_getHostingLpIndex(HvLpIndex lp)
|
static inline HvLpIndex HvLpConfig_getHostingLpIndex(HvLpIndex lp)
|
||||||
{
|
{
|
||||||
return HvCallCfg_getHostingLpIndex(lp);
|
return HvCallCfg_getHostingLpIndex(lp);
|
||||||
}
|
}
|
||||||
//================================================================
|
|
||||||
|
|
||||||
#endif /* _HVLPCONFIG_H */
|
#endif /* _HVLPCONFIG_H */
|
||||||
|
@ -1,27 +1,24 @@
|
|||||||
/*
|
/*
|
||||||
* HvLpEvent.h
|
* HvLpEvent.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//======================================================================
|
/* This file contains the class for HV events in the system. */
|
||||||
//
|
|
||||||
// This file contains the class for HV events in the system.
|
|
||||||
//
|
|
||||||
//=====================================================================
|
|
||||||
#ifndef _HVLPEVENT_H
|
#ifndef _HVLPEVENT_H
|
||||||
#define _HVLPEVENT_H
|
#define _HVLPEVENT_H
|
||||||
|
|
||||||
@ -30,69 +27,70 @@
|
|||||||
#include <asm/iSeries/HvTypes.h>
|
#include <asm/iSeries/HvTypes.h>
|
||||||
#include <asm/iSeries/HvCallEvent.h>
|
#include <asm/iSeries/HvCallEvent.h>
|
||||||
|
|
||||||
//=====================================================================
|
/*
|
||||||
//
|
* HvLpEvent is the structure for Lp Event messages passed between
|
||||||
// HvLpEvent is the structure for Lp Event messages passed between
|
* partitions through PLIC.
|
||||||
// partitions through PLIC.
|
*/
|
||||||
//
|
|
||||||
//=====================================================================
|
|
||||||
|
|
||||||
struct HvEventFlags
|
struct HvEventFlags {
|
||||||
{
|
u8 xValid:1; /* Indicates a valid request x00-x00 */
|
||||||
u8 xValid:1; // Indicates a valid request x00-x00
|
u8 xRsvd1:4; /* Reserved ... */
|
||||||
u8 xRsvd1:4; // Reserved ...
|
u8 xAckType:1; /* Immediate or deferred ... */
|
||||||
u8 xAckType:1; // Immediate or deferred ...
|
u8 xAckInd:1; /* Indicates if ACK required ... */
|
||||||
u8 xAckInd:1; // Indicates if ACK required ...
|
u8 xFunction:1; /* Interrupt or Acknowledge ... */
|
||||||
u8 xFunction:1; // Interrupt or Acknowledge ...
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
struct HvLpEvent
|
struct HvLpEvent {
|
||||||
{
|
struct HvEventFlags xFlags; /* Event flags x00-x00 */
|
||||||
struct HvEventFlags xFlags; // Event flags x00-x00
|
u8 xType; /* Type of message x01-x01 */
|
||||||
u8 xType; // Type of message x01-x01
|
u16 xSubtype; /* Subtype for event x02-x03 */
|
||||||
u16 xSubtype; // Subtype for event x02-x03
|
u8 xSourceLp; /* Source LP x04-x04 */
|
||||||
u8 xSourceLp; // Source LP x04-x04
|
u8 xTargetLp; /* Target LP x05-x05 */
|
||||||
u8 xTargetLp; // Target LP x05-x05
|
u8 xSizeMinus1; /* Size of Derived class - 1 x06-x06 */
|
||||||
u8 xSizeMinus1; // Size of Derived class - 1 x06-x06
|
u8 xRc; /* RC for Ack flows x07-x07 */
|
||||||
u8 xRc; // RC for Ack flows x07-x07
|
u16 xSourceInstanceId; /* Source sides instance id x08-x09 */
|
||||||
u16 xSourceInstanceId; // Source sides instance id x08-x09
|
u16 xTargetInstanceId; /* Target sides instance id x0A-x0B */
|
||||||
u16 xTargetInstanceId; // Target sides instance id x0A-x0B
|
|
||||||
union {
|
union {
|
||||||
u32 xSubtypeData; // Data usable by the subtype x0C-x0F
|
u32 xSubtypeData; /* Data usable by the subtype x0C-x0F */
|
||||||
u16 xSubtypeDataShort[2]; // Data as 2 shorts
|
u16 xSubtypeDataShort[2]; /* Data as 2 shorts */
|
||||||
u8 xSubtypeDataChar[4]; // Data as 4 chars
|
u8 xSubtypeDataChar[4]; /* Data as 4 chars */
|
||||||
} x;
|
} x;
|
||||||
|
|
||||||
u64 xCorrelationToken; // Unique value for source/type x10-x17
|
u64 xCorrelationToken; /* Unique value for source/type x10-x17 */
|
||||||
};
|
};
|
||||||
|
|
||||||
// Lp Event handler function
|
|
||||||
typedef void (*LpEventHandler)(struct HvLpEvent *, struct pt_regs *);
|
typedef void (*LpEventHandler)(struct HvLpEvent *, struct pt_regs *);
|
||||||
|
|
||||||
// Register a handler for an event type
|
/* Register a handler for an event type - returns 0 on success */
|
||||||
// returns 0 on success
|
extern int HvLpEvent_registerHandler(HvLpEvent_Type eventType,
|
||||||
extern int HvLpEvent_registerHandler( HvLpEvent_Type eventType, LpEventHandler hdlr);
|
LpEventHandler hdlr);
|
||||||
|
|
||||||
// Unregister a handler for an event type
|
/*
|
||||||
// This call will sleep until the handler being removed is guaranteed to
|
* Unregister a handler for an event type
|
||||||
// be no longer executing on any CPU. Do not call with locks held.
|
*
|
||||||
//
|
* This call will sleep until the handler being removed is guaranteed to
|
||||||
// returns 0 on success
|
* be no longer executing on any CPU. Do not call with locks held.
|
||||||
// Unregister will fail if there are any paths open for the type
|
*
|
||||||
extern int HvLpEvent_unregisterHandler( HvLpEvent_Type eventType );
|
* returns 0 on success
|
||||||
|
* Unregister will fail if there are any paths open for the type
|
||||||
|
*/
|
||||||
|
extern int HvLpEvent_unregisterHandler(HvLpEvent_Type eventType);
|
||||||
|
|
||||||
// Open an Lp Event Path for an event type
|
/*
|
||||||
// returns 0 on success
|
* Open an Lp Event Path for an event type
|
||||||
// openPath will fail if there is no handler registered for the event type.
|
* returns 0 on success
|
||||||
// The lpIndex specified is the partition index for the target partition
|
* openPath will fail if there is no handler registered for the event type.
|
||||||
// (for VirtualIo, VirtualLan and SessionMgr) other types specify zero)
|
* The lpIndex specified is the partition index for the target partition
|
||||||
extern int HvLpEvent_openPath( HvLpEvent_Type eventType, HvLpIndex lpIndex );
|
* (for VirtualIo, VirtualLan and SessionMgr) other types specify zero)
|
||||||
|
*/
|
||||||
|
extern int HvLpEvent_openPath(HvLpEvent_Type eventType, HvLpIndex lpIndex);
|
||||||
|
|
||||||
|
/*
|
||||||
// Close an Lp Event Path for a type and partition
|
* Close an Lp Event Path for a type and partition
|
||||||
// returns 0 on sucess
|
* returns 0 on sucess
|
||||||
extern int HvLpEvent_closePath( HvLpEvent_Type eventType, HvLpIndex lpIndex );
|
*/
|
||||||
|
extern int HvLpEvent_closePath(HvLpEvent_Type eventType, HvLpIndex lpIndex);
|
||||||
|
|
||||||
#define HvLpEvent_Type_Hypervisor 0
|
#define HvLpEvent_Type_Hypervisor 0
|
||||||
#define HvLpEvent_Type_MachineFac 1
|
#define HvLpEvent_Type_MachineFac 1
|
||||||
@ -141,4 +139,4 @@ extern int HvLpEvent_closePath( HvLpEvent_Type eventType, HvLpIndex lpIndex );
|
|||||||
#define HvLpDma_Rc_InvalidAddress 4
|
#define HvLpDma_Rc_InvalidAddress 4
|
||||||
#define HvLpDma_Rc_InvalidLength 5
|
#define HvLpDma_Rc_InvalidLength 5
|
||||||
|
|
||||||
#endif // _HVLPEVENT_H
|
#endif /* _HVLPEVENT_H */
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
/*
|
/*
|
||||||
* HvReleaseData.h
|
* HvReleaseData.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
@ -19,47 +19,43 @@
|
|||||||
#ifndef _HVRELEASEDATA_H
|
#ifndef _HVRELEASEDATA_H
|
||||||
#define _HVRELEASEDATA_H
|
#define _HVRELEASEDATA_H
|
||||||
|
|
||||||
//=============================================================================
|
/*
|
||||||
//
|
* This control block contains the critical information about the
|
||||||
// This control block contains the critical information about the
|
* release so that it can be changed in the future (ie, the virtual
|
||||||
// release so that it can be changed in the future (ie, the virtual
|
* address of the OS's NACA).
|
||||||
// address of the OS's NACA).
|
*/
|
||||||
//
|
|
||||||
#include <asm/types.h>
|
#include <asm/types.h>
|
||||||
#include <asm/naca.h>
|
#include <asm/naca.h>
|
||||||
|
|
||||||
//=============================================================================
|
/*
|
||||||
//
|
* When we IPL a secondary partition, we will check if if the
|
||||||
// When we IPL a secondary partition, we will check if if the
|
* secondary xMinPlicVrmIndex > the primary xVrmIndex.
|
||||||
// secondary xMinPlicVrmIndex > the primary xVrmIndex.
|
* If it is then this tells PLIC that this secondary is not
|
||||||
// If it is then this tells PLIC that this secondary is not
|
* supported running on this "old" of a level of PLIC.
|
||||||
// supported running on this "old" of a level of PLIC.
|
*
|
||||||
//
|
* Likewise, we will compare the primary xMinSlicVrmIndex to
|
||||||
// Likewise, we will compare the primary xMinSlicVrmIndex to
|
* the secondary xVrmIndex.
|
||||||
// the secondary xVrmIndex.
|
* If the primary xMinSlicVrmDelta > secondary xVrmDelta then we
|
||||||
// If the primary xMinSlicVrmDelta > secondary xVrmDelta then we
|
* know that this PLIC does not support running an OS "that old".
|
||||||
// know that this PLIC does not support running an OS "that old".
|
*/
|
||||||
//
|
|
||||||
//=============================================================================
|
|
||||||
|
|
||||||
struct HvReleaseData
|
struct HvReleaseData {
|
||||||
{
|
u32 xDesc; /* Descriptor "HvRD" ebcdic x00-x03 */
|
||||||
u32 xDesc; // Descriptor "HvRD" ebcdic x00-x03
|
u16 xSize; /* Size of this control block x04-x05 */
|
||||||
u16 xSize; // Size of this control block x04-x05
|
u16 xVpdAreasPtrOffset; /* Offset in NACA of ItVpdAreas x06-x07 */
|
||||||
u16 xVpdAreasPtrOffset; // Offset in NACA of ItVpdAreas x06-x07
|
struct naca_struct *xSlicNacaAddr; /* Virt addr of SLIC NACA x08-x0F */
|
||||||
struct naca_struct * xSlicNacaAddr; // Virt addr of SLIC NACA x08-x0F
|
u32 xMsNucDataOffset; /* Offset of Linux Mapping Data x10-x13 */
|
||||||
u32 xMsNucDataOffset; // Offset of Linux Mapping Data x10-x13
|
u32 xRsvd1; /* Reserved x14-x17 */
|
||||||
u32 xRsvd1; // Reserved x14-x17
|
u16 xTagsMode:1; /* 0 == tags active, 1 == tags inactive */
|
||||||
u16 xTagsMode:1; // 0 == tags active, 1 == tags inactive
|
u16 xAddressSize:1; /* 0 == 64-bit, 1 == 32-bit */
|
||||||
u16 xAddressSize:1; // 0 == 64-bit, 1 == 32-bit
|
u16 xNoSharedProcs:1; /* 0 == shared procs, 1 == no shared */
|
||||||
u16 xNoSharedProcs:1; // 0 == shared procs, 1 == no shared
|
u16 xNoHMT:1; /* 0 == allow HMT, 1 == no HMT */
|
||||||
u16 xNoHMT:1; // 0 == allow HMT, 1 == no HMT
|
u16 xRsvd2:12; /* Reserved x18-x19 */
|
||||||
u16 xRsvd2:12; // Reserved x18-x19
|
u16 xVrmIndex; /* VRM Index of OS image x1A-x1B */
|
||||||
u16 xVrmIndex; // VRM Index of OS image x1A-x1B
|
u16 xMinSupportedPlicVrmIndex; /* Min PLIC level (soft) x1C-x1D */
|
||||||
u16 xMinSupportedPlicVrmIndex;// Min PLIC level (soft) x1C-x1D
|
u16 xMinCompatablePlicVrmIndex; /* Min PLIC levelP (hard) x1E-x1F */
|
||||||
u16 xMinCompatablePlicVrmIndex;// Min PLIC levelP (hard) x1E-x1F
|
char xVrmName[12]; /* Displayable name x20-x2B */
|
||||||
char xVrmName[12]; // Displayable name x20-x2B
|
char xRsvd3[20]; /* Reserved x2C-x3F */
|
||||||
char xRsvd3[20]; // Reserved x2C-x3F
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* _HVRELEASEDATA_H */
|
#endif /* _HVRELEASEDATA_H */
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
/*
|
/*
|
||||||
* HvTypes.h
|
* HvTypes.h
|
||||||
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
* Copyright (C) 2001 Mike Corrigan IBM Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
* (at your option) any later version.
|
* (at your option) any later version.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope that it will be useful,
|
* This program is distributed in the hope that it will be useful,
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
* GNU General Public License for more details.
|
* GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
@ -19,74 +19,62 @@
|
|||||||
#ifndef _HVTYPES_H
|
#ifndef _HVTYPES_H
|
||||||
#define _HVTYPES_H
|
#define _HVTYPES_H
|
||||||
|
|
||||||
//===========================================================================
|
/*
|
||||||
// Header File Id
|
* General typedefs for the hypervisor.
|
||||||
// Name______________: HvTypes.H
|
*/
|
||||||
//
|
|
||||||
// Description_______:
|
|
||||||
//
|
|
||||||
// General typedefs for the hypervisor.
|
|
||||||
//
|
|
||||||
// Declared Class(es):
|
|
||||||
//
|
|
||||||
//===========================================================================
|
|
||||||
|
|
||||||
#include <asm/types.h>
|
#include <asm/types.h>
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
// Typedefs
|
|
||||||
//-------------------------------------------------------------------
|
|
||||||
typedef u8 HvLpIndex;
|
typedef u8 HvLpIndex;
|
||||||
typedef u16 HvLpInstanceId;
|
typedef u16 HvLpInstanceId;
|
||||||
typedef u64 HvLpTOD;
|
typedef u64 HvLpTOD;
|
||||||
typedef u64 HvLpSystemSerialNum;
|
typedef u64 HvLpSystemSerialNum;
|
||||||
typedef u8 HvLpDeviceSerialNum[12];
|
typedef u8 HvLpDeviceSerialNum[12];
|
||||||
typedef u16 HvLpSanHwSet;
|
typedef u16 HvLpSanHwSet;
|
||||||
typedef u16 HvLpBus;
|
typedef u16 HvLpBus;
|
||||||
typedef u16 HvLpBoard;
|
typedef u16 HvLpBoard;
|
||||||
typedef u16 HvLpCard;
|
typedef u16 HvLpCard;
|
||||||
typedef u8 HvLpDeviceType[4];
|
typedef u8 HvLpDeviceType[4];
|
||||||
typedef u8 HvLpDeviceModel[3];
|
typedef u8 HvLpDeviceModel[3];
|
||||||
typedef u64 HvIoToken;
|
typedef u64 HvIoToken;
|
||||||
typedef u8 HvLpName[8];
|
typedef u8 HvLpName[8];
|
||||||
typedef u32 HvIoId;
|
typedef u32 HvIoId;
|
||||||
typedef u64 HvRealMemoryIndex;
|
typedef u64 HvRealMemoryIndex;
|
||||||
typedef u32 HvLpIndexMap; // Must hold HvMaxArchitectedLps bits!!!
|
typedef u32 HvLpIndexMap; /* Must hold HvMaxArchitectedLps bits!!! */
|
||||||
typedef u16 HvLpVrmIndex;
|
typedef u16 HvLpVrmIndex;
|
||||||
typedef u32 HvXmGenerationId;
|
typedef u32 HvXmGenerationId;
|
||||||
typedef u8 HvLpBusPool;
|
typedef u8 HvLpBusPool;
|
||||||
typedef u8 HvLpSharedPoolIndex;
|
typedef u8 HvLpSharedPoolIndex;
|
||||||
typedef u16 HvLpSharedProcUnitsX100;
|
typedef u16 HvLpSharedProcUnitsX100;
|
||||||
typedef u8 HvLpVirtualLanIndex;
|
typedef u8 HvLpVirtualLanIndex;
|
||||||
typedef u16 HvLpVirtualLanIndexMap; // Must hold HvMaxArchitectedVirtualLans bits!!!
|
typedef u16 HvLpVirtualLanIndexMap; /* Must hold HvMaxArchitectedVirtualLans bits!!! */
|
||||||
typedef u16 HvBusNumber; // Hypervisor Bus Number
|
typedef u16 HvBusNumber; /* Hypervisor Bus Number */
|
||||||
typedef u8 HvSubBusNumber; // Hypervisor SubBus Number
|
typedef u8 HvSubBusNumber; /* Hypervisor SubBus Number */
|
||||||
typedef u8 HvAgentId; // Hypervisor DevFn
|
typedef u8 HvAgentId; /* Hypervisor DevFn */
|
||||||
|
|
||||||
|
|
||||||
#define HVMAXARCHITECTEDLPS 32
|
#define HVMAXARCHITECTEDLPS 32
|
||||||
#define HVMAXARCHITECTEDVIRTUALLANS 16
|
#define HVMAXARCHITECTEDVIRTUALLANS 16
|
||||||
#define HVMAXARCHITECTEDVIRTUALDISKS 32
|
#define HVMAXARCHITECTEDVIRTUALDISKS 32
|
||||||
#define HVMAXARCHITECTEDVIRTUALCDROMS 8
|
#define HVMAXARCHITECTEDVIRTUALCDROMS 8
|
||||||
#define HVMAXARCHITECTEDVIRTUALTAPES 8
|
#define HVMAXARCHITECTEDVIRTUALTAPES 8
|
||||||
#define HVCHUNKSIZE 256 * 1024
|
#define HVCHUNKSIZE (256 * 1024)
|
||||||
#define HVPAGESIZE 4 * 1024
|
#define HVPAGESIZE (4 * 1024)
|
||||||
#define HVLPMINMEGSPRIMARY 256
|
#define HVLPMINMEGSPRIMARY 256
|
||||||
#define HVLPMINMEGSSECONDARY 64
|
#define HVLPMINMEGSSECONDARY 64
|
||||||
#define HVCHUNKSPERMEG 4
|
#define HVCHUNKSPERMEG 4
|
||||||
#define HVPAGESPERMEG 256
|
#define HVPAGESPERMEG 256
|
||||||
#define HVPAGESPERCHUNK 64
|
#define HVPAGESPERCHUNK 64
|
||||||
|
|
||||||
#define HvMaxArchitectedLps ((HvLpIndex)HVMAXARCHITECTEDLPS)
|
#define HvMaxArchitectedLps ((HvLpIndex)HVMAXARCHITECTEDLPS)
|
||||||
#define HvMaxArchitectedVirtualLans ((HvLpVirtualLanIndex)16)
|
#define HvMaxArchitectedVirtualLans ((HvLpVirtualLanIndex)16)
|
||||||
#define HvLpIndexInvalid ((HvLpIndex)0xff)
|
#define HvLpIndexInvalid ((HvLpIndex)0xff)
|
||||||
|
|
||||||
//--------------------------------------------------------------------
|
/*
|
||||||
// Enums for the sub-components under PLIC
|
* Enums for the sub-components under PLIC
|
||||||
// Used in HvCall and HvPrimaryCall
|
* Used in HvCall and HvPrimaryCall
|
||||||
//--------------------------------------------------------------------
|
*/
|
||||||
enum HvCallCompIds
|
enum HvCallCompIds {
|
||||||
{
|
|
||||||
HvCallCompId = 0,
|
HvCallCompId = 0,
|
||||||
HvCallCpuCtlsCompId = 1,
|
HvCallCpuCtlsCompId = 1,
|
||||||
HvCallCfgCompId = 2,
|
HvCallCfgCompId = 2,
|
||||||
@ -97,18 +85,18 @@ enum HvCallCompIds
|
|||||||
HvCallSmCompId = 7,
|
HvCallSmCompId = 7,
|
||||||
HvCallSpdCompId = 8,
|
HvCallSpdCompId = 8,
|
||||||
HvCallXmCompId = 9,
|
HvCallXmCompId = 9,
|
||||||
HvCallRioCompId = 10,
|
HvCallRioCompId = 10,
|
||||||
HvCallRsvd3CompId = 11,
|
HvCallRsvd3CompId = 11,
|
||||||
HvCallRsvd2CompId = 12,
|
HvCallRsvd2CompId = 12,
|
||||||
HvCallRsvd1CompId = 13,
|
HvCallRsvd1CompId = 13,
|
||||||
HvCallMaxCompId = 14,
|
HvCallMaxCompId = 14,
|
||||||
HvPrimaryCallCompId = 0,
|
HvPrimaryCallCompId = 0,
|
||||||
HvPrimaryCallCfgCompId = 1,
|
HvPrimaryCallCfgCompId = 1,
|
||||||
HvPrimaryCallPciCompId = 2,
|
HvPrimaryCallPciCompId = 2,
|
||||||
HvPrimaryCallSmCompId = 3,
|
HvPrimaryCallSmCompId = 3,
|
||||||
HvPrimaryCallSpdCompId = 4,
|
HvPrimaryCallSpdCompId = 4,
|
||||||
HvPrimaryCallXmCompId = 5,
|
HvPrimaryCallXmCompId = 5,
|
||||||
HvPrimaryCallRioCompId = 6,
|
HvPrimaryCallRioCompId = 6,
|
||||||
HvPrimaryCallRsvd7CompId = 7,
|
HvPrimaryCallRsvd7CompId = 7,
|
||||||
HvPrimaryCallRsvd6CompId = 8,
|
HvPrimaryCallRsvd6CompId = 8,
|
||||||
HvPrimaryCallRsvd5CompId = 9,
|
HvPrimaryCallRsvd5CompId = 9,
|
||||||
@ -116,7 +104,7 @@ enum HvCallCompIds
|
|||||||
HvPrimaryCallRsvd3CompId = 11,
|
HvPrimaryCallRsvd3CompId = 11,
|
||||||
HvPrimaryCallRsvd2CompId = 12,
|
HvPrimaryCallRsvd2CompId = 12,
|
||||||
HvPrimaryCallRsvd1CompId = 13,
|
HvPrimaryCallRsvd1CompId = 13,
|
||||||
HvPrimaryCallMaxCompId = HvCallMaxCompId
|
HvPrimaryCallMaxCompId = HvCallMaxCompId
|
||||||
};
|
};
|
||||||
|
|
||||||
struct HvLpBufferList {
|
struct HvLpBufferList {
|
||||||
|
Loading…
Reference in New Issue
Block a user