mirror of https://github.com/containers/podman.git
				
				
				
			
		
			
				
	
	
		
			636 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			636 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Go
		
	
	
	
| // +build aix
 | |
| 
 | |
| package perfstat
 | |
| 
 | |
| import "golang.org/x/sys/unix"
 | |
| 
 | |
| // function Getsystemcfg() is defined in golang.org/x/sys/unix
 | |
| // we define here just missing constants for the function and some helpers
 | |
| 
 | |
| // Calls to getsystemcfg()
 | |
| const (
 | |
| 	SC_ARCH         = 1  /* processor architecture */
 | |
| 	SC_IMPL         = 2  /* processor implementation */
 | |
| 	SC_VERS         = 3  /* processor version */
 | |
| 	SC_WIDTH        = 4  /* width (32 || 64) */
 | |
| 	SC_NCPUS        = 5  /* 1 = UP, n = n-way MP */
 | |
| 	SC_L1C_ATTR     = 6  /* L1 cache attributes (bit flags) */
 | |
| 	SC_L1C_ISZ      = 7  /* size of L1 instruction cache */
 | |
| 	SC_L1C_DSZ      = 8  /* size of L1 data cache */
 | |
| 	SC_L1C_ICA      = 9  /* L1 instruction cache associativity */
 | |
| 	SC_L1C_DCA      = 10 /* L1 data cache associativity */
 | |
| 	SC_L1C_IBS      = 11 /* L1 instruction cache block size */
 | |
| 	SC_L1C_DBS      = 12 /* L1 data cache block size */
 | |
| 	SC_L1C_ILS      = 13 /* L1 instruction cache line size */
 | |
| 	SC_L1C_DLS      = 14 /* L1 data cache line size */
 | |
| 	SC_L2C_SZ       = 15 /* size of L2 cache, 0 = No L2 cache */
 | |
| 	SC_L2C_AS       = 16 /* L2 cache associativity */
 | |
| 	SC_TLB_ATTR     = 17 /* TLB attributes (bit flags) */
 | |
| 	SC_ITLB_SZ      = 18 /* entries in instruction TLB */
 | |
| 	SC_DTLB_SZ      = 19 /* entries in data TLB */
 | |
| 	SC_ITLB_ATT     = 20 /* instruction tlb associativity */
 | |
| 	SC_DTLB_ATT     = 21 /* data tlb associativity */
 | |
| 	SC_RESRV_SZ     = 22 /* size of reservation */
 | |
| 	SC_PRI_LC       = 23 /* spin lock count in supevisor mode */
 | |
| 	SC_PRO_LC       = 24 /* spin lock count in problem state */
 | |
| 	SC_RTC_TYPE     = 25 /* RTC type */
 | |
| 	SC_VIRT_AL      = 26 /* 1 if hardware aliasing is supported */
 | |
| 	SC_CAC_CONG     = 27 /* number of page bits for cache synonym */
 | |
| 	SC_MOD_ARCH     = 28 /* used by system for model determination */
 | |
| 	SC_MOD_IMPL     = 29 /* used by system for model determination */
 | |
| 	SC_XINT         = 30 /* used by system for time base conversion */
 | |
| 	SC_XFRAC        = 31 /* used by system for time base conversion */
 | |
| 	SC_KRN_ATTR     = 32 /* kernel attributes, see below */
 | |
| 	SC_PHYSMEM      = 33 /* bytes of OS available memory */
 | |
| 	SC_SLB_ATTR     = 34 /* SLB attributes */
 | |
| 	SC_SLB_SZ       = 35 /* size of slb (0 = no slb) */
 | |
| 	SC_ORIG_NCPUS   = 36 /* original number of CPUs */
 | |
| 	SC_MAX_NCPUS    = 37 /* max cpus supported by this AIX image */
 | |
| 	SC_MAX_REALADDR = 38 /* max supported real memory address +1 */
 | |
| 	SC_ORIG_ENT_CAP = 39 /* configured entitled processor capacity at boot required by cross-partition LPAR tools. */
 | |
| 	SC_ENT_CAP      = 40 /* entitled processor capacity */
 | |
| 	SC_DISP_WHE     = 41 /* Dispatch wheel time period (TB units) */
 | |
| 	SC_CAPINC       = 42 /* delta by which capacity can change */
 | |
| 	SC_VCAPW        = 43 /* priority weight for idle capacity distribution */
 | |
| 	SC_SPLP_STAT    = 44 /* State of SPLPAR enablement: 0x1 => 1=SPLPAR capable; 0=not, 0x2 => SPLPAR enabled 0=dedicated, 1=shared */
 | |
| 	SC_SMT_STAT     = 45 /* State of SMT enablement: 0x1 = SMT Capable  0=no/1=yes, 0x2 = SMT Enabled  0=no/1=yes, 0x4 = SMT threads bound true 0=no/1=yes */
 | |
| 	SC_SMT_TC       = 46 /* Number of SMT Threads per Physical CPU */
 | |
| 	SC_VMX_VER      = 47 /* RPA defined VMX version: 0 = VMX not available or disabled, 1 = VMX capable, 2 = VMX and VSX capable */
 | |
| 	SC_LMB_SZ       = 48 /* Size of an LMB on this system. */
 | |
| 	SC_MAX_XCPU     = 49 /* Number of exclusive cpus on line */
 | |
| 	SC_EC_LVL       = 50 /* Kernel error checking level */
 | |
| 	SC_AME_STAT     = 51 /* AME status */
 | |
| 	SC_ECO_STAT     = 52 /* extended cache options */
 | |
| 	SC_DFP_STAT     = 53 /* RPA defined DFP version, 0=none/disabled */
 | |
| 	SC_VRM_STAT     = 54 /* VRM Capable/enabled */
 | |
| 	SC_PHYS_IMP     = 55 /* physical processor implementation */
 | |
| 	SC_PHYS_VER     = 56 /* physical processor version */
 | |
| 	SC_SPCM_STATUS  = 57
 | |
| 	SC_SPCM_MAX     = 58
 | |
| 	SC_TM_VER       = 59 /* Transaction Memory version, 0 - not capable */
 | |
| 	SC_NX_CAP       = 60 /* NX GZIP capable */
 | |
| 	SC_PKS_STATE    = 61 /* Platform KeyStore */
 | |
| )
 | |
| 
 | |
| /* kernel attributes                        */
 | |
| /* bit          0/1 meaning                 */
 | |
| /* -----------------------------------------*/
 | |
| /* 31   32-bit kernel / 64-bit kernel       */
 | |
| /* 30   non-LPAR      / LPAR                */
 | |
| /* 29   old 64bit ABI / 64bit Large ABI     */
 | |
| /* 28   non-NUMA      / NUMA                */
 | |
| /* 27   UP            / MP                  */
 | |
| /* 26   no DR CPU add / DR CPU add support  */
 | |
| /* 25   no DR CPU rm  / DR CPU rm  support  */
 | |
| /* 24   no DR MEM add / DR MEM add support  */
 | |
| /* 23   no DR MEM rm  / DR MEM rm  support  */
 | |
| /* 22   kernel keys disabled / enabled      */
 | |
| /* 21   no recovery   / recovery enabled    */
 | |
| /* 20   non-MLS    / MLS enabled            */
 | |
| /* 19   enhanced affinity indicator         */
 | |
| /* 18   non-vTPM    / vTPM enabled          */
 | |
| /* 17   non-VIOS    / VIOS                  */
 | |
| 
 | |
| // Values for architecture field
 | |
| const (
 | |
| 	ARCH_POWER_RS = 0x0001 /* Power Classic architecture */
 | |
| 	ARCH_POWER_PC = 0x0002 /* Power PC architecture */
 | |
| 	ARCH_IA64     = 0x0003 /* Intel IA64 architecture */
 | |
| )
 | |
| 
 | |
| // Values for implementation field for POWER_PC Architectures
 | |
| const (
 | |
| 	IMPL_POWER_RS1     = 0x00001     /* RS1 class CPU */
 | |
| 	IMPL_POWER_RSC     = 0x00002     /* RSC class CPU */
 | |
| 	IMPL_POWER_RS2     = 0x00004     /* RS2 class CPU */
 | |
| 	IMPL_POWER_601     = 0x00008     /* 601 class CPU */
 | |
| 	IMPL_POWER_603     = 0x00020     /* 603 class CPU */
 | |
| 	IMPL_POWER_604     = 0x00010     /* 604 class CPU */
 | |
| 	IMPL_POWER_620     = 0x00040     /* 620 class CPU */
 | |
| 	IMPL_POWER_630     = 0x00080     /* 630 class CPU */
 | |
| 	IMPL_POWER_A35     = 0x00100     /* A35 class CPU */
 | |
| 	IMPL_POWER_RS64II  = 0x0200      /* RS64-II class CPU */
 | |
| 	IMPL_POWER_RS64III = 0x0400      /* RS64-III class CPU */
 | |
| 	IMPL_POWER4        = 0x0800      /* 4 class CPU */
 | |
| 	IMPL_POWER_RS64IV  = IMPL_POWER4 /* 4 class CPU */
 | |
| 	IMPL_POWER_MPC7450 = 0x1000      /* MPC7450 class CPU */
 | |
| 	IMPL_POWER5        = 0x2000      /* 5 class CPU */
 | |
| 	IMPL_POWER6        = 0x4000      /* 6 class CPU */
 | |
| 	IMPL_POWER7        = 0x8000      /* 7 class CPU */
 | |
| 	IMPL_POWER8        = 0x10000     /* 8 class CPU */
 | |
| 	IMPL_POWER9        = 0x20000     /* 9 class CPU */
 | |
| )
 | |
| 
 | |
| // Values for implementation field for IA64 Architectures
 | |
| const (
 | |
| 	IMPL_IA64_M1 = 0x0001 /* IA64 M1 class CPU (Itanium) */
 | |
| 	IMPL_IA64_M2 = 0x0002 /* IA64 M2 class CPU */
 | |
| )
 | |
| 
 | |
| // Values for the version field
 | |
| const (
 | |
| 	PV_601        = 0x010001 /* Power PC 601 */
 | |
| 	PV_601A       = 0x010002 /* Power PC 601 */
 | |
| 	PV_603        = 0x060000 /* Power PC 603 */
 | |
| 	PV_604        = 0x050000 /* Power PC 604 */
 | |
| 	PV_620        = 0x070000 /* Power PC 620 */
 | |
| 	PV_630        = 0x080000 /* Power PC 630 */
 | |
| 	PV_A35        = 0x090000 /* Power PC A35 */
 | |
| 	PV_RS64II     = 0x0A0000 /* Power PC RS64II */
 | |
| 	PV_RS64III    = 0x0B0000 /* Power PC RS64III */
 | |
| 	PV_4          = 0x0C0000 /* Power PC 4 */
 | |
| 	PV_RS64IV     = PV_4     /* Power PC 4 */
 | |
| 	PV_MPC7450    = 0x0D0000 /* Power PC MPC7450 */
 | |
| 	PV_4_2        = 0x0E0000 /* Power PC 4 */
 | |
| 	PV_4_3        = 0x0E0001 /* Power PC 4 */
 | |
| 	PV_5          = 0x0F0000 /* Power PC 5 */
 | |
| 	PV_5_2        = 0x0F0001 /* Power PC 5 */
 | |
| 	PV_5_3        = 0x0F0002 /* Power PC 5 */
 | |
| 	PV_6          = 0x100000 /* Power PC 6 */
 | |
| 	PV_6_1        = 0x100001 /* Power PC 6 DD1.x */
 | |
| 	PV_7          = 0x200000 /* Power PC 7 */
 | |
| 	PV_8          = 0x300000 /* Power PC 8 */
 | |
| 	PV_9          = 0x400000 /* Power PC 9 */
 | |
| 	PV_5_Compat   = 0x0F8000 /* Power PC 5 */
 | |
| 	PV_6_Compat   = 0x108000 /* Power PC 6 */
 | |
| 	PV_7_Compat   = 0x208000 /* Power PC 7 */
 | |
| 	PV_8_Compat   = 0x308000 /* Power PC 8 */
 | |
| 	PV_9_Compat   = 0x408000 /* Power PC 9 */
 | |
| 	PV_RESERVED_2 = 0x0A0000 /* source compatability */
 | |
| 	PV_RESERVED_3 = 0x0B0000 /* source compatability */
 | |
| 	PV_RS2        = 0x040000 /* Power RS2 */
 | |
| 	PV_RS1        = 0x020000 /* Power RS1 */
 | |
| 	PV_RSC        = 0x030000 /* Power RSC */
 | |
| 	PV_M1         = 0x008000 /* Intel IA64 M1 */
 | |
| 	PV_M2         = 0x008001 /* Intel IA64 M2 */
 | |
| )
 | |
| 
 | |
| // Values for rtc_type
 | |
| const (
 | |
| 	RTC_POWER    = 1 /* rtc as defined by Power Arch. */
 | |
| 	RTC_POWER_PC = 2 /* rtc as defined by Power PC Arch. */
 | |
| 	RTC_IA64     = 3 /* rtc as defined by IA64 Arch. */
 | |
| )
 | |
| 
 | |
| const NX_GZIP_PRESENT = 0x00000001
 | |
| 
 | |
| const (
 | |
| 	PKS_STATE_CAPABLE = 1
 | |
| 	PKS_STATE_ENABLED = 2
 | |
| )
 | |
| 
 | |
| // Macros for identifying physical processor
 | |
| const (
 | |
| 	PPI4_1 = 0x35
 | |
| 	PPI4_2 = 0x38
 | |
| 	PPI4_3 = 0x39
 | |
| 	PPI4_4 = 0x3C
 | |
| 	PPI4_5 = 0x44
 | |
| 	PPI5_1 = 0x3A
 | |
| 	PPI5_2 = 0x3B
 | |
| 	PPI6_1 = 0x3E
 | |
| 	PPI7_1 = 0x3F
 | |
| 	PPI7_2 = 0x4A
 | |
| 	PPI8_1 = 0x4B
 | |
| 	PPI8_2 = 0x4D
 | |
| 	PPI9   = 0x4E
 | |
| )
 | |
| 
 | |
| // Macros for kernel attributes
 | |
| const (
 | |
| 	KERN_TYPE            = 0x1
 | |
| 	KERN_LPAR            = 0x2
 | |
| 	KERN_64BIT_LARGE_ABI = 0x4
 | |
| 	KERN_NUMA            = 0x8
 | |
| 	KERN_UPMP            = 0x10
 | |
| 	KERN_DR_CPU_ADD      = 0x20
 | |
| 	KERN_DR_CPU_RM       = 0x40
 | |
| 	KERN_DR_MEM_ADD      = 0x80
 | |
| 	KERN_DR_MEM_RM       = 0x100
 | |
| 	KERN_KKEY_ENABLED    = 0x200
 | |
| 	KERN_RECOVERY        = 0x400
 | |
| 	KERN_MLS             = 0x800
 | |
| 	KERN_ENH_AFFINITY    = 0x1000
 | |
| 	KERN_VTPM            = 0x2000
 | |
| 	KERN_VIOS            = 0x4000
 | |
| )
 | |
| 
 | |
| // macros for SPLPAR environment.
 | |
| const (
 | |
| 	SPLPAR_CAPABLE        = 0x1
 | |
| 	SPLPAR_ENABLED        = 0x2
 | |
| 	SPLPAR_DONATE_CAPABLE = 0x4
 | |
| )
 | |
| 
 | |
| // Macros for SMT status determination
 | |
| const (
 | |
| 	SMT_CAPABLE = 0x1
 | |
| 	SMT_ENABLE  = 0x2
 | |
| 	SMT_BOUND   = 0x4
 | |
| 	SMT_ORDER   = 0x8
 | |
| )
 | |
| 
 | |
| // Macros for VRM status determination
 | |
| const (
 | |
| 	VRM_CAPABLE  = 0x1
 | |
| 	VRM_ENABLE   = 0x2
 | |
| 	CMOX_CAPABLE = 0x4
 | |
| )
 | |
| 
 | |
| // Macros for AME status determination
 | |
| const AME_ENABLE = 0x1
 | |
| 
 | |
| // Macros for extended cache options
 | |
| const (
 | |
| 	ECO_CAPABLE = 0x1
 | |
| 	ECO_ENABLE  = 0x2
 | |
| )
 | |
| 
 | |
| // These define blocks of values for model_arch and model_impl that are reserved for OEM use.
 | |
| const (
 | |
| 	MODEL_ARCH_RSPC         = 2
 | |
| 	MODEL_ARCH_CHRP         = 3
 | |
| 	MODEL_ARCH_IA64         = 4
 | |
| 	MODEL_ARCH_OEM_START    = 1024
 | |
| 	MODEL_ARCH_OEM_END      = 2047
 | |
| 	MODEL_IMPL_RS6K_UP_MCA  = 1
 | |
| 	MODEL_IMPL_RS6K_SMP_MCA = 2
 | |
| 	MODEL_IMPL_RSPC_UP_PCI  = 3
 | |
| 	MODEL_IMPL_RSPC_SMP_PCI = 4
 | |
| 	MODEL_IMPL_CHRP_UP_PCI  = 5
 | |
| 	MODEL_IMPL_CHRP_SMP_PCI = 6
 | |
| 	MODEL_IMPL_IA64_COM     = 7
 | |
| 	MODEL_IMPL_IA64_SOFTSDV = 8
 | |
| 	MODEL_IMPL_MAMBO_SIM    = 9
 | |
| 	MODEL_IMPL_POWER_KVM    = 10
 | |
| 	MODEL_IMPL_OEM_START    = 1024
 | |
| 	MODEL_IMPL_OEM_END      = 2047
 | |
| )
 | |
| 
 | |
| // example determining processor compatibilty mode on AIX:
 | |
| // impl := unix.Getsystemcfg(SC_IMPL)
 | |
| // if impl&IMPL_POWER8 != 0 {
 | |
| //     // we are running on POWER8
 | |
| // }
 | |
| // if impl&IMPL_POWER9 != 0 {
 | |
| //     // we are running on POWER9
 | |
| // }
 | |
| 
 | |
| func GetCPUImplementation() string {
 | |
| 	impl := unix.Getsystemcfg(SC_IMPL)
 | |
| 	switch {
 | |
| 	case impl&IMPL_POWER4 != 0:
 | |
| 		return "POWER4"
 | |
| 	case impl&IMPL_POWER5 != 0:
 | |
| 		return "POWER5"
 | |
| 	case impl&IMPL_POWER6 != 0:
 | |
| 		return "POWER6"
 | |
| 	case impl&IMPL_POWER7 != 0:
 | |
| 		return "POWER7"
 | |
| 	case impl&IMPL_POWER8 != 0:
 | |
| 		return "POWER8"
 | |
| 	case impl&IMPL_POWER9 != 0:
 | |
| 		return "POWER9"
 | |
| 	default:
 | |
| 		return "Unknown"
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func POWER9OrNewer() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_IMPL)
 | |
| 	if impl&IMPL_POWER9 != 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func POWER9() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_IMPL)
 | |
| 	if impl&IMPL_POWER9 != 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func POWER8OrNewer() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_IMPL)
 | |
| 	if impl&IMPL_POWER9 != 0 || impl&IMPL_POWER8 != 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func POWER8() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_IMPL)
 | |
| 	if impl&IMPL_POWER8 != 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func POWER7OrNewer() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_IMPL)
 | |
| 	if impl&IMPL_POWER9 != 0 || impl&IMPL_POWER8 != 0 || impl&IMPL_POWER7 != 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func POWER7() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_IMPL)
 | |
| 	if impl&IMPL_POWER7 != 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func HasTransactionalMemory() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_TM_VER)
 | |
| 	if impl > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func Is64Bit() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_WIDTH)
 | |
| 	if impl == 64 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func IsSMP() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_NCPUS)
 | |
| 	if impl > 1 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func HasVMX() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_VMX_VER)
 | |
| 	if impl > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func HasVSX() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_VMX_VER)
 | |
| 	if impl > 1 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func HasDFP() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_DFP_STAT)
 | |
| 	if impl > 1 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func HasNxGzip() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_NX_CAP)
 | |
| 	if impl&NX_GZIP_PRESENT > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func PksCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_PKS_STATE)
 | |
| 	if impl&PKS_STATE_CAPABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func PksEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_PKS_STATE)
 | |
| 	if impl&PKS_STATE_ENABLED > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func CPUMode() string {
 | |
| 	impl := unix.Getsystemcfg(SC_VERS)
 | |
| 	switch impl {
 | |
| 	case PV_9, PV_9_Compat:
 | |
| 		return "POWER9"
 | |
| 	case PV_8, PV_8_Compat:
 | |
| 		return "POWER8"
 | |
| 	case PV_7, PV_7_Compat:
 | |
| 		return "POWER7"
 | |
| 	default:
 | |
| 		return "Unknown"
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func KernelBits() int {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_TYPE == KERN_TYPE {
 | |
| 		return 64
 | |
| 	}
 | |
| 	return 32
 | |
| }
 | |
| 
 | |
| func IsLPAR() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_LPAR == KERN_LPAR {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func CpuAddCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_DR_CPU_ADD == KERN_DR_CPU_ADD {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func CpuRemoveCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_DR_CPU_RM == KERN_DR_CPU_RM {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func MemoryAddCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_DR_MEM_ADD == KERN_DR_MEM_ADD {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func MemoryRemoveCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_DR_MEM_RM == KERN_DR_MEM_RM {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func DLparCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&(KERN_DR_CPU_ADD|KERN_DR_CPU_RM|KERN_DR_MEM_ADD|KERN_DR_MEM_RM) > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func IsNUMA() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_NUMA > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func KernelKeys() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_KKEY_ENABLED > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func RecoveryMode() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_RECOVERY > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func EnhancedAffinity() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_ENH_AFFINITY > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func VTpmEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_VTPM > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func IsVIOS() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_VIOS > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func MLSEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_KRN_ATTR)
 | |
| 	if impl&KERN_MLS > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func SPLparCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_SPLP_STAT)
 | |
| 	if impl&SPLPAR_CAPABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func SPLparEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_SPLP_STAT)
 | |
| 	if impl&SPLPAR_ENABLED > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func DedicatedLpar() bool {
 | |
| 	return !SPLparEnabled()
 | |
| }
 | |
| 
 | |
| func SPLparCapped() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_VCAPW)
 | |
| 	if impl == 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func SPLparDonating() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_SPLP_STAT)
 | |
| 	if impl&SPLPAR_DONATE_CAPABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func SmtCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_SMT_STAT)
 | |
| 	if impl&SMT_CAPABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func SmtEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_SMT_STAT)
 | |
| 	if impl&SMT_ENABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func VrmCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_VRM_STAT)
 | |
| 	if impl&VRM_CAPABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func VrmEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_VRM_STAT)
 | |
| 	if impl&VRM_ENABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func AmeEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_AME_STAT)
 | |
| 	if impl&AME_ENABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func EcoCapable() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_ECO_STAT)
 | |
| 	if impl&ECO_CAPABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func EcoEnabled() bool {
 | |
| 	impl := unix.Getsystemcfg(SC_ECO_STAT)
 | |
| 	if impl&ECO_ENABLE > 0 {
 | |
| 		return true
 | |
| 	}
 | |
| 	return false
 | |
| }
 |