From 155b35a3a217155223abbd50fdfe0574bd80b9eb Mon Sep 17 00:00:00 2001 From: Christian Beer Date: Tue, 10 Nov 2015 16:34:46 +0100 Subject: [PATCH] VboxWrapper: prevent resource leak in FloppyIO::receive(string*) fixes CID 34512 found by Coverity --- samples/vboxwrapper/floppyio.cpp | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/samples/vboxwrapper/floppyio.cpp b/samples/vboxwrapper/floppyio.cpp index 5fbba30a3d..71c1e56bd4 100644 --- a/samples/vboxwrapper/floppyio.cpp +++ b/samples/vboxwrapper/floppyio.cpp @@ -275,17 +275,26 @@ int FloppyIO::receive(string * ansBuffer) { char * dataToReceive = new char[this->szInput]; // Check for ready state - if (!this->ready()) return this->setError(-4, "Stream is not ready!"); + if (!this->ready()) { + delete[] dataToReceive; + return this->setError(-4, "Stream is not ready!"); + } // If synchronized, wait for input data if (this->synchronized) { // Wait for input control byte to become 1 int iState = this->waitForSync(this->ofsCtrlByteIn, 1, this->syncTimeout); - if (iState<0) return iState; + if (iState<0) { + delete[] dataToReceive; + return iState; + } } // Check for stream status - if (!this->fIO->good()) return this->setError(-1, "I/O Stream reported no-good state while receiving!"); + if (!this->fIO->good()) { + delete[] dataToReceive; + return this->setError(-1, "I/O Stream reported no-good state while receiving!"); + } // Read the input bytes from FD this->fIO->seekg(this->ofsInput, ios_base::beg); @@ -298,6 +307,7 @@ int FloppyIO::receive(string * ansBuffer) { // Copy input data to string object *ansBuffer = dataToReceive; + dataToReceive = NULL; return (int)ansBuffer->length(); }