BaseTools/VolInfo: Fix potential memory leak

Cc: Liming Gao <liming.gao@intel.com>
Cc: Yonghong Zhu <yonghong.zhu@intel.com>
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Hao Wu <hao.a.wu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
diff --git a/BaseTools/Source/C/VolInfo/VolInfo.c b/BaseTools/Source/C/VolInfo/VolInfo.c
index 5da6582..312d332 100644
--- a/BaseTools/Source/C/VolInfo/VolInfo.c
+++ b/BaseTools/Source/C/VolInfo/VolInfo.c
@@ -258,6 +258,14 @@
       continue;

     }

     if ((stricmp (argv[0], "--hash") == 0)) {

+      if (EnableHash == TRUE) {

+        //

+        // --hash already given in the option, ignore this one

+        //

+        argc --;

+        argv ++;

+        continue;

+      }

       EnableHash = TRUE;

       OpenSslCommand = "openssl";

       OpenSslEnv = getenv("OPENSSL_PATH");

@@ -1784,8 +1792,14 @@
         }

 

         ScratchBuffer       = malloc (ScratchSize);

+        if (ScratchBuffer == NULL) {

+          Error (NULL, 0, 4001, "Resource", "memory cannot be allocated!");

+          return EFI_OUT_OF_RESOURCES;

+        }

         UncompressedBuffer  = malloc (UncompressedLength);

-        if ((ScratchBuffer == NULL) || (UncompressedBuffer == NULL)) {

+        if (UncompressedBuffer == NULL) {

+          free (ScratchBuffer);

+          Error (NULL, 0, 4001, "Resource", "memory cannot be allocated!");

           return EFI_OUT_OF_RESOURCES;

         }

         Status = DecompressFunction (