From cf0d72e1723977c3b65b29cb7557f0bcd431feb1 Mon Sep 17 00:00:00 2001 From: mwalker33 <mwal5099@bigpond.net.au> Date: Sun, 29 Sep 2019 10:43:01 +1000 Subject: [PATCH] lf sniff offset Added samples to skip to lf config --- armsrc/lfsampling.c | 19 +++++++++++++++---- client/cmdlf.c | 25 ++++++++++++++++--------- include/pm3_cmd.h | 1 + 3 files changed, 32 insertions(+), 13 deletions(-) diff --git a/armsrc/lfsampling.c b/armsrc/lfsampling.c index 498d8f747..eea2a4c86 100644 --- a/armsrc/lfsampling.c +++ b/armsrc/lfsampling.c @@ -33,6 +33,7 @@ void printConfig() { Dbprintf(" [d] decimation..........%d", config.decimation); Dbprintf(" [a] averaging...........%s", (config.averaging) ? "Yes" : "No"); Dbprintf(" [t] trigger threshold...%d", config.trigger_threshold); + Dbprintf(" [s] samples to skip.....%d ", config.samples_to_skip); } /** @@ -50,6 +51,7 @@ void setSamplingConfig(sample_config *sc) { if (sc->divisor != 0) config.divisor = sc->divisor; if (sc->bits_per_sample != 0) config.bits_per_sample = sc->bits_per_sample; if (sc->trigger_threshold != -1) config.trigger_threshold = sc->trigger_threshold; + if (sc->samples_to_skip != -1) config.samples_to_skip = sc->samples_to_skip; config.decimation = (sc->decimation != 0) ? sc->decimation : 1; config.averaging = sc->averaging; @@ -124,7 +126,7 @@ void LFSetupFPGAForADC(int divisor, bool lf_field) { * @param silent - is true, now outputs are made. If false, dbprints the status * @return the number of bits occupied by the samples. */ -uint32_t DoAcquisition(uint8_t decimation, uint32_t bits_per_sample, bool averaging, int trigger_threshold, bool silent, int bufsize, uint32_t cancel_after) { +uint32_t DoAcquisition(uint8_t decimation, uint32_t bits_per_sample, bool averaging, int trigger_threshold, bool silent, int bufsize, uint32_t cancel_after, int samples_to_skip) { uint8_t *dest = BigBuf_get_addr(); bufsize = (bufsize > 0 && bufsize < BigBuf_max_traceLen()) ? bufsize : BigBuf_max_traceLen(); @@ -144,6 +146,7 @@ uint32_t DoAcquisition(uint8_t decimation, uint32_t bits_per_sample, bool averag uint32_t sample_total_numbers = 0; uint32_t sample_total_saved = 0; uint32_t cancel_counter = 0; + uint32_t samples_skipped = 0; uint16_t checker = 0; @@ -176,6 +179,12 @@ uint32_t DoAcquisition(uint8_t decimation, uint32_t bits_per_sample, bool averag } trigger_threshold = 0; + + if (samples_to_skip > samples_skipped) { + samples_skipped++; + continue; + } + sample_total_numbers++; if (averaging) @@ -196,6 +205,7 @@ uint32_t DoAcquisition(uint8_t decimation, uint32_t bits_per_sample, bool averag // store the sample sample_total_saved ++; + if (bits_per_sample == 8) { dest[sample_total_saved - 1] = sample; @@ -238,7 +248,7 @@ uint32_t DoAcquisition(uint8_t decimation, uint32_t bits_per_sample, bool averag * @return number of bits sampled */ uint32_t DoAcquisition_default(int trigger_threshold, bool silent) { - return DoAcquisition(1, 8, 0, trigger_threshold, silent, 0, 0); + return DoAcquisition(1, 8, 0, trigger_threshold, silent, 0, 0,0); } uint32_t DoAcquisition_config(bool silent, int sample_size) { return DoAcquisition(config.decimation @@ -247,11 +257,12 @@ uint32_t DoAcquisition_config(bool silent, int sample_size) { , config.trigger_threshold , silent , sample_size - , 0); + , 0 + , config.samples_to_skip); } uint32_t DoPartialAcquisition(int trigger_threshold, bool silent, int sample_size, uint32_t cancel_after) { - return DoAcquisition(1, 8, 0, trigger_threshold, silent, sample_size, cancel_after); + return DoAcquisition(1, 8, 0, trigger_threshold, silent, sample_size, cancel_after,0); } uint32_t ReadLF(bool activeField, bool silent, int sample_size) { diff --git a/client/cmdlf.c b/client/cmdlf.c index ee4302e82..16e8a64d5 100644 --- a/client/cmdlf.c +++ b/client/cmdlf.c @@ -105,14 +105,15 @@ static int usage_lf_sniff(void) { static int usage_lf_config(void) { PrintAndLogEx(NORMAL, "Usage: lf config [h] [H|<divisor>] [b <bps>] [d <decim>] [a 0|1]"); PrintAndLogEx(NORMAL, "Options:"); - PrintAndLogEx(NORMAL, " h This help"); - PrintAndLogEx(NORMAL, " L Low frequency (125 kHz)"); - PrintAndLogEx(NORMAL, " H High frequency (134 kHz)"); - PrintAndLogEx(NORMAL, " q <divisor> Manually set divisor. 88-> 134 kHz, 95-> 125 kHz"); - PrintAndLogEx(NORMAL, " b <bps> Sets resolution of bits per sample. Default (max): 8"); - PrintAndLogEx(NORMAL, " d <decim> Sets decimation. A value of N saves only 1 in N samples. Default: 1"); - PrintAndLogEx(NORMAL, " a [0|1] Averaging - if set, will average the stored sample value when decimating. Default: 1"); - PrintAndLogEx(NORMAL, " t <threshold> Sets trigger threshold. 0 means no threshold (range: 0-128)"); + PrintAndLogEx(NORMAL, " h This help"); + PrintAndLogEx(NORMAL, " L Low frequency (125 kHz)"); + PrintAndLogEx(NORMAL, " H High frequency (134 kHz)"); + PrintAndLogEx(NORMAL, " q <divisor> Manually set divisor. 88-> 134 kHz, 95-> 125 kHz"); + PrintAndLogEx(NORMAL, " b <bps> Sets resolution of bits per sample. Default (max): 8"); + PrintAndLogEx(NORMAL, " d <decim> Sets decimation. A value of N saves only 1 in N samples. Default: 1"); + PrintAndLogEx(NORMAL, " a [0|1] Averaging - if set, will average the stored sample value when decimating. Default: 1"); + PrintAndLogEx(NORMAL, " t <threshold> Sets trigger threshold. 0 means no threshold (range: 0-128)"); + PrintAndLogEx(NORMAL, " s <samplestoskip> Sets a number of samples to skip before capture. Default: 0"); PrintAndLogEx(NORMAL, "Examples:"); PrintAndLogEx(NORMAL, " lf config b 8 L"); PrintAndLogEx(NORMAL, " Samples at 125 kHz, 8bps."); @@ -399,6 +400,8 @@ int CmdLFSetConfig(const char *Cmd) { bool errors = false; int trigger_threshold = -1;//Means no change uint8_t unsigned_trigg = 0; + int samples_to_skip = -1; + uint8_t cmdp = 0; while (param_getchar(Cmd, cmdp) != 0x00 && !errors) { @@ -437,6 +440,10 @@ int CmdLFSetConfig(const char *Cmd) { averaging = param_getchar(Cmd, cmdp + 1) == '1'; cmdp += 2; break; + case 's': + samples_to_skip = param_get32ex(Cmd,cmdp+1,0,10); + cmdp+=2; + break; default: PrintAndLogEx(WARNING, "Unknown parameter '%c'", param_getchar(Cmd, cmdp)); errors = 1; @@ -450,7 +457,7 @@ int CmdLFSetConfig(const char *Cmd) { //Bps is limited to 8 if (bps >> 4) bps = 8; - sample_config config = { decimation, bps, averaging, divisor, trigger_threshold }; + sample_config config = { decimation, bps, averaging, divisor, trigger_threshold,samples_to_skip }; clearCommandBuffer(); SendCommandNG(CMD_LF_SAMPLING_SET_CONFIG, (uint8_t *)&config, sizeof(sample_config)); diff --git a/include/pm3_cmd.h b/include/pm3_cmd.h index 1628c558d..a8ef019d7 100644 --- a/include/pm3_cmd.h +++ b/include/pm3_cmd.h @@ -118,6 +118,7 @@ typedef struct { bool averaging; int divisor; int trigger_threshold; + int samples_to_skip; } PACKED sample_config; /* typedef struct {