*** empty log message ***

svn path=/trunk/boinc/; revision=8812
This commit is contained in:
Rom Walton 2005-11-07 11:12:51 +00:00
parent a3a6ada375
commit 0aa4cbb7ca
2 changed files with 53 additions and 6 deletions

View File

@ -13613,3 +13613,12 @@ Rom 7 Nov 2005
locale/client/en_US/ locale/client/en_US/
BOINC Manager.po BOINC Manager.po
BOINC Manager.mo BOINC Manager.mo
Rom 7 Nov 2005
- Use GlobalMemoryStatusEx instead of GlobalMemoryStatus so that
we can detect memory sizes larger than 4GB in size.
client/win/
hostinfo_win.cpp

View File

@ -28,6 +28,22 @@
HINSTANCE g_hIdleDetectionDll; HINSTANCE g_hIdleDetectionDll;
// Memory Status Structure for Win2K and WinXP based systems.
typedef struct _MYMEMORYSTATUSEX {
DWORD dwLength;
DWORD dwMemoryLoad;
DWORDLONG ullTotalPhys;
DWORDLONG ullAvailPhys;
DWORDLONG ullTotalPageFile;
DWORDLONG ullAvailPageFile;
DWORDLONG ullTotalVirtual;
DWORDLONG ullAvailVirtual;
DWORDLONG ullAvailExtendedVirtual;
} MYMEMORYSTATUSEX, *LPMYMEMORYSTATUSEX;
typedef BOOL (WINAPI *MYGLOBALMEMORYSTATUSEX)(LPMYMEMORYSTATUSEX lpBuffer);
// Returns the number of seconds difference from UTC // Returns the number of seconds difference from UTC
// //
int get_timezone(void) { int get_timezone(void) {
@ -296,12 +312,34 @@ int HOST_INFO::get_host_info() {
timezone = get_timezone(); timezone = get_timezone();
MEMORYSTATUS mStatus; // Detect the amount of memory the system has with the new API, if it doesn't
ZeroMemory(&mStatus, sizeof(MEMORYSTATUS)); // exist, then use the older API.
mStatus.dwLength = sizeof(MEMORYSTATUS); HMODULE hKernel32;
GlobalMemoryStatus(&mStatus); MYGLOBALMEMORYSTATUSEX myGlobalMemoryStatusEx;
m_nbytes = (double)mStatus.dwTotalPhys; hKernel32 = LoadLibrary("kernel32.dll");
m_swap = (double)mStatus.dwTotalPageFile; if (hKernel32) {
myGlobalMemoryStatusEx = (MYGLOBALMEMORYSTATUSEX) GetProcAddress(hKernel32, "GlobalMemoryStatusEx");
}
if (hKernel32 && myGlobalMemoryStatusEx) {
MYMEMORYSTATUSEX mStatusEx;
ZeroMemory(&mStatusEx, sizeof(MYMEMORYSTATUSEX));
mStatusEx.dwLength = sizeof(MYMEMORYSTATUSEX);
(*myGlobalMemoryStatusEx)(&mStatusEx);
m_nbytes = (double)mStatusEx.ullTotalPhys;
m_swap = (double)mStatusEx.ullTotalPageFile;
} else {
MEMORYSTATUS mStatus;
ZeroMemory(&mStatus, sizeof(MEMORYSTATUS));
mStatus.dwLength = sizeof(MEMORYSTATUS);
GlobalMemoryStatus(&mStatus);
m_nbytes = (double)mStatus.dwTotalPhys;
m_swap = (double)mStatus.dwTotalPageFile;
}
if (hKernel32) {
FreeLibrary(hKernel32);
}
// gets processor vendor name and model name from registry, works for intel // gets processor vendor name and model name from registry, works for intel
char vendorName[256], processorName[256], identifierName[256]; char vendorName[256], processorName[256], identifierName[256];