/**/ /***************************************************************************/ /** **/ /** © Copyright 2010, Hewlett-Packard Development Company, L.P. **/ /** **/ /** Confidential computer software. Valid license from HP and/or **/ /** its subsidiaries required for possession, use, or copying. **/ /** **/ /** Consistent with FAR 12.211 and 12.212, Commercial Computer Software, **/ /** Computer Software Documentation, and Technical Data for Commercial **/ /** Items are licensed to the U.S. Government under vendor's standard **/ /** commercial license. **/ /** **/ /** Neither HP nor any of its subsidiaries shall be liable for technical **/ /** or editorial errors or omissions contained herein. The information **/ /** in this document is provided "as is" without warranty of any kind and **/ /** is subject to change without notice. The warranties for HP products **/ /** are set forth in the express limited warranty statements accompanying **/ /** such products. Nothing herein should be construed as constituting an **/ /** additional warranty. **/ /** **/ /***************************************************************************/ /********************************************************************************************************************************/ /* Created: 30-Mar-2010 17:24:20 by OpenVMS SDL EV3-3 */ /* Source: 31-OCT-2009 05:22:35 $1$DGA7274:[LIB_H.SRC]RADDEF.SDL;1 */ /********************************************************************************************************************************/ /*** MODULE $RADDEF ***/ #ifndef __RADDEF_LOADED #define __RADDEF_LOADED 1 #pragma __nostandard /* This file uses non-ANSI-Standard features */ #pragma __member_alignment __save #pragma __nomember_alignment #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __save /* Save the previously-defined required ptr size */ #pragma __required_pointer_size __short /* And set ptr size default to 32-bit pointers */ #endif #ifdef __cplusplus extern "C" { #define __unknown_params ... #define __optional_params ... #else #define __unknown_params #define __optional_params ... #endif #ifndef __struct #if !defined(__VAXC) #define __struct struct #else #define __struct variant_struct #endif #endif #ifndef __union #if !defined(__VAXC) #define __union union #else #define __union variant_union #endif #endif /*+ */ /* RAD Database - Structure containing information about a particular Resource Affinity Domain (RAD) */ /* within a system. This structure also serves as the base for other structures */ /* which are defined for each RAD. */ /* */ /* */ #define RAD$M_NO_MEMORY 0x1 #define RAD$M_NO_POOL 0x2 #define RAD$C_MAX_RADS 32 /* Maximum number of RADs possible */ #ifdef __cplusplus /* Define structure prototypes */ struct _pcb; struct _kpb; #endif /* #ifdef __cplusplus */ #if !defined(__NOBASEALIGN_SUPPORT) && !defined(__cplusplus) /* If using pre DECC V4.0 or C++ */ #pragma __nomember_alignment __quadword #else #pragma __nomember_alignment #endif typedef struct _rad { #pragma __nomember_alignment unsigned int rad$l_rad_id; /* The (0-based) RAD number represented by this structure */ __union { unsigned int rad$l_flags; __struct { unsigned rad$v_no_memory : 1; /* indicator if Rad has no memory */ unsigned rad$v_no_pool : 1; /* indicator if Rad has no pool */ unsigned rad$v_reserved : 30; /* Reserved for future use */ } rad$r_flags_bits; } rad$r_flags_overlay; unsigned short int rad$w_mbo; /* Part of 64-bit header. Must be 1 */ unsigned char rad$b_type; /* DYN$C_MISC */ unsigned char rad$b_subtype; /* DYN$C_RAD */ int rad$l_cfg_hard_id; /* "Hard" id of CFG node corresponding to or containing this RAD */ /* can go here. */ unsigned __int64 rad$q_size; /* Size of structure in bytes */ /* End of 64-bit header */ unsigned __int64 rad$q_cfg_handle; /* Handle to find node corresponding to or */ /* containing this RAD. */ #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __long /* And set ptr size default to 64-bit pointers */ void *rad$pq_cpu_cbb; /* Pointer to bitmask of CPUs or 0 */ #else unsigned __int64 rad$pq_cpu_cbb; #endif unsigned __int64 rad$q_cpu_mask; /* Bitmask if CBB ptr is 0 */ #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __long /* And set ptr size default to 64-bit pointers */ void *rad$pq_distance_array; /* Pointer to an array of "distances" to other RADs */ #else unsigned __int64 rad$pq_distance_array; #endif /* (Array length is RIH$L_MAX_RADS) */ #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __long /* And set ptr size default to 64-bit pointers */ void *rad$pq_pfn_array; /* Pointer to an array of PFN begin/end */ #else unsigned __int64 rad$pq_pfn_array; #endif /* pairs on this RAD. 0 if n/a. (Use shift values from RIH) */ __int64 rad$q_pfn_array_length; /* How many PA pairs in the above list (in Wildfire, it would be 1) */ #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __short /* And set ptr size default to 32-bit pointers */ #endif struct _pcb *rad$l_pcb_cache; /* The per-RAD PCB cache */ int rad$l_spare1; /* Fill to quadword boundary */ #if !defined(__NOBASEALIGN_SUPPORT) && !defined(__cplusplus) /* If using pre DECC V4.0 or C++ */ #pragma __nomember_alignment __quadword #else #pragma __nomember_alignment #endif __union { #pragma __nomember_alignment #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __long /* And set ptr size default to 64-bit pointers */ struct _kpb *rad$q_kpb_cache; /* The per-RAD KPB cache */ #else unsigned __int64 rad$q_kpb_cache; #endif __struct { #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __short /* And set ptr size default to 32-bit pointers */ #endif struct _kpb *rad$ps_kpb_cache; unsigned int rad$l_sequence; } rad$r_lal_longwords_struct; } rad$r_cache_overlay; __int64 rad$q_spare2; /* Extra space to debug with */ __int64 rad$q_spare3; int rad$l_zeroed_list_count; /* Count of zeroed pages */ int rad$l_zero_list_hi_lim; /* Maxumum pages to zero for RAD */ int rad$l_base_rad_1; /* Best ILM or CLM RAD to be used by this RAD */ int rad$l_base_rad_2; /* Next best ILM or CLM RAD to be used by this RAD */ /* Add new pointers or info here */ } RAD; #if !defined(__VAXC) #define rad$l_flags rad$r_flags_overlay.rad$l_flags #define rad$v_no_memory rad$r_flags_overlay.rad$r_flags_bits.rad$v_no_memory #define rad$v_no_pool rad$r_flags_overlay.rad$r_flags_bits.rad$v_no_pool #define rad$v_reserved rad$r_flags_overlay.rad$r_flags_bits.rad$v_reserved #define rad$q_kpb_cache rad$r_cache_overlay.rad$q_kpb_cache #define rad$ps_kpb_cache rad$r_cache_overlay.rad$r_lal_longwords_struct.rad$ps_kpb_cache #define rad$l_sequence rad$r_cache_overlay.rad$r_lal_longwords_struct.rad$l_sequence #endif /* #if !defined(__VAXC) */ #define RAD$C_LENGTH 120 /* Length of RAD */ #ifdef __INITIAL_POINTER_SIZE #pragma __required_pointer_size __save /* Save current pointer size */ #pragma __required_pointer_size __long /* Pointers are 64-bit */ typedef struct _rad *RAD_PQ; /* Pointer to a RAD structure. */ typedef struct _rad **RAD_PPQ; /* Pointer to a pointer to a RAD structure. */ #pragma __required_pointer_size __restore /* Return to previous pointer size */ #else typedef unsigned __int64 RAD_PQ; #endif /* __INITIAL_POINTER_SIZE */ #pragma __member_alignment __restore #ifdef __INITIAL_POINTER_SIZE /* Defined whenever ptr size pragmas supported */ #pragma __required_pointer_size __restore /* Restore the previously-defined required ptr size */ #endif #ifdef __cplusplus } #endif #pragma __standard #endif /* __RADDEF_LOADED */