From faae1772c1a0cfc1b2f46ed5580c1899035d370f Mon Sep 17 00:00:00 2001 From: Matthias Baesken Date: Thu, 8 Nov 2018 17:10:47 +0100 Subject: [PATCH] 8213532: add missing LocalFree calls after using FormatMessage(A) [windows] Reviewed-by: dmarkov, serb --- .../windows/native/libawt/windows/ThemeReader.cpp | 10 ++++++++-- .../windows/native/libawt/windows/awt_Debug.cpp | 6 ++++-- .../windows/native/common/AccessBridgeDebug.cpp | 1 + 3 files changed, 13 insertions(+), 4 deletions(-) diff --git a/src/java.desktop/windows/native/libawt/windows/ThemeReader.cpp b/src/java.desktop/windows/native/libawt/windows/ThemeReader.cpp index 99ca918a500..8a4461be409 100644 --- a/src/java.desktop/windows/native/libawt/windows/ThemeReader.cpp +++ b/src/java.desktop/windows/native/libawt/windows/ThemeReader.cpp @@ -251,7 +251,7 @@ static void assert_result(HRESULT hres, JNIEnv *env) { DWORD lastError = GetLastError(); if (lastError != 0) { LPSTR msgBuffer = NULL; - FormatMessageA(FORMAT_MESSAGE_ALLOCATE_BUFFER | + DWORD fret= FormatMessageA(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, NULL, @@ -261,8 +261,14 @@ static void assert_result(HRESULT hres, JNIEnv *env) { // it's an output parameter when allocate buffer is used 0, NULL); - DTRACE_PRINTLN3("Error: hres=0x%x lastError=0x%x %s\n", hres, + if (fret != 0) { + DTRACE_PRINTLN3("Error: hres=0x%x lastError=0x%x %s\n", hres, lastError, msgBuffer); + LocalFree(msgBuffer); + } else { + DTRACE_PRINTLN2("Error: hres=0x%x lastError=0x%x \n", hres, + lastError); + } } } #endif diff --git a/src/java.desktop/windows/native/libawt/windows/awt_Debug.cpp b/src/java.desktop/windows/native/libawt/windows/awt_Debug.cpp index 49f341b660b..5faa5f3a634 100644 --- a/src/java.desktop/windows/native/libawt/windows/awt_Debug.cpp +++ b/src/java.desktop/windows/native/libawt/windows/awt_Debug.cpp @@ -182,7 +182,7 @@ void AwtDebugSupport::AssertCallback(const char * expr, const char * file, int l int ret = IDNO; static jboolean headless = isHeadless(); - FormatMessageA(FORMAT_MESSAGE_ALLOCATE_BUFFER | + DWORD fret= FormatMessageA(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, NULL, @@ -197,7 +197,9 @@ void AwtDebugSupport::AssertCallback(const char * expr, const char * file, int l } // format the assertion message _snprintf(assertMsg, ASSERT_MSG_SIZE, AssertFmt, expr, file, line, lastError, msgBuffer); - LocalFree(msgBuffer); + if (fret != 0) { + LocalFree(msgBuffer); + } // tell the user the bad news fprintf(stderr, "*********************\n"); diff --git a/src/jdk.accessibility/windows/native/common/AccessBridgeDebug.cpp b/src/jdk.accessibility/windows/native/common/AccessBridgeDebug.cpp index f41125d8c08..8c1e281ad8a 100644 --- a/src/jdk.accessibility/windows/native/common/AccessBridgeDebug.cpp +++ b/src/jdk.accessibility/windows/native/common/AccessBridgeDebug.cpp @@ -66,6 +66,7 @@ char *printError(char *msg) { if (lpMsgBuf != NULL) { strncat((char *)retbuf, ": ", sizeof(retbuf) - strlen(retbuf) - 1); strncat((char *)retbuf, (char *)lpMsgBuf, sizeof(retbuf) - strlen(retbuf) - 1); + LocalFree(lpMsgBuf); } return (char *)retbuf; }