RTSystemQueryOSInfo-win.cpp revision 295cafc57090fbc05ed081f4d1907005745afa06
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * IPRT - RTSystemQueryOSInfo, generic stub.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * Copyright (C) 2008 Sun Microsystems, Inc.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * available from http://www.virtualbox.org. This file is free software;
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * you can redistribute it and/or modify it under the terms of the GNU
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * General Public License (GPL) as published by the Free Software
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * The contents of this file may alternatively be used under the terms
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * of the Common Development and Distribution License Version 1.0
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * VirtualBox OSE distribution, in which case the provisions of the
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * CDDL are applicable instead of those of the GPL.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * You may elect to license modified versions of this file under the
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * terms and conditions of either the GPL or the CDDL or both.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * Clara, CA 95054 USA or visit http://www.sun.com if you need
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * additional information or have any questions.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync/*******************************************************************************
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync* Header Files *
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync*******************************************************************************/
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync/*******************************************************************************
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync* Structures and Typedefs *
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync*******************************************************************************/
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * Windows OS type as determined by rtSystemWinOSType().
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * These are the PRODUCT_* defines found in the Vista Platform SDK and returned
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * by GetProductInfo().
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * We define them ourselves because we don't necessarily have any Vista PSDK around.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_UNDEFINED = 0x00000000, ///< An unknown product
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_BUSINESS = 0x00000006, ///< Business Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_BUSINESS_N = 0x00000010, ///< Business Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_CLUSTER_SERVER = 0x00000012, ///< Cluster Server Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_DATACENTER_SERVER = 0x00000008, ///< Server Datacenter Edition (full installation)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_DATACENTER_SERVER_CORE = 0x0000000C, ///< Server Datacenter Edition (core installation)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_ENTERPRISE = 0x00000004, ///< Enterprise Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_ENTERPRISE_N = 0x0000001B, ///< Enterprise Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_ENTERPRISE_SERVER = 0x0000000A, ///< Server Enterprise Edition (full installation)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_ENTERPRISE_SERVER_CORE = 0x0000000E, ///< Server Enterprise Edition (core installation)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_ENTERPRISE_SERVER_IA64 = 0x0000000F, ///< Server Enterprise Edition for Itanium-based Systems
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_HOME_BASIC = 0x00000002, ///< Home Basic Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_HOME_BASIC_N = 0x00000005, ///< Home Basic Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_HOME_PREMIUM = 0x00000003, ///< Home Premium Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_HOME_PREMIUM_N = 0x0000001A, ///< Home Premium Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_HOME_SERVER = 0x00000013, ///< Home Server Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_SERVER_FOR_SMALLBUSINESS = 0x00000018, ///< Server for Small Business Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_SMALLBUSINESS_SERVER = 0x00000009, ///< Small Business Server
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_SMALLBUSINESS_SERVER_PREMIUM = 0x00000019, ///< Small Business Server Premium Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_STANDARD_SERVER = 0x00000007, ///< Server Standard Edition (full installation)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_STANDARD_SERVER_CORE = 0x0000000D, ///< Server Standard Edition (core installation)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_STARTER = 0x0000000B, ///< Starter Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_STORAGE_ENTERPRISE_SERVER = 0x00000017, ///< Storage Server Enterprise Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_STORAGE_EXPRESS_SERVER = 0x00000014, ///< Storage Server Express Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_STORAGE_STANDARD_SERVER = 0x00000015, ///< Storage Server Standard Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_STORAGE_WORKGROUP_SERVER = 0x00000016, ///< Storage Server Workgroup Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_ULTIMATE = 0x00000001, ///< Ultimate Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_ULTIMATE_N = 0x0000001C, ///< Ultimate Edition
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_WEB_SERVER = 0x00000011, ///< Web Server Edition (full)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync kRTWinProdType_WEB_SERVER_CORE = 0x0000001D ///< Web Server Edition (core)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * Translates OSVERSIONINOFEX into a Windows OS type.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * @returns The Windows OS type.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * @param pOSInfoEx The OS info returned by Windows.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * @remarks This table has been assembled from Usenet postings, personal
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * observations, and reading other people's code. Please feel
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * free to add to it or correct it.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync dwPlatFormID dwMajorVersion dwMinorVersion dwBuildNumber
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync95 1 4 0 950
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync95 SP1 1 4 0 >950 && <=1080
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync95 OSR2 1 4 <10 >1080
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync98 1 4 10 1998
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync98 SP1 1 4 10 >1998 && <2183
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync98 SE 1 4 10 >=2183
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncME 1 4 90 3000
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncNT 3.51 2 3 51 1057
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncNT 4 2 4 0 1381
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync2000 2 5 0 2195
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncXP 2 5 1 2600
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync2003 2 5 2 3790
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncCE 1.0 3 1 0
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncCE 2.0 3 2 0
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncCE 2.1 3 2 1
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncCE 3.0 3 3 0
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncstatic RTWINOSTYPE rtSystemWinOSType(OSVERSIONINFOEX const *pOSInfoEx)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync DWORD const dwPlatformId = pOSInfoEx->dwPlatformId;
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync DWORD const dwMinorVersion = pOSInfoEx->dwMinorVersion;
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync DWORD const dwMajorVersion = pOSInfoEx->dwMajorVersion;
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync DWORD const dwBuildNumber = pOSInfoEx->dwBuildNumber & 0xFFFF; /* Win 9x needs this. */
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync /** @todo check Windows Server 2008! */
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * Wrapper around the GetProductInfo API.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync * @returns The vista type.
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsyncstatic RTWINPRODTYPE rtSystemWinGetProductInfo(DWORD dwOSMajorVersion, DWORD dwOSMinorVersion, DWORD dwSpMajorVersion, DWORD dwSpMinorVersion)
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync BOOL (WINAPI *pfnGetProductInfo)(DWORD, DWORD, DWORD, DWORD, PDWORD);
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync pfnGetProductInfo = (BOOL (WINAPI *)(DWORD, DWORD, DWORD, DWORD, PDWORD))GetProcAddress(GetModuleHandle("KERNEL32.DLL"), "GetProductInfo");
a33af978add1a03aab11b2895f441af5cb2a11a6vboxsync if (pfnGetProductInfo(dwOSMajorVersion, dwOSMinorVersion, dwSpMajorVersion, dwSpMinorVersion, &dwProductType))
switch (enmVistaType)
case kRTWinProdType_DATACENTER_SERVER: strcat(pszTmp, " Server Datacenter Edition (full installation)"); break;
case kRTWinProdType_DATACENTER_SERVER_CORE: strcat(pszTmp, " Server Datacenter Edition (core installation)"); break;
case kRTWinProdType_ENTERPRISE_SERVER: strcat(pszTmp, " Server Enterprise Edition (full installation)"); break;
case kRTWinProdType_ENTERPRISE_SERVER_CORE: strcat(pszTmp, " Server Enterprise Edition (core installation)"); break;
case kRTWinProdType_ENTERPRISE_SERVER_IA64: strcat(pszTmp, " Server Enterprise Edition for Itanium-based Systems"); break;
case kRTWinProdType_SERVER_FOR_SMALLBUSINESS: strcat(pszTmp, " Server for Small Business Edition"); break;
case kRTWinProdType_SMALLBUSINESS_SERVER_PREMIUM: strcat(pszTmp, " Small Business Server Premium Edition"); break;
case kRTWinProdType_STANDARD_SERVER: strcat(pszTmp, " Server Standard Edition (full installation)"); break;
case kRTWinProdType_STANDARD_SERVER_CORE: strcat(pszTmp, " Server Standard Edition (core installation)"); break;
case kRTWinProdType_STORAGE_ENTERPRISE_SERVER: strcat(pszTmp, " Storage Server Enterprise Edition"); break;
case kRTWinProdType_STORAGE_EXPRESS_SERVER: strcat(pszTmp, " Storage Server Express Edition"); break;
case kRTWinProdType_STORAGE_STANDARD_SERVER: strcat(pszTmp, " Storage Server Standard Edition"); break;
case kRTWinProdType_STORAGE_WORKGROUP_SERVER: strcat(pszTmp, " Storage Server Workgroup Edition"); break;
case kRTWinProdType_WEB_SERVER_CORE: strcat(pszTmp, " Web Server Edition (core installation)"); break;
case kRTWinProdType_UNDEFINED: break;
int rc;
switch (enmInfo)
case RTSYSOSINFO_PRODUCT:
switch (enmVer)
case kRTWinOSType_XP:
case kRTWinOSType_VISTA:
case kRTWinOSType_NT_UNKNOWN:
RTStrPrintf(szTmp, sizeof(szTmp), "Unknown NT v%u.%u", OSInfoEx.dwMajorVersion, OSInfoEx.dwMinorVersion);
AssertFailed();
case kRTWinOSType_UNKNOWN:
RTStrPrintf(szTmp, sizeof(szTmp), "Unknown %d v%u.%u", OSInfoEx.dwPlatformId, OSInfoEx.dwMajorVersion, OSInfoEx.dwMinorVersion);
case RTSYSOSINFO_RELEASE:
RTStrPrintf(szTmp, sizeof(szTmp), "%u.%u.%u", OSInfoEx.dwMajorVersion, OSInfoEx.dwMinorVersion, OSInfoEx.dwBuildNumber);
case RTSYSOSINFO_SERVICE_PACK:
RTStrPrintf(szTmp, sizeof(szTmp), "Service Pack %u.%u", (unsigned)OSInfoEx.wServicePackMajor, (unsigned)OSInfoEx.wServicePackMinor);
switch (enmVer)
return VINF_SUCCESS;
if (!cchInfo)
return VERR_BUFFER_OVERFLOW;
switch (enmInfo)
case RTSYSOSINFO_PRODUCT:
case RTSYSOSINFO_RELEASE:
case RTSYSOSINFO_SERVICE_PACK:
case RTSYSOSINFO_VERSION:
return VERR_NOT_SUPPORTED;