From 0edf6c13416f6ed755783356189233be88e7d060 Mon Sep 17 00:00:00 2001 From: Alex Menkov Date: Wed, 18 Sep 2019 12:13:56 -0700 Subject: [PATCH] 8186825: some memory leak issues in the transport_startTransport Reviewed-by: sspitsyn, phh --- .../share/native/libjdwp/transport.c | 33 ++++++++++++++----- 1 file changed, 24 insertions(+), 9 deletions(-) diff --git a/src/jdk.jdwp.agent/share/native/libjdwp/transport.c b/src/jdk.jdwp.agent/share/native/libjdwp/transport.c index 6e8c9e7194a..757fec4d88b 100644 --- a/src/jdk.jdwp.agent/share/native/libjdwp/transport.c +++ b/src/jdk.jdwp.agent/share/native/libjdwp/transport.c @@ -49,6 +49,15 @@ typedef struct TransportInfo { static struct jdwpTransportCallback callback = {jvmtiAllocate, jvmtiDeallocate}; +static void freeTransportInfo(TransportInfo *info) { + if (info) { + jvmtiDeallocate(info->name); + jvmtiDeallocate(info->address); + jvmtiDeallocate(info->allowed_peers); + jvmtiDeallocate(info); + } +} + /* * Print the last transport error */ @@ -345,12 +354,14 @@ acceptThread(jvmtiEnv* jvmti_env, JNIEnv* jni_env, void* arg) LOG_MISC(("Begin accept thread")); - info = (TransportInfo*)(void*)arg; + info = (TransportInfo*)arg; t = info->transport; rc = (*t)->Accept(t, info->timeout, 0); /* System property no longer needed */ setTransportProperty(jni_env, NULL); + /* TransportInfo data no longer needed */ + freeTransportInfo(info); if (rc != JDWPTRANSPORT_ERROR_NONE) { /* @@ -371,10 +382,14 @@ acceptThread(jvmtiEnv* jvmti_env, JNIEnv* jni_env, void* arg) static void JNICALL attachThread(jvmtiEnv* jvmti_env, JNIEnv* jni_env, void* arg) { - TransportInfo *info = (TransportInfo*)(void*)arg; + TransportInfo *info = (TransportInfo*)arg; + jdwpTransportEnv *t = info->transport; + + /* TransportInfo data no longer needed */ + freeTransportInfo(info); LOG_MISC(("Begin attach thread")); - connectionInitiated(info->transport); + connectionInitiated(t); LOG_MISC(("End attach thread")); } @@ -484,7 +499,7 @@ transport_startTransport(jboolean isServer, char *name, char *address, if (info->transport == NULL) { serror = loadTransport(name, info); if (serror != JDWP_ERROR(NONE)) { - jvmtiDeallocate(info); + freeTransportInfo(info); return serror; } } @@ -577,6 +592,9 @@ transport_startTransport(jboolean isServer, char *name, char *address, goto handleError; } + /* reset info - it will be deallocated by acceptThread */ + info = NULL; + launchCommand = debugInit_launchOnInit(); if (launchCommand != NULL) { serror = launch(launchCommand, name, retAddress); @@ -592,10 +610,7 @@ transport_startTransport(jboolean isServer, char *name, char *address, return JDWP_ERROR(NONE); handleError: - jvmtiDeallocate(info->name); - jvmtiDeallocate(info->address); - jvmtiDeallocate(info->allowed_peers); - jvmtiDeallocate(info); + freeTransportInfo(info); } else { /* * Note that we don't attempt to do a launch here. Launching @@ -614,7 +629,7 @@ handleError: /* The name, address and allowed_peers fields in 'info' * are not allocated in the non-server case so * they do not need to be freed. */ - jvmtiDeallocate(info); + freeTransportInfo(info); return serror; }