| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * definition for store system information stsi | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-07-20 11:15:04 +02:00
										 |  |  |  * Copyright IBM Corp. 2001, 2008 | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License (version 2 only) | 
					
						
							|  |  |  |  * as published by the Free Software Foundation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *    Author(s): Ulrich Weigand <weigand@de.ibm.com> | 
					
						
							|  |  |  |  *		 Christian Borntraeger <borntraeger@de.ibm.com> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-30 13:38:35 +02:00
										 |  |  | #ifndef __ASM_S390_SYSINFO_H
 | 
					
						
							|  |  |  | #define __ASM_S390_SYSINFO_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-25 16:10:53 +02:00
										 |  |  | #include <asm/bitsperlong.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  | struct sysinfo_1_1_1 { | 
					
						
							| 
									
										
										
										
											2012-09-03 14:05:05 +02:00
										 |  |  | 	unsigned char p:1; | 
					
						
							|  |  |  | 	unsigned char :6; | 
					
						
							|  |  |  | 	unsigned char t:1; | 
					
						
							|  |  |  | 	unsigned char :8; | 
					
						
							| 
									
										
										
										
											2010-10-25 16:10:16 +02:00
										 |  |  | 	unsigned char ccr; | 
					
						
							|  |  |  | 	unsigned char cai; | 
					
						
							|  |  |  | 	char reserved_0[28]; | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  | 	char manufacturer[16]; | 
					
						
							|  |  |  | 	char type[4]; | 
					
						
							|  |  |  | 	char reserved_1[12]; | 
					
						
							|  |  |  | 	char model_capacity[16]; | 
					
						
							|  |  |  | 	char sequence[16]; | 
					
						
							|  |  |  | 	char plant[4]; | 
					
						
							|  |  |  | 	char model[16]; | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:10 +02:00
										 |  |  | 	char model_perm_cap[16]; | 
					
						
							|  |  |  | 	char model_temp_cap[16]; | 
					
						
							| 
									
										
										
										
											2012-09-03 14:05:05 +02:00
										 |  |  | 	unsigned int model_cap_rating; | 
					
						
							|  |  |  | 	unsigned int model_perm_cap_rating; | 
					
						
							|  |  |  | 	unsigned int model_temp_cap_rating; | 
					
						
							|  |  |  | 	unsigned char typepct[5]; | 
					
						
							|  |  |  | 	unsigned char reserved_2[3]; | 
					
						
							|  |  |  | 	unsigned int ncr; | 
					
						
							|  |  |  | 	unsigned int npr; | 
					
						
							|  |  |  | 	unsigned int ntr; | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sysinfo_1_2_1 { | 
					
						
							|  |  |  | 	char reserved_0[80]; | 
					
						
							|  |  |  | 	char sequence[16]; | 
					
						
							|  |  |  | 	char plant[4]; | 
					
						
							|  |  |  | 	char reserved_1[2]; | 
					
						
							|  |  |  | 	unsigned short cpu_address; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sysinfo_1_2_2 { | 
					
						
							|  |  |  | 	char format; | 
					
						
							|  |  |  | 	char reserved_0[1]; | 
					
						
							|  |  |  | 	unsigned short acc_offset; | 
					
						
							| 
									
										
										
										
											2012-09-03 14:05:05 +02:00
										 |  |  | 	char reserved_1[20]; | 
					
						
							|  |  |  | 	unsigned int nominal_cap; | 
					
						
							|  |  |  | 	unsigned int secondary_cap; | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  | 	unsigned int capability; | 
					
						
							|  |  |  | 	unsigned short cpus_total; | 
					
						
							|  |  |  | 	unsigned short cpus_configured; | 
					
						
							|  |  |  | 	unsigned short cpus_standby; | 
					
						
							|  |  |  | 	unsigned short cpus_reserved; | 
					
						
							|  |  |  | 	unsigned short adjustment[0]; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sysinfo_1_2_2_extension { | 
					
						
							|  |  |  | 	unsigned int alt_capability; | 
					
						
							|  |  |  | 	unsigned short alt_adjustment[0]; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sysinfo_2_2_1 { | 
					
						
							|  |  |  | 	char reserved_0[80]; | 
					
						
							|  |  |  | 	char sequence[16]; | 
					
						
							|  |  |  | 	char plant[4]; | 
					
						
							|  |  |  | 	unsigned short cpu_id; | 
					
						
							|  |  |  | 	unsigned short cpu_address; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sysinfo_2_2_2 { | 
					
						
							|  |  |  | 	char reserved_0[32]; | 
					
						
							|  |  |  | 	unsigned short lpar_number; | 
					
						
							|  |  |  | 	char reserved_1; | 
					
						
							|  |  |  | 	unsigned char characteristics; | 
					
						
							|  |  |  | 	unsigned short cpus_total; | 
					
						
							|  |  |  | 	unsigned short cpus_configured; | 
					
						
							|  |  |  | 	unsigned short cpus_standby; | 
					
						
							|  |  |  | 	unsigned short cpus_reserved; | 
					
						
							|  |  |  | 	char name[8]; | 
					
						
							|  |  |  | 	unsigned int caf; | 
					
						
							|  |  |  | 	char reserved_2[16]; | 
					
						
							|  |  |  | 	unsigned short cpus_dedicated; | 
					
						
							|  |  |  | 	unsigned short cpus_shared; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define LPAR_CHAR_DEDICATED	(1 << 7)
 | 
					
						
							|  |  |  | #define LPAR_CHAR_SHARED	(1 << 6)
 | 
					
						
							|  |  |  | #define LPAR_CHAR_LIMITED	(1 << 5)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sysinfo_3_2_2 { | 
					
						
							|  |  |  | 	char reserved_0[31]; | 
					
						
							| 
									
										
										
										
											2010-02-26 22:37:39 +01:00
										 |  |  | 	unsigned char :4; | 
					
						
							|  |  |  | 	unsigned char count:4; | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  | 	struct { | 
					
						
							|  |  |  | 		char reserved_0[4]; | 
					
						
							|  |  |  | 		unsigned short cpus_total; | 
					
						
							|  |  |  | 		unsigned short cpus_configured; | 
					
						
							|  |  |  | 		unsigned short cpus_standby; | 
					
						
							|  |  |  | 		unsigned short cpus_reserved; | 
					
						
							|  |  |  | 		char name[8]; | 
					
						
							|  |  |  | 		unsigned int caf; | 
					
						
							|  |  |  | 		char cpi[16]; | 
					
						
							|  |  |  | 		char reserved_1[24]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} vm[8]; | 
					
						
							| 
									
										
											  
											
												[S390] Fix hypervisor detection for KVM
Currently we use the cpuid (via STIDP instruction) to recognize LPAR,
z/VM and KVM.
The architecture states, that bit 0-7 of STIDP returns all zero, and
if STIDP is executed in a virtual machine, the VM operating system
will replace bits 0-7 with FF.
KVM should not use FE to distinguish z/VM from KVM for interested
guests. The proper way to detect the hypervisor is the STSI (Store
System Information) instruction, which return information about the
hypervisors via function code 3, selector1=2, selector2=2.
This patch changes the detection routine of Linux to use STSI instead
of STIDP. This detection is earlier than bootmem, we have to use a
static buffer. Since STSI expects a 4kb block (4kb aligned) this
patch also changes the init.data alignment for s390. As this section
will be freed during boot, this should be no problem.
Patch is tested with LPAR, z/VM, KVM on LPAR, and KVM under z/VM.
Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
											
										 
											2009-03-26 15:23:58 +01:00
										 |  |  | 	char reserved_544[3552]; | 
					
						
							| 
									
										
										
										
											2008-04-17 07:46:09 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-04 14:26:03 +02:00
										 |  |  | extern int topology_max_mnest; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-25 16:10:53 +02:00
										 |  |  | #define TOPOLOGY_CPU_BITS	64
 | 
					
						
							|  |  |  | #define TOPOLOGY_NR_MAG		6
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct topology_cpu { | 
					
						
							|  |  |  | 	unsigned char reserved0[4]; | 
					
						
							|  |  |  | 	unsigned char :6; | 
					
						
							|  |  |  | 	unsigned char pp:2; | 
					
						
							|  |  |  | 	unsigned char reserved1; | 
					
						
							|  |  |  | 	unsigned short origin; | 
					
						
							|  |  |  | 	unsigned long mask[TOPOLOGY_CPU_BITS / BITS_PER_LONG]; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct topology_container { | 
					
						
							|  |  |  | 	unsigned char reserved[7]; | 
					
						
							|  |  |  | 	unsigned char id; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | union topology_entry { | 
					
						
							|  |  |  | 	unsigned char nl; | 
					
						
							|  |  |  | 	struct topology_cpu cpu; | 
					
						
							|  |  |  | 	struct topology_container container; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sysinfo_15_1_x { | 
					
						
							|  |  |  | 	unsigned char reserved0[2]; | 
					
						
							|  |  |  | 	unsigned short length; | 
					
						
							|  |  |  | 	unsigned char mag[TOPOLOGY_NR_MAG]; | 
					
						
							|  |  |  | 	unsigned char reserved1; | 
					
						
							|  |  |  | 	unsigned char mnest; | 
					
						
							|  |  |  | 	unsigned char reserved2[4]; | 
					
						
							|  |  |  | 	union topology_entry tle[0]; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-06 14:42:13 +02:00
										 |  |  | int stsi(void *sysinfo, int fc, int sel1, int sel2); | 
					
						
							| 
									
										
										
										
											2008-04-30 13:38:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-25 13:38:49 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Service level reporting interface. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct service_level { | 
					
						
							|  |  |  | 	struct list_head list; | 
					
						
							|  |  |  | 	void (*seq_print)(struct seq_file *, struct service_level *); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int register_service_level(struct service_level *); | 
					
						
							|  |  |  | int unregister_service_level(struct service_level *); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-30 13:38:35 +02:00
										 |  |  | #endif /* __ASM_S390_SYSINFO_H */
 |