]> cvs.zerfleddert.de Git - proxmark3-svn/commitdiff
Merge pull request #19 from alexgrin/iceman_master
authorIceman <iceman@iuse.se>
Wed, 3 Aug 2016 06:00:22 +0000 (08:00 +0200)
committerGitHub <noreply@github.com>
Wed, 3 Aug 2016 06:00:22 +0000 (08:00 +0200)
Another Coverity fix

client/cmdhflegic.c
client/util.c

index 9168258122140048a1ec15156a2d4d18f302b60b..4ad60e3b073e32e2a851faadfa1e1c82b91f81ab 100644 (file)
@@ -579,7 +579,10 @@ int CmdLegicCalcCrc8(const char *Cmd){
                        // peek at length of the input string so we can
                        // figure out how many elements to malloc in "data"
                        bg=en=0;
-                       param_getptr(Cmd, &bg, &en, cmdp+1);
+                       if (param_getptr(Cmd, &bg, &en, cmdp+1)) {
+                               errors = true;
+                               break;
+                       }
                        len = (en - bg + 1);
 
                        // check that user entered even number of characters
@@ -599,7 +602,10 @@ int CmdLegicCalcCrc8(const char *Cmd){
                                break;
                        }
                        
-                       param_gethex(Cmd, cmdp+1, data, len);
+                       if (param_gethex(Cmd, cmdp+1, data, len)) {
+                               errors = true;
+                               break;
+                       }
 
                        len >>= 1;      
                        cmdp += 2;
index e81d760014ce107d6a2f09fa95aafe1a2179c20e..b2ac82ae1d9522a58f0d2c6ef9e8a04459930aed 100644 (file)
@@ -221,7 +221,7 @@ void num_to_bytebitsLSBF(uint64_t n, size_t len, uint8_t *dest) {
 // hh,gg,ff,ee,dd,cc,bb,aa, pp,oo,nn,mm,ll,kk,jj,ii
 // up to 64 bytes or 512 bits
 uint8_t *SwapEndian64(const uint8_t *src, const size_t len, const uint8_t blockSize){
-       uint8_t buf[64];
+       static uint8_t buf[64];
        memset(buf, 0x00, 64);
        uint8_t *tmp = buf;
        for (uint8_t block=0; block < (uint8_t)(len/blockSize); block++){
@@ -229,7 +229,7 @@ uint8_t *SwapEndian64(const uint8_t *src, const size_t len, const uint8_t blockS
                        tmp[i+(blockSize*block)] = src[(blockSize-1-i)+(blockSize*block)];
                }
        }
-       return tmp;
+       return buf;
 }
 
 // takes a uint8_t src array, for len items and reverses the byte order in blocksizes (8,16,32,64), 
Impressum, Datenschutz