blob: f7054a892d9e921eef2cbc896c420b9c562c3188 [file] [log] [blame]
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +02001/*
2 * definition for store system information stsi
3 *
Heiko Carstensa53c8fa2012-07-20 11:15:04 +02004 * Copyright IBM Corp. 2001, 2008
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +02005 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License (version 2 only)
8 * as published by the Free Software Foundation.
9 *
10 * Author(s): Ulrich Weigand <weigand@de.ibm.com>
11 * Christian Borntraeger <borntraeger@de.ibm.com>
12 */
13
Heiko Carstensf291e172008-04-30 13:38:35 +020014#ifndef __ASM_S390_SYSINFO_H
15#define __ASM_S390_SYSINFO_H
16
Heiko Carstensc30f91b2010-10-25 16:10:53 +020017#include <asm/bitsperlong.h>
Ekaterina Tumanovaf3d0bd62014-10-20 15:24:31 +020018#include <linux/uuid.h>
Heiko Carstensc30f91b2010-10-25 16:10:53 +020019
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +020020struct sysinfo_1_1_1 {
Heiko Carstens25502f02012-09-03 14:05:05 +020021 unsigned char p:1;
22 unsigned char :6;
23 unsigned char t:1;
24 unsigned char :8;
Heiko Carstens7aca2ed2010-10-25 16:10:16 +020025 unsigned char ccr;
26 unsigned char cai;
27 char reserved_0[28];
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +020028 char manufacturer[16];
29 char type[4];
30 char reserved_1[12];
31 char model_capacity[16];
32 char sequence[16];
33 char plant[4];
34 char model[16];
Martin Schwidefskycbce70e2008-04-17 07:46:10 +020035 char model_perm_cap[16];
36 char model_temp_cap[16];
Heiko Carstens25502f02012-09-03 14:05:05 +020037 unsigned int model_cap_rating;
38 unsigned int model_perm_cap_rating;
39 unsigned int model_temp_cap_rating;
40 unsigned char typepct[5];
41 unsigned char reserved_2[3];
42 unsigned int ncr;
43 unsigned int npr;
44 unsigned int ntr;
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +020045};
46
47struct sysinfo_1_2_1 {
48 char reserved_0[80];
49 char sequence[16];
50 char plant[4];
51 char reserved_1[2];
52 unsigned short cpu_address;
53};
54
55struct sysinfo_1_2_2 {
56 char format;
57 char reserved_0[1];
58 unsigned short acc_offset;
Heiko Carstens25502f02012-09-03 14:05:05 +020059 char reserved_1[20];
60 unsigned int nominal_cap;
61 unsigned int secondary_cap;
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +020062 unsigned int capability;
63 unsigned short cpus_total;
64 unsigned short cpus_configured;
65 unsigned short cpus_standby;
66 unsigned short cpus_reserved;
67 unsigned short adjustment[0];
68};
69
70struct sysinfo_1_2_2_extension {
71 unsigned int alt_capability;
72 unsigned short alt_adjustment[0];
73};
74
75struct sysinfo_2_2_1 {
76 char reserved_0[80];
77 char sequence[16];
78 char plant[4];
79 unsigned short cpu_id;
80 unsigned short cpu_address;
81};
82
83struct sysinfo_2_2_2 {
84 char reserved_0[32];
85 unsigned short lpar_number;
86 char reserved_1;
87 unsigned char characteristics;
88 unsigned short cpus_total;
89 unsigned short cpus_configured;
90 unsigned short cpus_standby;
91 unsigned short cpus_reserved;
92 char name[8];
93 unsigned int caf;
Martin Schwidefsky10ad34b2015-01-14 17:52:10 +010094 char reserved_2[8];
95 unsigned char mt_installed;
96 unsigned char mt_general;
97 unsigned char mt_psmtid;
98 char reserved_3[5];
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +020099 unsigned short cpus_dedicated;
100 unsigned short cpus_shared;
101};
102
103#define LPAR_CHAR_DEDICATED (1 << 7)
104#define LPAR_CHAR_SHARED (1 << 6)
105#define LPAR_CHAR_LIMITED (1 << 5)
106
107struct sysinfo_3_2_2 {
108 char reserved_0[31];
Heiko Carstens8387c732010-02-26 22:37:39 +0100109 unsigned char :4;
110 unsigned char count:4;
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +0200111 struct {
112 char reserved_0[4];
113 unsigned short cpus_total;
114 unsigned short cpus_configured;
115 unsigned short cpus_standby;
116 unsigned short cpus_reserved;
117 char name[8];
118 unsigned int caf;
119 char cpi[16];
Ekaterina Tumanovaf3d0bd62014-10-20 15:24:31 +0200120 char reserved_1[3];
121 char ext_name_encoding;
122 unsigned int reserved_2;
123 uuid_be uuid;
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +0200124 } vm[8];
Ekaterina Tumanovaf3d0bd62014-10-20 15:24:31 +0200125 char reserved_3[1504];
126 char ext_names[8][256];
Christian Borntraegeraa24f7f2008-04-17 07:46:09 +0200127};
128
Heiko Carstensfade4dc2012-09-04 14:26:03 +0200129extern int topology_max_mnest;
130
Martin Schwidefsky10ad34b2015-01-14 17:52:10 +0100131#define TOPOLOGY_CORE_BITS 64
Heiko Carstensc30f91b2010-10-25 16:10:53 +0200132#define TOPOLOGY_NR_MAG 6
133
Martin Schwidefsky10ad34b2015-01-14 17:52:10 +0100134struct topology_core {
135 unsigned char nl;
136 unsigned char reserved0[3];
Heiko Carstensc30f91b2010-10-25 16:10:53 +0200137 unsigned char :6;
138 unsigned char pp:2;
139 unsigned char reserved1;
140 unsigned short origin;
Martin Schwidefsky10ad34b2015-01-14 17:52:10 +0100141 unsigned long mask[TOPOLOGY_CORE_BITS / BITS_PER_LONG];
Heiko Carstensc30f91b2010-10-25 16:10:53 +0200142};
143
144struct topology_container {
Martin Schwidefsky10ad34b2015-01-14 17:52:10 +0100145 unsigned char nl;
146 unsigned char reserved[6];
Heiko Carstensc30f91b2010-10-25 16:10:53 +0200147 unsigned char id;
148};
149
150union topology_entry {
151 unsigned char nl;
Martin Schwidefsky10ad34b2015-01-14 17:52:10 +0100152 struct topology_core cpu;
Heiko Carstensc30f91b2010-10-25 16:10:53 +0200153 struct topology_container container;
154};
155
156struct sysinfo_15_1_x {
157 unsigned char reserved0[2];
158 unsigned short length;
159 unsigned char mag[TOPOLOGY_NR_MAG];
160 unsigned char reserved1;
161 unsigned char mnest;
162 unsigned char reserved2[4];
163 union topology_entry tle[0];
164};
165
Heiko Carstenscaf757c2012-09-06 14:42:13 +0200166int stsi(void *sysinfo, int fc, int sel1, int sel2);
Heiko Carstensf291e172008-04-30 13:38:35 +0200167
Martin Schwidefsky6bcac502008-12-25 13:38:49 +0100168/*
169 * Service level reporting interface.
170 */
171struct service_level {
172 struct list_head list;
173 void (*seq_print)(struct seq_file *, struct service_level *);
174};
175
176int register_service_level(struct service_level *);
177int unregister_service_level(struct service_level *);
178
Heiko Carstensf291e172008-04-30 13:38:35 +0200179#endif /* __ASM_S390_SYSINFO_H */