| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *  Copyright (C) 2001 Ben. Herrenschmidt (benh@kernel.crashing.org) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Modifications for ppc64: | 
					
						
							|  |  |  |  *      Copyright (C) 2003 Dave Engebretsen <engebret@us.ibm.com> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  *  modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  *  as published by the Free Software Foundation; either version | 
					
						
							|  |  |  |  *  2 of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-10-24 15:07:29 +10:00
										 |  |  | #ifndef __ASM_POWERPC_FIRMWARE_H
 | 
					
						
							|  |  |  | #define __ASM_POWERPC_FIRMWARE_H
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __KERNEL__
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-25 18:19:00 +10:00
										 |  |  | #include <asm/asm-compat.h>
 | 
					
						
							| 
									
										
										
										
											2008-06-24 11:32:39 +10:00
										 |  |  | #include <asm/feature-fixups.h>
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* firmware feature bitmask values */ | 
					
						
							|  |  |  | #define FIRMWARE_MAX_FEATURES 63
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-25 18:19:00 +10:00
										 |  |  | #define FW_FEATURE_PFT		ASM_CONST(0x0000000000000001)
 | 
					
						
							|  |  |  | #define FW_FEATURE_TCE		ASM_CONST(0x0000000000000002)
 | 
					
						
							|  |  |  | #define FW_FEATURE_SPRG0	ASM_CONST(0x0000000000000004)
 | 
					
						
							|  |  |  | #define FW_FEATURE_DABR		ASM_CONST(0x0000000000000008)
 | 
					
						
							|  |  |  | #define FW_FEATURE_COPY		ASM_CONST(0x0000000000000010)
 | 
					
						
							|  |  |  | #define FW_FEATURE_ASR		ASM_CONST(0x0000000000000020)
 | 
					
						
							|  |  |  | #define FW_FEATURE_DEBUG	ASM_CONST(0x0000000000000040)
 | 
					
						
							|  |  |  | #define FW_FEATURE_TERM		ASM_CONST(0x0000000000000080)
 | 
					
						
							|  |  |  | #define FW_FEATURE_PERF		ASM_CONST(0x0000000000000100)
 | 
					
						
							|  |  |  | #define FW_FEATURE_DUMP		ASM_CONST(0x0000000000000200)
 | 
					
						
							|  |  |  | #define FW_FEATURE_INTERRUPT	ASM_CONST(0x0000000000000400)
 | 
					
						
							|  |  |  | #define FW_FEATURE_MIGRATE	ASM_CONST(0x0000000000000800)
 | 
					
						
							|  |  |  | #define FW_FEATURE_PERFMON	ASM_CONST(0x0000000000001000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_CRQ		ASM_CONST(0x0000000000002000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_VIO		ASM_CONST(0x0000000000004000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_RDMA		ASM_CONST(0x0000000000008000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_LLAN		ASM_CONST(0x0000000000010000)
 | 
					
						
							| 
									
										
										
										
											2009-10-11 21:47:34 +00:00
										 |  |  | #define FW_FEATURE_BULK_REMOVE	ASM_CONST(0x0000000000020000)
 | 
					
						
							| 
									
										
										
										
											2006-09-25 18:19:00 +10:00
										 |  |  | #define FW_FEATURE_XDABR	ASM_CONST(0x0000000000040000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_MULTITCE	ASM_CONST(0x0000000000080000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_SPLPAR	ASM_CONST(0x0000000000100000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_LPAR		ASM_CONST(0x0000000000400000)
 | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:57 +01:00
										 |  |  | #define FW_FEATURE_PS3_LV1	ASM_CONST(0x0000000000800000)
 | 
					
						
							| 
									
										
										
										
											2007-02-02 16:47:17 +09:00
										 |  |  | #define FW_FEATURE_BEAT		ASM_CONST(0x0000000001000000)
 | 
					
						
							| 
									
										
										
										
											2009-10-11 21:47:34 +00:00
										 |  |  | #define FW_FEATURE_CMO		ASM_CONST(0x0000000002000000)
 | 
					
						
							| 
									
										
										
										
											2010-11-09 13:24:48 +00:00
										 |  |  | #define FW_FEATURE_VPHN		ASM_CONST(0x0000000004000000)
 | 
					
						
							| 
									
										
										
										
											2011-05-04 16:01:20 +10:00
										 |  |  | #define FW_FEATURE_XCMO		ASM_CONST(0x0000000008000000)
 | 
					
						
							| 
									
										
										
										
											2011-09-19 17:44:57 +00:00
										 |  |  | #define FW_FEATURE_OPAL		ASM_CONST(0x0000000010000000)
 | 
					
						
							|  |  |  | #define FW_FEATURE_OPALv2	ASM_CONST(0x0000000020000000)
 | 
					
						
							| 
									
										
										
										
											2006-09-25 18:19:00 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef __ASSEMBLY__
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:40:16 +10:00
										 |  |  | enum { | 
					
						
							| 
									
										
										
										
											2005-11-10 13:37:51 +11:00
										 |  |  | #ifdef CONFIG_PPC64
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:43:21 +10:00
										 |  |  | 	FW_FEATURE_PSERIES_POSSIBLE = FW_FEATURE_PFT | FW_FEATURE_TCE | | 
					
						
							| 
									
										
										
										
											2005-08-03 14:40:16 +10:00
										 |  |  | 		FW_FEATURE_SPRG0 | FW_FEATURE_DABR | FW_FEATURE_COPY | | 
					
						
							|  |  |  | 		FW_FEATURE_ASR | FW_FEATURE_DEBUG | FW_FEATURE_TERM | | 
					
						
							|  |  |  | 		FW_FEATURE_PERF | FW_FEATURE_DUMP | FW_FEATURE_INTERRUPT | | 
					
						
							|  |  |  | 		FW_FEATURE_MIGRATE | FW_FEATURE_PERFMON | FW_FEATURE_CRQ | | 
					
						
							|  |  |  | 		FW_FEATURE_VIO | FW_FEATURE_RDMA | FW_FEATURE_LLAN | | 
					
						
							| 
									
										
										
										
											2009-10-11 21:47:34 +00:00
										 |  |  | 		FW_FEATURE_BULK_REMOVE | FW_FEATURE_XDABR | | 
					
						
							|  |  |  | 		FW_FEATURE_MULTITCE | FW_FEATURE_SPLPAR | FW_FEATURE_LPAR | | 
					
						
							| 
									
										
										
										
											2011-05-04 16:01:20 +10:00
										 |  |  | 		FW_FEATURE_CMO | FW_FEATURE_VPHN | FW_FEATURE_XCMO, | 
					
						
							| 
									
										
										
										
											2005-08-03 14:43:21 +10:00
										 |  |  | 	FW_FEATURE_PSERIES_ALWAYS = 0, | 
					
						
							| 
									
										
										
										
											2011-09-19 17:44:57 +00:00
										 |  |  | 	FW_FEATURE_POWERNV_POSSIBLE = FW_FEATURE_OPAL | FW_FEATURE_OPALv2, | 
					
						
							|  |  |  | 	FW_FEATURE_POWERNV_ALWAYS = 0, | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:57 +01:00
										 |  |  | 	FW_FEATURE_PS3_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, | 
					
						
							|  |  |  | 	FW_FEATURE_PS3_ALWAYS = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, | 
					
						
							| 
									
										
										
										
											2007-02-02 16:47:17 +09:00
										 |  |  | 	FW_FEATURE_CELLEB_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_BEAT, | 
					
						
							| 
									
										
										
										
											2007-12-04 19:38:24 +11:00
										 |  |  | 	FW_FEATURE_CELLEB_ALWAYS = 0, | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:57 +01:00
										 |  |  | 	FW_FEATURE_NATIVE_POSSIBLE = 0, | 
					
						
							|  |  |  | 	FW_FEATURE_NATIVE_ALWAYS = 0, | 
					
						
							| 
									
										
										
										
											2005-08-03 14:40:16 +10:00
										 |  |  | 	FW_FEATURE_POSSIBLE = | 
					
						
							|  |  |  | #ifdef CONFIG_PPC_PSERIES
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:43:21 +10:00
										 |  |  | 		FW_FEATURE_PSERIES_POSSIBLE | | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-09-19 17:44:57 +00:00
										 |  |  | #ifdef CONFIG_PPC_POWERNV
 | 
					
						
							|  |  |  | 		FW_FEATURE_POWERNV_POSSIBLE | | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:56 +01:00
										 |  |  | #ifdef CONFIG_PPC_PS3
 | 
					
						
							| 
									
										
										
										
											2006-11-23 00:46:53 +01:00
										 |  |  | 		FW_FEATURE_PS3_POSSIBLE | | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:57 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-02-02 16:47:17 +09:00
										 |  |  | #ifdef CONFIG_PPC_CELLEB
 | 
					
						
							|  |  |  | 		FW_FEATURE_CELLEB_POSSIBLE | | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:57 +01:00
										 |  |  | #ifdef CONFIG_PPC_NATIVE
 | 
					
						
							|  |  |  | 		FW_FEATURE_NATIVE_ALWAYS | | 
					
						
							| 
									
										
										
										
											2005-08-03 14:40:16 +10:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 		0, | 
					
						
							| 
									
										
										
										
											2005-08-03 14:43:21 +10:00
										 |  |  | 	FW_FEATURE_ALWAYS = | 
					
						
							|  |  |  | #ifdef CONFIG_PPC_PSERIES
 | 
					
						
							|  |  |  | 		FW_FEATURE_PSERIES_ALWAYS & | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-09-19 17:44:57 +00:00
										 |  |  | #ifdef CONFIG_PPC_POWERNV
 | 
					
						
							|  |  |  | 		FW_FEATURE_POWERNV_ALWAYS & | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:56 +01:00
										 |  |  | #ifdef CONFIG_PPC_PS3
 | 
					
						
							| 
									
										
										
										
											2006-11-23 00:46:53 +01:00
										 |  |  | 		FW_FEATURE_PS3_ALWAYS & | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:57 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-02-02 16:47:17 +09:00
										 |  |  | #ifdef CONFIG_PPC_CELLEB
 | 
					
						
							|  |  |  | 		FW_FEATURE_CELLEB_ALWAYS & | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-11-27 19:18:57 +01:00
										 |  |  | #ifdef CONFIG_PPC_NATIVE
 | 
					
						
							|  |  |  | 		FW_FEATURE_NATIVE_ALWAYS & | 
					
						
							| 
									
										
										
										
											2005-08-03 14:43:21 +10:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 		FW_FEATURE_POSSIBLE, | 
					
						
							| 
									
										
										
										
											2005-11-10 13:37:51 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | #else /* CONFIG_PPC64 */
 | 
					
						
							|  |  |  | 	FW_FEATURE_POSSIBLE = 0, | 
					
						
							|  |  |  | 	FW_FEATURE_ALWAYS = 0, | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:40:16 +10:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | /* This is used to identify firmware features which are available
 | 
					
						
							|  |  |  |  * to the kernel. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2006-03-27 14:26:25 +11:00
										 |  |  | extern unsigned long	powerpc_firmware_features; | 
					
						
							| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-23 23:33:03 +11:00
										 |  |  | #define firmware_has_feature(feature)					\
 | 
					
						
							|  |  |  | 	((FW_FEATURE_ALWAYS & (feature)) ||				\ | 
					
						
							| 
									
										
										
										
											2006-03-27 14:26:25 +11:00
										 |  |  | 		(FW_FEATURE_POSSIBLE & powerpc_firmware_features & (feature))) | 
					
						
							| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-04 18:39:33 +11:00
										 |  |  | extern void system_reset_fwnmi(void); | 
					
						
							|  |  |  | extern void machine_check_fwnmi(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This is true if we are using the firmware NMI handler (typically LPAR) */ | 
					
						
							|  |  |  | extern int fwnmi_active; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-10-24 16:42:40 +10:00
										 |  |  | extern unsigned int __start___fw_ftr_fixup, __stop___fw_ftr_fixup; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-03 14:35:25 +10:00
										 |  |  | #endif /* __ASSEMBLY__ */
 | 
					
						
							|  |  |  | #endif /* __KERNEL__ */
 | 
					
						
							| 
									
										
										
										
											2005-10-24 15:07:29 +10:00
										 |  |  | #endif /* __ASM_POWERPC_FIRMWARE_H */
 |