Linux Audio

Check our new training course

Loading...
v3.5.6
  1/*
  2 * definition for store system information stsi
  3 *
  4 * Copyright IBM Corp. 2001,2008
  5 *
  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
 14#ifndef __ASM_S390_SYSINFO_H
 15#define __ASM_S390_SYSINFO_H
 16
 17#include <asm/bitsperlong.h>
 18
 19struct sysinfo_1_1_1 {
 20	unsigned short :16;
 
 
 
 21	unsigned char ccr;
 22	unsigned char cai;
 23	char reserved_0[28];
 24	char manufacturer[16];
 25	char type[4];
 26	char reserved_1[12];
 27	char model_capacity[16];
 28	char sequence[16];
 29	char plant[4];
 30	char model[16];
 31	char model_perm_cap[16];
 32	char model_temp_cap[16];
 33	char model_cap_rating[4];
 34	char model_perm_cap_rating[4];
 35	char model_temp_cap_rating[4];
 
 
 
 
 
 36};
 37
 38struct sysinfo_1_2_1 {
 39	char reserved_0[80];
 40	char sequence[16];
 41	char plant[4];
 42	char reserved_1[2];
 43	unsigned short cpu_address;
 44};
 45
 46struct sysinfo_1_2_2 {
 47	char format;
 48	char reserved_0[1];
 49	unsigned short acc_offset;
 50	char reserved_1[24];
 51	unsigned int secondary_capability;
 
 52	unsigned int capability;
 53	unsigned short cpus_total;
 54	unsigned short cpus_configured;
 55	unsigned short cpus_standby;
 56	unsigned short cpus_reserved;
 57	unsigned short adjustment[0];
 58};
 59
 60struct sysinfo_1_2_2_extension {
 61	unsigned int alt_capability;
 62	unsigned short alt_adjustment[0];
 63};
 64
 65struct sysinfo_2_2_1 {
 66	char reserved_0[80];
 67	char sequence[16];
 68	char plant[4];
 69	unsigned short cpu_id;
 70	unsigned short cpu_address;
 71};
 72
 73struct sysinfo_2_2_2 {
 74	char reserved_0[32];
 75	unsigned short lpar_number;
 76	char reserved_1;
 77	unsigned char characteristics;
 78	unsigned short cpus_total;
 79	unsigned short cpus_configured;
 80	unsigned short cpus_standby;
 81	unsigned short cpus_reserved;
 82	char name[8];
 83	unsigned int caf;
 84	char reserved_2[16];
 85	unsigned short cpus_dedicated;
 86	unsigned short cpus_shared;
 87};
 88
 89#define LPAR_CHAR_DEDICATED	(1 << 7)
 90#define LPAR_CHAR_SHARED	(1 << 6)
 91#define LPAR_CHAR_LIMITED	(1 << 5)
 92
 93struct sysinfo_3_2_2 {
 94	char reserved_0[31];
 95	unsigned char :4;
 96	unsigned char count:4;
 97	struct {
 98		char reserved_0[4];
 99		unsigned short cpus_total;
100		unsigned short cpus_configured;
101		unsigned short cpus_standby;
102		unsigned short cpus_reserved;
103		char name[8];
104		unsigned int caf;
105		char cpi[16];
106		char reserved_1[24];
107
108	} vm[8];
109	char reserved_544[3552];
110};
111
 
 
112#define TOPOLOGY_CPU_BITS	64
113#define TOPOLOGY_NR_MAG		6
114
115struct topology_cpu {
116	unsigned char reserved0[4];
117	unsigned char :6;
118	unsigned char pp:2;
119	unsigned char reserved1;
120	unsigned short origin;
121	unsigned long mask[TOPOLOGY_CPU_BITS / BITS_PER_LONG];
122};
123
124struct topology_container {
125	unsigned char reserved[7];
126	unsigned char id;
127};
128
129union topology_entry {
130	unsigned char nl;
131	struct topology_cpu cpu;
132	struct topology_container container;
133};
134
135struct sysinfo_15_1_x {
136	unsigned char reserved0[2];
137	unsigned short length;
138	unsigned char mag[TOPOLOGY_NR_MAG];
139	unsigned char reserved1;
140	unsigned char mnest;
141	unsigned char reserved2[4];
142	union topology_entry tle[0];
143};
144
145static inline int stsi(void *sysinfo, int fc, int sel1, int sel2)
146{
147	register int r0 asm("0") = (fc << 28) | sel1;
148	register int r1 asm("1") = sel2;
149
150	asm volatile(
151		"   stsi 0(%2)\n"
152		"0: jz   2f\n"
153		"1: lhi  %0,%3\n"
154		"2:\n"
155		EX_TABLE(0b, 1b)
156		: "+d" (r0) : "d" (r1), "a" (sysinfo), "K" (-ENOSYS)
157		: "cc", "memory");
158	return r0;
159}
160
161/*
162 * Service level reporting interface.
163 */
164struct service_level {
165	struct list_head list;
166	void (*seq_print)(struct seq_file *, struct service_level *);
167};
168
169int register_service_level(struct service_level *);
170int unregister_service_level(struct service_level *);
171
172#endif /* __ASM_S390_SYSINFO_H */
v3.15
  1/*
  2 * definition for store system information stsi
  3 *
  4 * Copyright IBM Corp. 2001, 2008
  5 *
  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
 14#ifndef __ASM_S390_SYSINFO_H
 15#define __ASM_S390_SYSINFO_H
 16
 17#include <asm/bitsperlong.h>
 18
 19struct sysinfo_1_1_1 {
 20	unsigned char p:1;
 21	unsigned char :6;
 22	unsigned char t:1;
 23	unsigned char :8;
 24	unsigned char ccr;
 25	unsigned char cai;
 26	char reserved_0[28];
 27	char manufacturer[16];
 28	char type[4];
 29	char reserved_1[12];
 30	char model_capacity[16];
 31	char sequence[16];
 32	char plant[4];
 33	char model[16];
 34	char model_perm_cap[16];
 35	char model_temp_cap[16];
 36	unsigned int model_cap_rating;
 37	unsigned int model_perm_cap_rating;
 38	unsigned int model_temp_cap_rating;
 39	unsigned char typepct[5];
 40	unsigned char reserved_2[3];
 41	unsigned int ncr;
 42	unsigned int npr;
 43	unsigned int ntr;
 44};
 45
 46struct sysinfo_1_2_1 {
 47	char reserved_0[80];
 48	char sequence[16];
 49	char plant[4];
 50	char reserved_1[2];
 51	unsigned short cpu_address;
 52};
 53
 54struct sysinfo_1_2_2 {
 55	char format;
 56	char reserved_0[1];
 57	unsigned short acc_offset;
 58	char reserved_1[20];
 59	unsigned int nominal_cap;
 60	unsigned int secondary_cap;
 61	unsigned int capability;
 62	unsigned short cpus_total;
 63	unsigned short cpus_configured;
 64	unsigned short cpus_standby;
 65	unsigned short cpus_reserved;
 66	unsigned short adjustment[0];
 67};
 68
 69struct sysinfo_1_2_2_extension {
 70	unsigned int alt_capability;
 71	unsigned short alt_adjustment[0];
 72};
 73
 74struct sysinfo_2_2_1 {
 75	char reserved_0[80];
 76	char sequence[16];
 77	char plant[4];
 78	unsigned short cpu_id;
 79	unsigned short cpu_address;
 80};
 81
 82struct sysinfo_2_2_2 {
 83	char reserved_0[32];
 84	unsigned short lpar_number;
 85	char reserved_1;
 86	unsigned char characteristics;
 87	unsigned short cpus_total;
 88	unsigned short cpus_configured;
 89	unsigned short cpus_standby;
 90	unsigned short cpus_reserved;
 91	char name[8];
 92	unsigned int caf;
 93	char reserved_2[16];
 94	unsigned short cpus_dedicated;
 95	unsigned short cpus_shared;
 96};
 97
 98#define LPAR_CHAR_DEDICATED	(1 << 7)
 99#define LPAR_CHAR_SHARED	(1 << 6)
100#define LPAR_CHAR_LIMITED	(1 << 5)
101
102struct sysinfo_3_2_2 {
103	char reserved_0[31];
104	unsigned char :4;
105	unsigned char count:4;
106	struct {
107		char reserved_0[4];
108		unsigned short cpus_total;
109		unsigned short cpus_configured;
110		unsigned short cpus_standby;
111		unsigned short cpus_reserved;
112		char name[8];
113		unsigned int caf;
114		char cpi[16];
115		char reserved_1[24];
116
117	} vm[8];
118	char reserved_544[3552];
119};
120
121extern int topology_max_mnest;
122
123#define TOPOLOGY_CPU_BITS	64
124#define TOPOLOGY_NR_MAG		6
125
126struct topology_cpu {
127	unsigned char reserved0[4];
128	unsigned char :6;
129	unsigned char pp:2;
130	unsigned char reserved1;
131	unsigned short origin;
132	unsigned long mask[TOPOLOGY_CPU_BITS / BITS_PER_LONG];
133};
134
135struct topology_container {
136	unsigned char reserved[7];
137	unsigned char id;
138};
139
140union topology_entry {
141	unsigned char nl;
142	struct topology_cpu cpu;
143	struct topology_container container;
144};
145
146struct sysinfo_15_1_x {
147	unsigned char reserved0[2];
148	unsigned short length;
149	unsigned char mag[TOPOLOGY_NR_MAG];
150	unsigned char reserved1;
151	unsigned char mnest;
152	unsigned char reserved2[4];
153	union topology_entry tle[0];
154};
155
156int stsi(void *sysinfo, int fc, int sel1, int sel2);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
157
158/*
159 * Service level reporting interface.
160 */
161struct service_level {
162	struct list_head list;
163	void (*seq_print)(struct seq_file *, struct service_level *);
164};
165
166int register_service_level(struct service_level *);
167int unregister_service_level(struct service_level *);
168
169#endif /* __ASM_S390_SYSINFO_H */