]> git.zerfleddert.de Git - proxmark3-svn/commitdiff
FIX: several calls to nonce2key/nonce2key_ex has problems with not clearing up memor...
authoriceman1001 <iceman@iuse.se>
Sat, 29 Oct 2016 20:12:38 +0000 (22:12 +0200)
committericeman1001 <iceman@iuse.se>
Sat, 29 Oct 2016 20:12:38 +0000 (22:12 +0200)
Still exists problem which needs to be dealt with.

client/nonce2key/nonce2key.c

index 727f241d7d9c7f53f87cb80ebd19fe355a2b1808..853329002c3352d85af1f2a06e2c9aa2ca12463b 100644 (file)
@@ -150,6 +150,7 @@ int nonce2key_ex(uint8_t blockno, uint8_t keytype, uint32_t uid, uint32_t nt, ui
                return 0;
        }
        
+       uint8_t retval = 1;
        // Validate all key candidates with testing each of them with mfCheckKeys
        uint8_t keyBlock[6] = {0,0,0,0,0,0};
        uint64_t key64;
@@ -159,13 +160,16 @@ int nonce2key_ex(uint8_t blockno, uint8_t keytype, uint32_t uid, uint32_t nt, ui
                key64 = 0;
                if (!mfCheckKeys(blockno, keytype, false, 1, keyBlock, &key64)) {
                        *key = key64;
-                       free(last_keylist);
-                       last_keylist = NULL;
-                       free(state);
-                       return 0;
+                       retval = 0;
+                       goto out;
                }
-       }       
-       return 1;
+       }
+       
+out:
+       free(last_keylist);
+       last_keylist = NULL;
+       free(state);
+       return retval;
 }
 
 // 32 bit recover key from 2 nonces
Impressum, Datenschutz