sysinfo.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * definition for store system information stsi
  4. *
  5. * Copyright IBM Corp. 2001, 2008
  6. *
  7. * Author(s): Ulrich Weigand <[email protected]>
  8. * Christian Borntraeger <[email protected]>
  9. */
  10. #ifndef __ASM_S390_SYSINFO_H
  11. #define __ASM_S390_SYSINFO_H
  12. #include <asm/bitsperlong.h>
  13. #include <linux/uuid.h>
  14. struct sysinfo_1_1_1 {
  15. unsigned char p:1;
  16. unsigned char :6;
  17. unsigned char t:1;
  18. unsigned char :8;
  19. unsigned char ccr;
  20. unsigned char cai;
  21. char reserved_0[20];
  22. unsigned long lic;
  23. char manufacturer[16];
  24. char type[4];
  25. char reserved_1[12];
  26. char model_capacity[16];
  27. char sequence[16];
  28. char plant[4];
  29. char model[16];
  30. char model_perm_cap[16];
  31. char model_temp_cap[16];
  32. unsigned int model_cap_rating;
  33. unsigned int model_perm_cap_rating;
  34. unsigned int model_temp_cap_rating;
  35. unsigned char typepct[5];
  36. unsigned char reserved_2[3];
  37. unsigned int ncr;
  38. unsigned int npr;
  39. unsigned int ntr;
  40. };
  41. struct sysinfo_1_2_1 {
  42. char reserved_0[80];
  43. char sequence[16];
  44. char plant[4];
  45. char reserved_1[2];
  46. unsigned short cpu_address;
  47. };
  48. struct sysinfo_1_2_2 {
  49. char format;
  50. char reserved_0[1];
  51. unsigned short acc_offset;
  52. unsigned char mt_installed :1;
  53. unsigned char :2;
  54. unsigned char mt_stid :5;
  55. unsigned char :3;
  56. unsigned char mt_gtid :5;
  57. char reserved_1[18];
  58. unsigned int nominal_cap;
  59. unsigned int secondary_cap;
  60. unsigned int capability;
  61. unsigned short cpus_total;
  62. unsigned short cpus_configured;
  63. unsigned short cpus_standby;
  64. unsigned short cpus_reserved;
  65. unsigned short adjustment[];
  66. };
  67. struct sysinfo_1_2_2_extension {
  68. unsigned int alt_capability;
  69. unsigned short alt_adjustment[];
  70. };
  71. struct sysinfo_2_2_1 {
  72. char reserved_0[80];
  73. char sequence[16];
  74. char plant[4];
  75. unsigned short cpu_id;
  76. unsigned short cpu_address;
  77. };
  78. struct sysinfo_2_2_2 {
  79. char reserved_0[32];
  80. unsigned short lpar_number;
  81. char reserved_1;
  82. unsigned char characteristics;
  83. unsigned short cpus_total;
  84. unsigned short cpus_configured;
  85. unsigned short cpus_standby;
  86. unsigned short cpus_reserved;
  87. char name[8];
  88. unsigned int caf;
  89. char reserved_2[8];
  90. unsigned char mt_installed :1;
  91. unsigned char :2;
  92. unsigned char mt_stid :5;
  93. unsigned char :3;
  94. unsigned char mt_gtid :5;
  95. unsigned char :3;
  96. unsigned char mt_psmtid :5;
  97. char reserved_3[5];
  98. unsigned short cpus_dedicated;
  99. unsigned short cpus_shared;
  100. char reserved_4[3];
  101. unsigned char vsne;
  102. uuid_t uuid;
  103. char reserved_5[160];
  104. char ext_name[256];
  105. };
  106. #define LPAR_CHAR_DEDICATED (1 << 7)
  107. #define LPAR_CHAR_SHARED (1 << 6)
  108. #define LPAR_CHAR_LIMITED (1 << 5)
  109. struct sysinfo_3_2_2 {
  110. char reserved_0[31];
  111. unsigned char :4;
  112. unsigned char count:4;
  113. struct {
  114. char reserved_0[4];
  115. unsigned short cpus_total;
  116. unsigned short cpus_configured;
  117. unsigned short cpus_standby;
  118. unsigned short cpus_reserved;
  119. char name[8];
  120. unsigned int caf;
  121. char cpi[16];
  122. char reserved_1[3];
  123. unsigned char evmne;
  124. unsigned int reserved_2;
  125. uuid_t uuid;
  126. } vm[8];
  127. char reserved_3[1504];
  128. char ext_names[8][256];
  129. };
  130. extern int topology_max_mnest;
  131. /*
  132. * Returns the maximum nesting level supported by the cpu topology code.
  133. * The current maximum level is 4 which is the drawer level.
  134. */
  135. static inline unsigned char topology_mnest_limit(void)
  136. {
  137. return min(topology_max_mnest, 4);
  138. }
  139. #define TOPOLOGY_NR_MAG 6
  140. struct topology_core {
  141. unsigned char nl;
  142. unsigned char reserved0[3];
  143. unsigned char :5;
  144. unsigned char d:1;
  145. unsigned char pp:2;
  146. unsigned char reserved1;
  147. unsigned short origin;
  148. unsigned long mask;
  149. };
  150. struct topology_container {
  151. unsigned char nl;
  152. unsigned char reserved[6];
  153. unsigned char id;
  154. };
  155. union topology_entry {
  156. unsigned char nl;
  157. struct topology_core cpu;
  158. struct topology_container container;
  159. };
  160. struct sysinfo_15_1_x {
  161. unsigned char reserved0[2];
  162. unsigned short length;
  163. unsigned char mag[TOPOLOGY_NR_MAG];
  164. unsigned char reserved1;
  165. unsigned char mnest;
  166. unsigned char reserved2[4];
  167. union topology_entry tle[];
  168. };
  169. int stsi(void *sysinfo, int fc, int sel1, int sel2);
  170. /*
  171. * Service level reporting interface.
  172. */
  173. struct service_level {
  174. struct list_head list;
  175. void (*seq_print)(struct seq_file *, struct service_level *);
  176. };
  177. int register_service_level(struct service_level *);
  178. int unregister_service_level(struct service_level *);
  179. int sthyi_fill(void *dst, u64 *rc);
  180. #endif /* __ASM_S390_SYSINFO_H */