HvCallCfg.h 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. /*
  2. * HvCallCfg.h
  3. * Copyright (C) 2001 Mike Corrigan IBM Corporation
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  18. */
  19. /*
  20. * This file contains the "hypervisor call" interface which is used to
  21. * drive the hypervisor from the OS.
  22. */
  23. #ifndef _HVCALLCFG_H
  24. #define _HVCALLCFG_H
  25. #include <asm/iSeries/HvCallSc.h>
  26. #include <asm/iSeries/HvTypes.h>
  27. enum HvCallCfg_ReqQual {
  28. HvCallCfg_Cur = 0,
  29. HvCallCfg_Init = 1,
  30. HvCallCfg_Max = 2,
  31. HvCallCfg_Min = 3
  32. };
  33. #define HvCallCfgGetLps HvCallCfg + 0
  34. #define HvCallCfgGetActiveLpMap HvCallCfg + 1
  35. #define HvCallCfgGetLpVrmIndex HvCallCfg + 2
  36. #define HvCallCfgGetLpMinSupportedPlicVrmIndex HvCallCfg + 3
  37. #define HvCallCfgGetLpMinCompatablePlicVrmIndex HvCallCfg + 4
  38. #define HvCallCfgGetLpVrmName HvCallCfg + 5
  39. #define HvCallCfgGetSystemPhysicalProcessors HvCallCfg + 6
  40. #define HvCallCfgGetPhysicalProcessors HvCallCfg + 7
  41. #define HvCallCfgGetSystemMsChunks HvCallCfg + 8
  42. #define HvCallCfgGetMsChunks HvCallCfg + 9
  43. #define HvCallCfgGetInteractivePercentage HvCallCfg + 10
  44. #define HvCallCfgIsBusDedicated HvCallCfg + 11
  45. #define HvCallCfgGetBusOwner HvCallCfg + 12
  46. #define HvCallCfgGetBusAllocation HvCallCfg + 13
  47. #define HvCallCfgGetBusUnitOwner HvCallCfg + 14
  48. #define HvCallCfgGetBusUnitAllocation HvCallCfg + 15
  49. #define HvCallCfgGetVirtualBusPool HvCallCfg + 16
  50. #define HvCallCfgGetBusUnitInterruptProc HvCallCfg + 17
  51. #define HvCallCfgGetConfiguredBusUnitsForIntProc HvCallCfg + 18
  52. #define HvCallCfgGetRioSanBusPool HvCallCfg + 19
  53. #define HvCallCfgGetSharedPoolIndex HvCallCfg + 20
  54. #define HvCallCfgGetSharedProcUnits HvCallCfg + 21
  55. #define HvCallCfgGetNumProcsInSharedPool HvCallCfg + 22
  56. #define HvCallCfgRouter23 HvCallCfg + 23
  57. #define HvCallCfgRouter24 HvCallCfg + 24
  58. #define HvCallCfgRouter25 HvCallCfg + 25
  59. #define HvCallCfgRouter26 HvCallCfg + 26
  60. #define HvCallCfgRouter27 HvCallCfg + 27
  61. #define HvCallCfgGetMinRuntimeMsChunks HvCallCfg + 28
  62. #define HvCallCfgSetMinRuntimeMsChunks HvCallCfg + 29
  63. #define HvCallCfgGetVirtualLanIndexMap HvCallCfg + 30
  64. #define HvCallCfgGetLpExecutionMode HvCallCfg + 31
  65. #define HvCallCfgGetHostingLpIndex HvCallCfg + 32
  66. static inline HvLpIndex HvCallCfg_getLps(void)
  67. {
  68. HvLpIndex retVal = HvCall0(HvCallCfgGetLps);
  69. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  70. return retVal;
  71. }
  72. static inline int HvCallCfg_isBusDedicated(u64 busIndex)
  73. {
  74. int retVal = HvCall1(HvCallCfgIsBusDedicated,busIndex);
  75. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  76. return retVal;
  77. }
  78. static inline HvLpIndex HvCallCfg_getBusOwner(u64 busIndex)
  79. {
  80. HvLpIndex retVal = HvCall1(HvCallCfgGetBusOwner,busIndex);
  81. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  82. return retVal;
  83. }
  84. static inline HvLpIndexMap HvCallCfg_getBusAllocation(u64 busIndex)
  85. {
  86. HvLpIndexMap retVal = HvCall1(HvCallCfgGetBusAllocation,busIndex);
  87. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  88. return retVal;
  89. }
  90. static inline HvLpIndexMap HvCallCfg_getActiveLpMap(void)
  91. {
  92. HvLpIndexMap retVal = HvCall0(HvCallCfgGetActiveLpMap);
  93. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  94. return retVal;
  95. }
  96. static inline HvLpVirtualLanIndexMap HvCallCfg_getVirtualLanIndexMap(
  97. HvLpIndex lp)
  98. {
  99. /*
  100. * This is a new function in V5R1 so calls to this on older
  101. * hypervisors will return -1
  102. */
  103. u64 retVal = HvCall1(HvCallCfgGetVirtualLanIndexMap, lp);
  104. if (retVal == -1)
  105. retVal = 0;
  106. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  107. return retVal;
  108. }
  109. static inline u64 HvCallCfg_getSystemMsChunks(void)
  110. {
  111. u64 retVal = HvCall0(HvCallCfgGetSystemMsChunks);
  112. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  113. return retVal;
  114. }
  115. static inline u64 HvCallCfg_getMsChunks(HvLpIndex lp,
  116. enum HvCallCfg_ReqQual qual)
  117. {
  118. u64 retVal = HvCall2(HvCallCfgGetMsChunks,lp,qual);
  119. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  120. return retVal;
  121. }
  122. static inline u64 HvCallCfg_getMinRuntimeMsChunks(HvLpIndex lp)
  123. {
  124. /*
  125. * NOTE: This function was added in v5r1 so older hypervisors
  126. * will return a -1 value
  127. */
  128. return HvCall1(HvCallCfgGetMinRuntimeMsChunks, lp);
  129. }
  130. static inline u64 HvCallCfg_setMinRuntimeMsChunks(u64 chunks)
  131. {
  132. u64 retVal = HvCall1(HvCallCfgSetMinRuntimeMsChunks,chunks);
  133. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  134. return retVal;
  135. }
  136. static inline u64 HvCallCfg_getSystemPhysicalProcessors(void)
  137. {
  138. u64 retVal = HvCall0(HvCallCfgGetSystemPhysicalProcessors);
  139. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  140. return retVal;
  141. }
  142. static inline u64 HvCallCfg_getPhysicalProcessors(HvLpIndex lp,
  143. enum HvCallCfg_ReqQual qual)
  144. {
  145. u64 retVal = HvCall2(HvCallCfgGetPhysicalProcessors,lp,qual);
  146. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  147. return retVal;
  148. }
  149. static inline u64 HvCallCfg_getConfiguredBusUnitsForInterruptProc(HvLpIndex lp,
  150. u16 hvLogicalProcIndex)
  151. {
  152. u64 retVal = HvCall2(HvCallCfgGetConfiguredBusUnitsForIntProc,lp,hvLogicalProcIndex);
  153. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  154. return retVal;
  155. }
  156. static inline HvLpSharedPoolIndex HvCallCfg_getSharedPoolIndex(HvLpIndex lp)
  157. {
  158. HvLpSharedPoolIndex retVal =
  159. HvCall1(HvCallCfgGetSharedPoolIndex,lp);
  160. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  161. return retVal;
  162. }
  163. static inline u64 HvCallCfg_getSharedProcUnits(HvLpIndex lp,
  164. enum HvCallCfg_ReqQual qual)
  165. {
  166. u64 retVal = HvCall2(HvCallCfgGetSharedProcUnits,lp,qual);
  167. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  168. return retVal;
  169. }
  170. static inline u64 HvCallCfg_getNumProcsInSharedPool(HvLpSharedPoolIndex sPI)
  171. {
  172. u16 retVal = HvCall1(HvCallCfgGetNumProcsInSharedPool,sPI);
  173. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  174. return retVal;
  175. }
  176. static inline HvLpIndex HvCallCfg_getHostingLpIndex(HvLpIndex lp)
  177. {
  178. u64 retVal = HvCall1(HvCallCfgGetHostingLpIndex,lp);
  179. // getPaca()->adjustHmtForNoOfSpinLocksHeld();
  180. return retVal;
  181. }
  182. #endif /* _HVCALLCFG_H */