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:
KWSys Robot 2013-01-14 09:26:01 -05:00 committed by Brad King
parent 6318834b95
commit 4ba0ac7be4
4 changed files with 129 additions and 37 deletions

View File

@ -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)

View File

@ -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;
} }

View File

@ -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;
} }

View File

@ -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