From e552242db6de8530ede549d4ec218aa6c72a7243 Mon Sep 17 00:00:00 2001 From: Matthias Baesken Date: Tue, 2 Oct 2018 13:48:08 +0200 Subject: [PATCH] 8211106: [windows] Update OS detection code to recognize Windows Server 2019 Reviewed-by: alanb, clanger, bobv --- src/hotspot/os/windows/os_windows.cpp | 8 +++++++- .../windows/native/libjava/java_props_md.c | 17 +++++++++++++++-- 2 files changed, 22 insertions(+), 3 deletions(-) diff --git a/src/hotspot/os/windows/os_windows.cpp b/src/hotspot/os/windows/os_windows.cpp index 0448858f478..ca3610d75ab 100644 --- a/src/hotspot/os/windows/os_windows.cpp +++ b/src/hotspot/os/windows/os_windows.cpp @@ -1688,7 +1688,13 @@ void os::win32::print_windows_version(outputStream* st) { if (is_workstation) { st->print("10"); } else { - st->print("Server 2016"); + // distinguish Windows Server 2016 and 2019 by build number + // Windows server 2019 GA 10/2018 build number is 17763 + if (build_number > 17762) { + st->print("Server 2019"); + } else { + st->print("Server 2016"); + } } break; diff --git a/src/java.base/windows/native/libjava/java_props_md.c b/src/java.base/windows/native/libjava/java_props_md.c index 3d738613a1d..02eac2acf45 100644 --- a/src/java.base/windows/native/libjava/java_props_md.c +++ b/src/java.base/windows/native/libjava/java_props_md.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -359,6 +359,7 @@ GetJavaProperties(JNIEnv* env) static java_props_t sprops = {0}; int majorVersion; int minorVersion; + int buildNumber = 0; if (sprops.line_separator) { return &sprops; @@ -398,6 +399,8 @@ GetJavaProperties(JNIEnv* env) GetVersionEx((OSVERSIONINFO *) &ver); majorVersion = ver.dwMajorVersion; minorVersion = ver.dwMinorVersion; + /* distinguish Windows Server 2016 and 2019 by build number */ + buildNumber = ver.dwBuildNumber; is_workstation = (ver.wProductType == VER_NT_WORKSTATION); platformId = ver.dwPlatformId; sprops.patch_level = _strdup(ver.szCSDVersion); @@ -448,6 +451,7 @@ GetJavaProperties(JNIEnv* env) } majorVersion = HIWORD(file_info->dwProductVersionMS); minorVersion = LOWORD(file_info->dwProductVersionMS); + buildNumber = HIWORD(file_info->dwProductVersionLS); free(version_info); } while (0); @@ -478,6 +482,8 @@ GetJavaProperties(JNIEnv* env) * Windows Server 2012 R2 6 3 (!VER_NT_WORKSTATION) * Windows 10 10 0 (VER_NT_WORKSTATION) * Windows Server 2016 10 0 (!VER_NT_WORKSTATION) + * Windows Server 2019 10 0 (!VER_NT_WORKSTATION) + * where (buildNumber > 17762) * * This mapping will presumably be augmented as new Windows * versions are released. @@ -551,7 +557,14 @@ GetJavaProperties(JNIEnv* env) } } else { switch (minorVersion) { - case 0: sprops.os_name = "Windows Server 2016"; break; + case 0: + /* Windows server 2019 GA 10/2018 build number is 17763 */ + if (buildNumber > 17762) { + sprops.os_name = "Windows Server 2019"; + } else { + sprops.os_name = "Windows Server 2016"; + } + break; default: sprops.os_name = "Windows NT (unknown)"; } }