From 78f3c8a7d441b8ed8febbbf8008cedfe762da13e Mon Sep 17 00:00:00 2001 From: Ivan Gerasimov Date: Thu, 12 Jul 2018 06:04:57 -0700 Subject: [PATCH] 8207145: (fs) Native memory leak in WindowsNativeDispatcher.LookupPrivilegeValue0 Reviewed-by: alanb --- .../windows/classes/sun/nio/fs/WindowsSecurity.java | 9 +++++---- .../windows/native/libnio/fs/WindowsNativeDispatcher.c | 7 +++++-- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/src/java.base/windows/classes/sun/nio/fs/WindowsSecurity.java b/src/java.base/windows/classes/sun/nio/fs/WindowsSecurity.java index 7e8af3e426b..30ddb7bb7ce 100644 --- a/src/java.base/windows/classes/sun/nio/fs/WindowsSecurity.java +++ b/src/java.base/windows/classes/sun/nio/fs/WindowsSecurity.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 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 @@ -102,9 +102,8 @@ class WindowsSecurity { final boolean stopImpersontating = impersontating; final boolean needToRevert = elevated; - return new Privilege() { - @Override - public void drop() { + return () -> { + try { if (token != 0L) { try { if (stopImpersontating) @@ -118,6 +117,8 @@ class WindowsSecurity { CloseHandle(token); } } + } finally { + LocalFree(pLuid); } }; } diff --git a/src/java.base/windows/native/libnio/fs/WindowsNativeDispatcher.c b/src/java.base/windows/native/libnio/fs/WindowsNativeDispatcher.c index 972f6b2df1b..07ba6e4a1f6 100644 --- a/src/java.base/windows/native/libnio/fs/WindowsNativeDispatcher.c +++ b/src/java.base/windows/native/libnio/fs/WindowsNativeDispatcher.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 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 @@ -1043,8 +1043,11 @@ Java_sun_nio_fs_WindowsNativeDispatcher_LookupPrivilegeValue0(JNIEnv* env, if (pLuid == NULL) { JNU_ThrowInternalError(env, "Unable to allocate LUID structure"); } else { - if (LookupPrivilegeValueW(NULL, lpName, pLuid) == 0) + if (LookupPrivilegeValueW(NULL, lpName, pLuid) == 0) { + LocalFree(pLuid); throwWindowsException(env, GetLastError()); + return (jlong)0; + } } return ptr_to_jlong(pLuid); }