From: iceman1001 Date: Thu, 1 Sep 2016 18:34:56 +0000 (+0200) Subject: FIX: added a sanity check in preamble search to make sure it doesn't look out-of... X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/commitdiff_plain/5735cfa58ee49398bcb494c1ea8e245baa51fac7 FIX: added a sanity check in preamble search to make sure it doesn't look out-of-bounds in the memcmp call --- diff --git a/common/lfdemod.c b/common/lfdemod.c index 27bef1dd..f231cd69 100644 --- a/common/lfdemod.c +++ b/common/lfdemod.c @@ -148,6 +148,9 @@ uint32_t bytebits_to_byteLSBF(uint8_t *src, size_t numbits) //search for given preamble in given BitStream and return success=1 or fail=0 and startIndex and length uint8_t preambleSearch(uint8_t *BitStream, uint8_t *preamble, size_t pLen, size_t *size, size_t *startIdx) { + // Sanity check. If preamble length is bigger than bitstream length. + if ( *size <= pLen ) return 0; + uint8_t foundCnt = 0; for (int idx = 0; idx < *size - pLen; idx++){ if (memcmp(BitStream+idx, preamble, pLen) == 0){