From: marshmellow42 Date: Tue, 14 Mar 2017 20:24:14 +0000 (-0400) Subject: move new functions to utilities area X-Git-Tag: v3.0.0~45^2~4 X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/commitdiff_plain/d87bf1567a5520ae035b2cd710992fa05a5c6439 move new functions to utilities area --- diff --git a/common/lfdemod.c b/common/lfdemod.c index 395b44b1..d7524dc9 100644 --- a/common/lfdemod.c +++ b/common/lfdemod.c @@ -222,6 +222,56 @@ size_t findModStart(uint8_t dest[], size_t size, uint8_t threshold_value, uint8_ return i; } +void getNextLow(uint8_t samples[], size_t size, int low, int *i) { + while ((samples[*i] > low) && (*i < size)) + *i+=1; +} + +void getNextHigh(uint8_t samples[], size_t size, int high, int *i) { + while ((samples[*i] < high) && (*i < size)) + *i+=1; +} + +// load wave counters +bool loadWaveCounters(uint8_t samples[], size_t size, int lowToLowWaveLen[], int highToLowWaveLen[], int *waveCnt, int *skip, int *minClk, int *high, int *low) { + int i=0, start, waveStart; + size_t testsize = (size < 512) ? size : 512; + + if ( getHiLo(samples, testsize, high, low, 80, 80) == -1 ) { + if (g_debugMode==2) prnt("DEBUG STT: just noise detected - quitting"); + return false; //just noise + } + + // get to first full low to prime loop and skip incomplete first pulse + getNextHigh(samples, size, *high, &i); + getNextLow(samples, size, *low, &i); + *skip = i; + + // populate tmpbuff buffer with pulse lengths + while (i < size) { + // measure from low to low + getNextLow(samples, size, *low, &i); + start = i; + + //find first high point for this wave + getNextHigh(samples, size, *high, &i); + waveStart = i; + + getNextLow(samples, size, *low, &i); + + if (*waveCnt >= (size/32)) + break; + + highToLowWaveLen[*waveCnt] = i - waveStart; //first high to first low + lowToLowWaveLen[*waveCnt] = i - start; + *waveCnt += 1; + if (i-start < *minClk && i < size) { + *minClk = i - start; + } + } + return true; +} + //by marshmellow //amplify based on ask edge detection - not accurate enough to use all the time void askAmp(uint8_t *BitStream, size_t size) { @@ -887,55 +937,6 @@ uint8_t detectFSKClk(uint8_t *BitStream, size_t size, uint8_t fcHigh, uint8_t fc //--------------------Modulation Demods &/or Decoding Section----------------------------------- //********************************************************************************************** -void getNextLow(uint8_t samples[], size_t size, int low, int *i) { - while ((samples[*i] > low) && (*i < size)) - *i+=1; -} -void getNextHigh(uint8_t samples[], size_t size, int high, int *i) { - while ((samples[*i] < high) && (*i < size)) - *i+=1; -} - -// load wave counters -bool loadWaveCounters(uint8_t samples[], size_t size, int lowToLowWaveLen[], int highToLowWaveLen[], int *waveCnt, int *skip, int *minClk, int *high, int *low) { - int i=0, start, waveStart; - size_t testsize = (size < 512) ? size : 512; - - if ( getHiLo(samples, testsize, high, low, 80, 80) == -1 ) { - if (g_debugMode==2) prnt("DEBUG STT: just noise detected - quitting"); - return false; //just noise - } - - // get to first full low to prime loop and skip incomplete first pulse - getNextHigh(samples, size, *high, &i); - getNextLow(samples, size, *low, &i); - *skip = i; - - // populate tmpbuff buffer with pulse lengths - while (i < size) { - // measure from low to low - getNextLow(samples, size, *low, &i); - start = i; - - //find first high point for this wave - getNextHigh(samples, size, *high, &i); - waveStart = i; - - getNextLow(samples, size, *low, &i); - - if (*waveCnt >= (size/32)) - break; - - highToLowWaveLen[*waveCnt] = i - waveStart; //first high to first low - lowToLowWaveLen[*waveCnt] = i - start; - *waveCnt += 1; - if (i-start < *minClk && i < size) { - *minClk = i - start; - } - } - return true; -} - // look for Sequence Terminator - should be pulses of clk*(1 or 2), clk*2, clk*(1.5 or 2), by idx we mean graph position index... bool findST(int *stStopLoc, int *stStartIdx, int lowToLowWaveLen[], int highToLowWaveLen[], int clk, int tol, int buffSize, int *i) { for (; *i < buffSize - 4; *i+=1) {