2003-01-05 12:17:12 +00:00
|
|
|
/* FEATCHK.H (c) Copyright Jan Jaeger, 2000-2003 */
|
2002-07-14 10:25:49 +00:00
|
|
|
/* Feature definition consistency checks */
|
2001-02-23 20:49:19 +00:00
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------*/
|
2002-07-14 10:25:49 +00:00
|
|
|
/* Perform various checks on feature combinations, and set */
|
|
|
|
|
/* additional flags to percolate certain features such as */
|
|
|
|
|
/* SIE down to lower architecture levels such that these */
|
|
|
|
|
/* can include emulation support */
|
2001-02-23 20:49:19 +00:00
|
|
|
/*-------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
|
|
#if defined(FEATCHK_CHECK_ALL)
|
|
|
|
|
|
|
|
|
|
/* FEATURE_INTERPRETIVE_EXECUTION is related to host related issues
|
|
|
|
|
_FEATURE_SIE is related to guest (emulation) related issues. This
|
|
|
|
|
because if FEATURE_INTERPRETIVE_EXECUTION is defined for say 390
|
|
|
|
|
mode, then _FEATURE_SIE will also need to be in 370 in order to
|
|
|
|
|
support 370 mode SIE emulation */
|
|
|
|
|
#if defined(FEATURE_INTERPRETIVE_EXECUTION)
|
|
|
|
|
#define _FEATURE_SIE
|
|
|
|
|
#if defined(FEATURE_ESAME)
|
|
|
|
|
#define _FEATURE_ZSIE
|
|
|
|
|
#endif
|
2002-12-05 13:27:27 +00:00
|
|
|
#if defined(FEATURE_PROTECTION_INTERCEPTION_CONTROL)
|
|
|
|
|
#define _FEATURE_PROTECTION_INTERCEPTION_CONTROL
|
|
|
|
|
#endif
|
2001-02-23 20:49:19 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* _FEATURE_MULTIPLE_CONTROLLED_DATA_SPACE is used for host
|
|
|
|
|
related processing issues, FEATURE_MULTIPLE_CONTROLLED_DATA_SPACE
|
|
|
|
|
is defined only in ESA/390 mode. MCDS is an ESA/390
|
|
|
|
|
feature that is supported under z/Architecture SIE */
|
|
|
|
|
#if defined(FEATURE_MULTIPLE_CONTROLLED_DATA_SPACE)
|
|
|
|
|
#define _FEATURE_MULTIPLE_CONTROLLED_DATA_SPACE
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-28 09:00:31 +00:00
|
|
|
#if defined(FEATURE_2K_STORAGE_KEYS)
|
2001-02-23 20:49:19 +00:00
|
|
|
#define _FEATURE_2K_STORAGE_KEYS
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_INTERVAL_TIMER)
|
|
|
|
|
#define _FEATURE_INTERVAL_TIMER
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_VECTOR_FACILITY)
|
|
|
|
|
#define _FEATURE_VECTOR_FACILITY
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-03-11 08:02:31 +00:00
|
|
|
#if defined(FEATURE_CHANNEL_SUBSYSTEM)
|
|
|
|
|
#define _FEATURE_CHANNEL_SUBSYSTEM
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-28 09:00:31 +00:00
|
|
|
#if defined(FEATURE_SYSTEM_CONSOLE)
|
|
|
|
|
#define _FEATURE_SYSTEM_CONSOLE
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-03-11 08:02:31 +00:00
|
|
|
#if defined(FEATURE_EXPANDED_STORAGE)
|
|
|
|
|
#define _FEATURE_EXPANDED_STORAGE
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if defined(_FEATURE_SIE) && defined(FEATURE_STORAGE_KEY_ASSIST)
|
|
|
|
|
#define _FEATURE_STORAGE_KEY_ASSIST
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_CPU_RECONFIG)
|
|
|
|
|
#define _FEATURE_CPU_RECONFIG
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-16 21:52:35 +00:00
|
|
|
#if defined(FEATURE_PER)
|
|
|
|
|
#define _FEATURE_PER
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_PER2)
|
|
|
|
|
#define _FEATURE_PER2
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-01-07 21:35:24 +00:00
|
|
|
#if defined(FEATURE_EXPEDITED_SIE_SUBSET)
|
|
|
|
|
#define _FEATURE_EXPEDITED_SIE_SUBSET
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_REGION_RELOCATE)
|
|
|
|
|
#define _FEATURE_REGION_RELOCATE
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_IO_ASSIST)
|
|
|
|
|
#define _FEATURE_IO_ASSIST
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_WAITSTATE_ASSIST)
|
|
|
|
|
#define _FEATURE_WAITSTATE_ASSIST
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_EXTERNAL_INTERRUPT_ASSIST)
|
|
|
|
|
#define _FEATURE_EXTERNAL_INTERRUPT_ASSIST
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#undef _VSTORE_C_STATIC
|
|
|
|
|
#if !defined(OPTION_NO_INLINE_VSTORE)
|
|
|
|
|
#define _VSTORE_C_STATIC static inline
|
|
|
|
|
#else
|
|
|
|
|
#define _VSTORE_C_STATIC
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-05-24 12:13:39 +00:00
|
|
|
#undef _VFETCH_C_STATIC
|
|
|
|
|
#if !defined(OPTION_NO_INLINE_IFETCH)
|
|
|
|
|
#define _VFETCH_C_STATIC static inline
|
|
|
|
|
#else
|
|
|
|
|
#define _VFETCH_C_STATIC
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#undef _DAT_C_STATIC
|
|
|
|
|
#if !defined(OPTION_NO_INLINE_DAT)
|
|
|
|
|
#define _DAT_C_STATIC static inline
|
|
|
|
|
#else
|
|
|
|
|
#define _DAT_C_STATIC
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-09-27 18:13:14 +00:00
|
|
|
#undef _LOGICAL_C_STATIC
|
|
|
|
|
#if !defined(OPTION_NO_INLINE_LOGICAL)
|
|
|
|
|
#define _LOGICAL_C_STATIC static inline
|
|
|
|
|
#else
|
|
|
|
|
#define _LOGICAL_C_STATIC
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-28 09:00:31 +00:00
|
|
|
#if !defined(OPTION_370_MODE) \
|
|
|
|
|
&& !defined(OPTION_390_MODE) \
|
|
|
|
|
&& !defined(OPTION_900_MODE)
|
|
|
|
|
#error No Architecture mode
|
|
|
|
|
#endif
|
|
|
|
|
#if defined(OPTION_370_MODE)
|
|
|
|
|
#define _370
|
|
|
|
|
#define _ARCHMODE1 370
|
|
|
|
|
#define ARCH_370 0
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(OPTION_390_MODE)
|
|
|
|
|
#define _390
|
|
|
|
|
#if !defined(_ARCHMODE1)
|
|
|
|
|
#define _ARCHMODE1 390
|
|
|
|
|
#define ARCH_390 0
|
|
|
|
|
#else
|
|
|
|
|
#define _ARCHMODE2 390
|
|
|
|
|
#define ARCH_390 1
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(OPTION_900_MODE)
|
|
|
|
|
#define _900
|
|
|
|
|
#if !defined(_ARCHMODE2)
|
|
|
|
|
#define _ARCHMODE2 900
|
|
|
|
|
#define ARCH_900 1
|
|
|
|
|
#else
|
|
|
|
|
#define _ARCHMODE3 900
|
|
|
|
|
#define ARCH_900 2
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if !defined(ARCH_370)
|
|
|
|
|
#define ARCH_370 -1
|
|
|
|
|
#endif
|
|
|
|
|
#if !defined(ARCH_390)
|
|
|
|
|
#define ARCH_390 -1
|
|
|
|
|
#endif
|
|
|
|
|
#if !defined(ARCH_900)
|
|
|
|
|
#define ARCH_900 -1
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(_ARCHMODE3)
|
2002-07-14 10:25:49 +00:00
|
|
|
#define GEN_MAXARCH 3+2
|
2001-12-28 09:00:31 +00:00
|
|
|
#elif defined(_ARCHMODE2)
|
2002-07-14 10:25:49 +00:00
|
|
|
#define GEN_MAXARCH 2+2
|
2001-12-28 09:00:31 +00:00
|
|
|
#else
|
2002-07-14 10:25:49 +00:00
|
|
|
#define GEN_MAXARCH 1+2
|
2001-12-28 09:00:31 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(_900) && !defined(_390)
|
|
|
|
|
#error OPTION_390_MODE must be enabled for OPTION_900_MODE
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#else /*!defined(FEATCHK_CHECK_ALL)*/
|
|
|
|
|
|
2001-05-21 19:25:48 +00:00
|
|
|
/* When ESAME is installed then all instructions
|
|
|
|
|
marked N3 in the reference are also available
|
|
|
|
|
in ESA/390 mode */
|
2001-12-28 09:00:31 +00:00
|
|
|
#if defined(_900)
|
2001-05-21 19:25:48 +00:00
|
|
|
#define FEATURE_ESAME_N3_ESA390
|
2001-12-28 09:00:31 +00:00
|
|
|
#endif /*defined(_900)*/
|
2001-05-21 19:25:48 +00:00
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if !defined(FEATURE_2K_STORAGE_KEYS) \
|
|
|
|
|
&& !defined(FEATURE_4K_STORAGE_KEYS)
|
|
|
|
|
#error Storage keys must be 2K or 4K
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-08-25 15:47:31 +00:00
|
|
|
#if defined(FEATURE_EXTENDED_STORAGE_KEYS)
|
|
|
|
|
#if !defined(FEATURE_S370E_EXTENDED_ADDRESSING)
|
|
|
|
|
#define FEATURE_S370E_EXTENDED_ADDRESSING
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if defined(FEATURE_EXPANDED_STORAGE) \
|
|
|
|
|
&& !defined(FEATURE_4K_STORAGE_KEYS)
|
|
|
|
|
#error Expanded storage cannot be defined with 2K storage keys
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-28 09:00:31 +00:00
|
|
|
#if defined(_900) && defined(FEATURE_VECTOR_FACILITY)
|
2001-04-08 19:04:48 +00:00
|
|
|
#error Vector Facility not supported on ESAME capable processors
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if defined(FEATURE_MOVE_PAGE_FACILITY_2) \
|
|
|
|
|
&& !defined(FEATURE_4K_STORAGE_KEYS)
|
|
|
|
|
#error Move page facility cannot be defined with 2K storage keys
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-28 09:00:31 +00:00
|
|
|
#if defined(FEATURE_ESAME) \
|
|
|
|
|
&& defined(FEATURE_INTERPRETIVE_EXECUTION) \
|
|
|
|
|
&& !defined(_FEATURE_SIE)
|
|
|
|
|
#error ESA/390 SIE must be defined when defining ESAME SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if defined(FEATURE_MULTIPLE_CONTROLLED_DATA_SPACE) \
|
|
|
|
|
&& !defined(FEATURE_INTERPRETIVE_EXECUTION)
|
|
|
|
|
#error MCDS only supported with SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-12-05 13:27:27 +00:00
|
|
|
#if defined(FEATURE_PROTECTION_INTERCEPTION_CONTROL) \
|
|
|
|
|
&& !defined(FEATURE_INTERPRETIVE_EXECUTION)
|
|
|
|
|
#error Protection Interception Control only supported with SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if defined(FEATURE_MULTIPLE_CONTROLLED_DATA_SPACE) \
|
|
|
|
|
&& !defined(FEATURE_STORAGE_KEY_ASSIST)
|
|
|
|
|
#error MCDS requires storage key assist
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-03-06 18:04:21 +00:00
|
|
|
#if defined(FEATURE_SIE) && defined(FEATURE_ESAME) \
|
|
|
|
|
&& !defined(FEATURE_STORAGE_KEY_ASSIST)
|
|
|
|
|
#error ESAME SIE requires storage key assist
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if defined(FEATURE_STORAGE_KEY_ASSIST) \
|
|
|
|
|
&& !defined(FEATURE_INTERPRETIVE_EXECUTION)
|
|
|
|
|
#error Storage Key assist only supported with SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-01-07 21:35:24 +00:00
|
|
|
#if defined(FEATURE_REGION_RELOCATE) \
|
|
|
|
|
&& !defined(FEATURE_INTERPRETIVE_EXECUTION)
|
|
|
|
|
#error Region Relocate Facility only supported with SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_IO_ASSIST) \
|
|
|
|
|
&& !defined(_FEATURE_SIE)
|
|
|
|
|
#error I/O Assist Feature only supported with SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_EXTERNAL_INTERRUPT_ASSIST) \
|
|
|
|
|
&& !defined(_FEATURE_SIE)
|
|
|
|
|
#error External Interruption assist only supported with SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_EXPEDITED_SIE_SUBSET) \
|
|
|
|
|
&& !defined(_FEATURE_SIE)
|
|
|
|
|
#error Expedited SIE Subset only supported with SIE
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#if defined(FEATURE_ESAME) \
|
|
|
|
|
&& defined(FEATURE_VECTOR_FACILITY)
|
|
|
|
|
#error Vector Facility not supported in ESAME mode
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_BINARY_FLOATING_POINT) \
|
2001-06-03 10:48:00 +00:00
|
|
|
&& defined(NO_IEEE_SUPPORT)
|
2001-02-23 20:49:19 +00:00
|
|
|
#undef FEATURE_BINARY_FLOATING_POINT
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(FEATURE_BASIC_FP_EXTENSIONS) \
|
|
|
|
|
&& !defined(FEATURE_HEXADECIMAL_FLOATING_POINT)
|
|
|
|
|
#error Basic FP extensions requires hexadecimal floating point
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if !defined(FEATURE_BASIC_FP_EXTENSIONS)
|
|
|
|
|
#if defined(FEATURE_BINARY_FLOATING_POINT) \
|
|
|
|
|
|| defined(FEATURE_HFP_EXTENSIONS) \
|
|
|
|
|
|| defined(FEATURE_FPS_EXTENSIONS)
|
|
|
|
|
#error Floating point extensions require basic FP extensions
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-10 11:55:41 +00:00
|
|
|
#if defined(FEATURE_PER2) && !defined(FEATURE_PER)
|
|
|
|
|
#error FEATURE_PER must be defined when using FEATURE_PER2
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
2001-02-23 20:49:19 +00:00
|
|
|
#endif /*!defined(FEATALL_CHECKALL)*/
|
|
|
|
|
|
|
|
|
|
/* end of FEATCHK.H */
|