KWSys 2013-01-14 (6fa1c99f)
Extract upstream KWSys using the following shell commands. $ git archive --prefix=upstream-kwsys/ 6fa1c99f | tar x $ git shortlog --no-merges --abbrev=8 --format='%h %s' 608d6b47..6fa1c99f Brad King (1): 84827cc1 Process: Avoid argv[0]==NULL from parsing empty command line Rolf Eike Beer (8): e041cd66 SystemInformation: factor out QueryMemoryBySysconf() ea850fa0 SystemInformation: factor out QueryProcessorBySysconf() 57f06d49 SystemInformation: count processors with sysconf() on Solaris c6057a06 SystemInformation: fix "Multi-character character constant" 5a27bd4f SystemInformation: make IsHyperThreadingSupported() return bool 342c0ad2 SystemInformation: query memory size with sysconf() on Solaris f0b857c1 SystemInformation: cache result of IsHyperThreadingSupported() ab0c2a09 SystemInformation: try using assembler with BorlandC Change-Id: I072371ed35eed892a5ef62a9e9e6cad734e961d9
This commit is contained in:
parent
6318834b95
commit
4ba0ac7be4
|
@ -574,6 +574,8 @@ IF(KWSYS_USE_SystemTools)
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
IF(KWSYS_USE_SystemInformation)
|
IF(KWSYS_USE_SystemInformation)
|
||||||
|
SET_PROPERTY(SOURCE SystemInformation.cxx APPEND PROPERTY
|
||||||
|
COMPILE_DEFINITIONS SIZEOF_VOID_P=${CMAKE_SIZEOF_VOID_P})
|
||||||
IF(NOT CYGWIN)
|
IF(NOT CYGWIN)
|
||||||
INCLUDE(CheckIncludeFiles)
|
INCLUDE(CheckIncludeFiles)
|
||||||
CHECK_INCLUDE_FILES("sys/types.h;ifaddrs.h" KWSYS_SYS_HAS_IFADDRS_H)
|
CHECK_INCLUDE_FILES("sys/types.h;ifaddrs.h" KWSYS_SYS_HAS_IFADDRS_H)
|
||||||
|
@ -638,6 +640,20 @@ IF(KWSYS_USE_SystemInformation)
|
||||||
SET_PROPERTY(SOURCE SystemInformation.cxx APPEND PROPERTY
|
SET_PROPERTY(SOURCE SystemInformation.cxx APPEND PROPERTY
|
||||||
COMPILE_DEFINITIONS KWSYS_CXX_HAS__ATOI64=1)
|
COMPILE_DEFINITIONS KWSYS_CXX_HAS__ATOI64=1)
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
IF(BORLAND)
|
||||||
|
KWSYS_PLATFORM_CXX_TEST(KWSYS_CXX_HAS_BORLAND_ASM
|
||||||
|
"Checking whether Borland CXX compiler supports assembler instructions" DIRECT)
|
||||||
|
IF(KWSYS_CXX_HAS_BORLAND_ASM)
|
||||||
|
SET_PROPERTY(SOURCE SystemInformation.cxx APPEND PROPERTY
|
||||||
|
COMPILE_DEFINITIONS KWSYS_CXX_HAS_BORLAND_ASM=1)
|
||||||
|
KWSYS_PLATFORM_CXX_TEST(KWSYS_CXX_HAS_BORLAND_ASM_CPUID
|
||||||
|
"Checking whether Borland CXX compiler supports CPUID assembler instruction" DIRECT)
|
||||||
|
IF(KWSYS_CXX_HAS_BORLAND_ASM_CPUID)
|
||||||
|
SET_PROPERTY(SOURCE SystemInformation.cxx APPEND PROPERTY
|
||||||
|
COMPILE_DEFINITIONS KWSYS_CXX_HAS_BORLAND_ASM_CPUID=1)
|
||||||
|
ENDIF()
|
||||||
|
ENDIF()
|
||||||
|
ENDIF()
|
||||||
IF(KWSYS_USE___INT64)
|
IF(KWSYS_USE___INT64)
|
||||||
SET_PROPERTY(SOURCE SystemInformation.cxx testSystemInformation.cxx APPEND PROPERTY
|
SET_PROPERTY(SOURCE SystemInformation.cxx testSystemInformation.cxx APPEND PROPERTY
|
||||||
COMPILE_DEFINITIONS KWSYS_USE___INT64=1)
|
COMPILE_DEFINITIONS KWSYS_USE___INT64=1)
|
||||||
|
|
|
@ -418,9 +418,10 @@ int kwsysProcess_AddCommand(kwsysProcess* cp, char const* const* command)
|
||||||
parse it. */
|
parse it. */
|
||||||
newCommands[cp->NumberOfCommands] =
|
newCommands[cp->NumberOfCommands] =
|
||||||
kwsysSystem_Parse_CommandForUnix(*command, 0);
|
kwsysSystem_Parse_CommandForUnix(*command, 0);
|
||||||
if(!newCommands[cp->NumberOfCommands])
|
if(!newCommands[cp->NumberOfCommands] ||
|
||||||
|
!newCommands[cp->NumberOfCommands][0])
|
||||||
{
|
{
|
||||||
/* Out of memory. */
|
/* Out of memory or no command parsed. */
|
||||||
free(newCommands);
|
free(newCommands);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -202,7 +202,7 @@ typedef struct rlimit ResourceLimitType;
|
||||||
#define USE_CPUID_INTRINSICS 0
|
#define USE_CPUID_INTRINSICS 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if USE_ASM_INSTRUCTIONS || USE_CPUID_INTRINSICS
|
#if USE_ASM_INSTRUCTIONS || USE_CPUID_INTRINSICS || defined(KWSYS_CXX_HAS_BORLAND_ASM_CPUID)
|
||||||
# define USE_CPUID 1
|
# define USE_CPUID 1
|
||||||
#else
|
#else
|
||||||
# define USE_CPUID 0
|
# define USE_CPUID 0
|
||||||
|
@ -224,6 +224,7 @@ static bool call_cpuid(int select, int result[4])
|
||||||
return true;
|
return true;
|
||||||
#else
|
#else
|
||||||
int tmp[4];
|
int tmp[4];
|
||||||
|
#if defined(_MSC_VER)
|
||||||
// Use SEH to determine CPUID presence
|
// Use SEH to determine CPUID presence
|
||||||
__try {
|
__try {
|
||||||
_asm {
|
_asm {
|
||||||
|
@ -263,6 +264,23 @@ static bool call_cpuid(int select, int result[4])
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(result, tmp, sizeof(tmp));
|
memcpy(result, tmp, sizeof(tmp));
|
||||||
|
#elif defined(KWSYS_CXX_HAS_BORLAND_ASM_CPUID)
|
||||||
|
unsigned int a, b, c, d;
|
||||||
|
__asm {
|
||||||
|
mov EAX, select;
|
||||||
|
cpuid
|
||||||
|
mov a, EAX;
|
||||||
|
mov b, EBX;
|
||||||
|
mov c, ECX;
|
||||||
|
mov d, EDX;
|
||||||
|
}
|
||||||
|
|
||||||
|
result[0] = a;
|
||||||
|
result[1] = b;
|
||||||
|
result[2] = c;
|
||||||
|
result[3] = d;
|
||||||
|
#endif
|
||||||
|
|
||||||
// The cpuid instruction succeeded.
|
// The cpuid instruction succeeded.
|
||||||
return true;
|
return true;
|
||||||
#endif
|
#endif
|
||||||
|
@ -432,7 +450,7 @@ protected:
|
||||||
int CPUCount();
|
int CPUCount();
|
||||||
unsigned char LogicalCPUPerPhysicalCPU();
|
unsigned char LogicalCPUPerPhysicalCPU();
|
||||||
unsigned char GetAPICId();
|
unsigned char GetAPICId();
|
||||||
unsigned int IsHyperThreadingSupported();
|
bool IsHyperThreadingSupported();
|
||||||
static LongLong GetCyclesDifference(DELAY_FUNC, unsigned int);
|
static LongLong GetCyclesDifference(DELAY_FUNC, unsigned int);
|
||||||
|
|
||||||
// For Linux and Cygwin, /proc/cpuinfo formats are slightly different
|
// For Linux and Cygwin, /proc/cpuinfo formats are slightly different
|
||||||
|
@ -456,7 +474,8 @@ protected:
|
||||||
kwsys_stl::string SysCtlBuffer;
|
kwsys_stl::string SysCtlBuffer;
|
||||||
|
|
||||||
// For Solaris
|
// For Solaris
|
||||||
bool QuerySolarisInfo();
|
bool QuerySolarisMemory();
|
||||||
|
bool QuerySolarisProcessor();
|
||||||
kwsys_stl::string ParseValueFromKStat(const char* arguments);
|
kwsys_stl::string ParseValueFromKStat(const char* arguments);
|
||||||
kwsys_stl::string RunProcess(kwsys_stl::vector<const char*> args);
|
kwsys_stl::string RunProcess(kwsys_stl::vector<const char*> args);
|
||||||
|
|
||||||
|
@ -481,9 +500,11 @@ protected:
|
||||||
//For AIX
|
//For AIX
|
||||||
bool QueryAIXMemory();
|
bool QueryAIXMemory();
|
||||||
|
|
||||||
|
bool QueryProcessorBySysconf();
|
||||||
bool QueryProcessor();
|
bool QueryProcessor();
|
||||||
|
|
||||||
// Evaluate the memory information.
|
// Evaluate the memory information.
|
||||||
|
bool QueryMemoryBySysconf();
|
||||||
bool QueryMemory();
|
bool QueryMemory();
|
||||||
size_t TotalVirtualMemory;
|
size_t TotalVirtualMemory;
|
||||||
size_t AvailableVirtualMemory;
|
size_t AvailableVirtualMemory;
|
||||||
|
@ -1287,7 +1308,7 @@ void SystemInformationImplementation::RunCPUCheck()
|
||||||
#elif defined(__APPLE__)
|
#elif defined(__APPLE__)
|
||||||
this->ParseSysCtl();
|
this->ParseSysCtl();
|
||||||
#elif defined (__SVR4) && defined (__sun)
|
#elif defined (__SVR4) && defined (__sun)
|
||||||
this->QuerySolarisInfo();
|
this->QuerySolarisProcessor();
|
||||||
#elif defined(__HAIKU__)
|
#elif defined(__HAIKU__)
|
||||||
this->QueryHaikuInfo();
|
this->QueryHaikuInfo();
|
||||||
#elif defined(__QNX__)
|
#elif defined(__QNX__)
|
||||||
|
@ -1313,7 +1334,7 @@ void SystemInformationImplementation::RunMemoryCheck()
|
||||||
#if defined(__APPLE__)
|
#if defined(__APPLE__)
|
||||||
this->ParseSysCtl();
|
this->ParseSysCtl();
|
||||||
#elif defined (__SVR4) && defined (__sun)
|
#elif defined (__SVR4) && defined (__sun)
|
||||||
this->QuerySolarisInfo();
|
this->QuerySolarisMemory();
|
||||||
#elif defined(__HAIKU__)
|
#elif defined(__HAIKU__)
|
||||||
this->QueryHaikuInfo();
|
this->QueryHaikuInfo();
|
||||||
#elif defined(__QNX__)
|
#elif defined(__QNX__)
|
||||||
|
@ -3016,7 +3037,7 @@ bool SystemInformationImplementation::RetreiveInformationFromCpuInfoFile()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SystemInformationImplementation::QueryProcessor()
|
bool SystemInformationImplementation::QueryProcessorBySysconf()
|
||||||
{
|
{
|
||||||
#if defined(_SC_NPROC_ONLN) && !defined(_SC_NPROCESSORS_ONLN)
|
#if defined(_SC_NPROC_ONLN) && !defined(_SC_NPROCESSORS_ONLN)
|
||||||
// IRIX names this slightly different
|
// IRIX names this slightly different
|
||||||
|
@ -3039,6 +3060,11 @@ bool SystemInformationImplementation::QueryProcessor()
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool SystemInformationImplementation::QueryProcessor()
|
||||||
|
{
|
||||||
|
return this->QueryProcessorBySysconf();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Get total system RAM in units of KiB.
|
Get total system RAM in units of KiB.
|
||||||
*/
|
*/
|
||||||
|
@ -3559,8 +3585,7 @@ bool SystemInformationImplementation::QueryAIXMemory()
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Query for the memory status */
|
bool SystemInformationImplementation::QueryMemoryBySysconf()
|
||||||
bool SystemInformationImplementation::QueryMemory()
|
|
||||||
{
|
{
|
||||||
#if defined(_SC_PHYS_PAGES) && defined(_SC_PAGESIZE)
|
#if defined(_SC_PHYS_PAGES) && defined(_SC_PAGESIZE)
|
||||||
// Assume the mmap() granularity as returned by _SC_PAGESIZE is also
|
// Assume the mmap() granularity as returned by _SC_PAGESIZE is also
|
||||||
|
@ -3597,6 +3622,12 @@ bool SystemInformationImplementation::QueryMemory()
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Query for the memory status */
|
||||||
|
bool SystemInformationImplementation::QueryMemory()
|
||||||
|
{
|
||||||
|
return this->QueryMemoryBySysconf();
|
||||||
|
}
|
||||||
|
|
||||||
/** */
|
/** */
|
||||||
size_t SystemInformationImplementation::GetTotalVirtualMemory()
|
size_t SystemInformationImplementation::GetTotalVirtualMemory()
|
||||||
{
|
{
|
||||||
|
@ -3729,8 +3760,13 @@ unsigned char SystemInformationImplementation::LogicalCPUPerPhysicalCPU(void)
|
||||||
|
|
||||||
|
|
||||||
/** Works only for windows */
|
/** Works only for windows */
|
||||||
unsigned int SystemInformationImplementation::IsHyperThreadingSupported()
|
bool SystemInformationImplementation::IsHyperThreadingSupported()
|
||||||
{
|
{
|
||||||
|
if (this->Features.ExtendedFeatures.SupportsHyperthreading)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
#if USE_CPUID
|
#if USE_CPUID
|
||||||
int Regs[4] = { 0, 0, 0, 0 },
|
int Regs[4] = { 0, 0, 0, 0 },
|
||||||
VendorId[4] = { 0, 0, 0, 0 };
|
VendorId[4] = { 0, 0, 0, 0 };
|
||||||
|
@ -3748,13 +3784,15 @@ unsigned int SystemInformationImplementation::IsHyperThreadingSupported()
|
||||||
|
|
||||||
if (((Regs[0] & FAMILY_ID) == PENTIUM4_ID) || (Regs[0] & EXT_FAMILY_ID))
|
if (((Regs[0] & FAMILY_ID) == PENTIUM4_ID) || (Regs[0] & EXT_FAMILY_ID))
|
||||||
{
|
{
|
||||||
if (VendorId[1] == 'uneG')
|
if (VendorId[1] == 0x756e6547) // 'uneG'
|
||||||
{
|
{
|
||||||
if (VendorId[3] == 'Ieni')
|
if (VendorId[3] == 0x49656e69) // 'Ieni'
|
||||||
{
|
{
|
||||||
if (VendorId[2] == 'letn')
|
if (VendorId[2] == 0x6c65746e) // 'letn'
|
||||||
{
|
{
|
||||||
return(Regs[3] & HT_BIT); // Genuine Intel with hyper-Threading technology
|
// Genuine Intel with hyper-Threading technology
|
||||||
|
this->Features.ExtendedFeatures.SupportsHyperthreading = ((Regs[3] & HT_BIT) != 0);
|
||||||
|
return this->Features.ExtendedFeatures.SupportsHyperthreading;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4251,16 +4289,40 @@ kwsys_stl::string SystemInformationImplementation::ParseValueFromKStat(const cha
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/** Querying for system information from Solaris */
|
/** Querying for system information from Solaris */
|
||||||
bool SystemInformationImplementation::QuerySolarisInfo()
|
bool SystemInformationImplementation::QuerySolarisMemory()
|
||||||
{
|
{
|
||||||
// Parse values
|
#if defined (__SVR4) && defined (__sun)
|
||||||
this->NumberOfPhysicalCPU = static_cast<unsigned int>(
|
// Solaris allows querying this value by sysconf, but if this is
|
||||||
atoi(this->ParseValueFromKStat("-n syste_misc -s ncpus").c_str()));
|
// a 32 bit process on a 64 bit host the returned memory will be
|
||||||
this->NumberOfLogicalCPU = this->NumberOfPhysicalCPU;
|
// limited to 4GiB. So if this is a 32 bit process or if the sysconf
|
||||||
this->Features.ExtendedFeatures.LogicalProcessorsPerPhysical = 1;
|
// method fails use the kstat interface.
|
||||||
|
#if SIZEOF_VOID_P == 8
|
||||||
|
if (this->QueryMemoryBySysconf())
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
char* tail;
|
||||||
|
unsigned long totalMemory =
|
||||||
|
strtoul(this->ParseValueFromKStat("-s physmem").c_str(),&tail,0);
|
||||||
|
this->TotalPhysicalMemory = totalMemory/128;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
#else
|
||||||
|
return false;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SystemInformationImplementation::QuerySolarisProcessor()
|
||||||
|
{
|
||||||
|
if (!this->QueryProcessorBySysconf())
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Parse values
|
||||||
this->CPUSpeedInMHz = static_cast<float>(atoi(this->ParseValueFromKStat("-s clock_MHz").c_str()));
|
this->CPUSpeedInMHz = static_cast<float>(atoi(this->ParseValueFromKStat("-s clock_MHz").c_str()));
|
||||||
|
|
||||||
// Chip family
|
// Chip family
|
||||||
|
@ -4277,20 +4339,6 @@ bool SystemInformationImplementation::QuerySolarisInfo()
|
||||||
this->FindManufacturer();
|
this->FindManufacturer();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cache size
|
|
||||||
this->Features.L1CacheSize = 0;
|
|
||||||
this->Features.L2CacheSize = 0;
|
|
||||||
|
|
||||||
char* tail;
|
|
||||||
unsigned long totalMemory =
|
|
||||||
strtoul(this->ParseValueFromKStat("-s physmem").c_str(),&tail,0);
|
|
||||||
this->TotalPhysicalMemory = totalMemory/128;
|
|
||||||
|
|
||||||
// Undefined values (for now at least)
|
|
||||||
this->TotalVirtualMemory = 0;
|
|
||||||
this->AvailablePhysicalMemory = 0;
|
|
||||||
this->AvailableVirtualMemory = 0;
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -580,3 +580,30 @@ int main()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef TEST_KWSYS_CXX_HAS_BORLAND_ASM
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int a = 1;
|
||||||
|
__asm {
|
||||||
|
xor EBX, EBX;
|
||||||
|
mov a, EBX;
|
||||||
|
}
|
||||||
|
|
||||||
|
return a;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef TEST_KWSYS_CXX_HAS_BORLAND_ASM_CPUID
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int a = 0;
|
||||||
|
__asm {
|
||||||
|
xor EAX, EAX;
|
||||||
|
cpuid;
|
||||||
|
mov a, EAX;
|
||||||
|
}
|
||||||
|
|
||||||
|
return a;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue