2010-02-21 08:47:22 +08:00
//-----------------------------------------------------------------------------
// Copyright (C) 2010 iZsh <izsh at fail0verflow.com>
2019-10-12 05:13:52 +08:00
// Modified by
// Marshellow
// Iceman
// Doegox
2010-02-21 08:47:22 +08:00
//
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
// at your option, any later version. See the LICENSE.txt file for the text of
// the license.
//-----------------------------------------------------------------------------
// Low frequency commands
//-----------------------------------------------------------------------------
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
# include "cmdlf.h"
2019-08-08 22:57:33 +08:00
# include <stdio.h>
# include <stdlib.h>
# include <string.h>
# include <limits.h>
# include <ctype.h>
2020-12-04 07:11:57 +08:00
# include "cmdparser.h" // command_t
2019-08-08 22:57:33 +08:00
# include "comms.h"
2020-12-04 07:11:57 +08:00
# include "commonutil.h" // ARRAYLEN
2019-08-08 22:57:33 +08:00
# include "lfdemod.h" // device/client demods of LF signals
# include "ui.h" // for show graph controls
2020-05-03 06:33:28 +08:00
# include "proxgui.h"
2020-12-04 07:11:57 +08:00
# include "cliparser.h" // args parsing
2019-08-08 22:57:33 +08:00
# include "graph.h" // for graph data
# include "cmddata.h" // for `lf search`
# include "cmdlfawid.h" // for awid menu
2020-12-04 07:11:57 +08:00
# include "cmdlfem.h" // for em menu
# include "cmdlfem410x.h" // for em4x menu
2020-10-17 01:13:40 +08:00
# include "cmdlfem4x05.h" // for em4x05 / 4x69
2020-10-20 07:00:23 +08:00
# include "cmdlfem4x50.h" // for em4x50
2020-12-06 06:47:03 +08:00
# include "cmdlfem4x70.h" // for em4x70
2019-08-08 22:57:33 +08:00
# include "cmdlfhid.h" // for hid menu
# include "cmdlfhitag.h" // for hitag menu
2020-09-29 03:09:26 +08:00
# include "cmdlfidteck.h" // for idteck menu
2019-08-08 22:57:33 +08:00
# include "cmdlfio.h" // for ioprox menu
# include "cmdlfcotag.h" // for COTAG meny
2020-10-12 18:27:00 +08:00
# include "cmdlfdestron.h" // for FDX-A FECAVA Destron menu
2020-10-12 04:38:52 +08:00
# include "cmdlffdxb.h" // for FDX-B menu
2020-09-29 03:09:26 +08:00
# include "cmdlfgallagher.h" // for GALLAGHER menu
# include "cmdlfguard.h" // for gproxii menu
# include "cmdlfindala.h" // for indala menu
# include "cmdlfjablotron.h" // for JABLOTRON menu
2019-08-08 22:57:33 +08:00
# include "cmdlfkeri.h" // for keri menu
2019-10-12 05:13:52 +08:00
# include "cmdlfmotorola.h" // for Motorola menu
2020-09-29 03:09:26 +08:00
# include "cmdlfnedap.h" // for NEDAP menu
# include "cmdlfnexwatch.h" // for nexwatch menu
# include "cmdlfnoralsy.h" // for NORALSY meny
# include "cmdlfpac.h" // for pac menu
# include "cmdlfparadox.h" // for paradox menu
# include "cmdlfpcf7931.h" // for pcf7931 menu
# include "cmdlfpresco.h" // for presco menu
# include "cmdlfpyramid.h" // for pyramid menu
# include "cmdlfsecurakey.h" // for securakey menu
# include "cmdlft55xx.h" // for t55xx menu
# include "cmdlfti.h" // for ti menu
# include "cmdlfviking.h" // for viking menu
# include "cmdlfvisa2000.h" // for VISA2000 menu
2019-08-08 22:57:33 +08:00
2020-09-17 23:17:28 +08:00
# define LF_CMDREAD_MAX_EXTRA_SYMBOLS 4
2020-06-02 02:45:37 +08:00
static bool g_lf_threshold_set = false ;
2017-02-27 21:04:50 +08:00
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
static int CmdHelp ( const char * Cmd ) ;
2019-04-10 19:06:05 +08:00
static int usage_lf_cmdread ( void ) {
2020-09-17 23:17:28 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf cmdread d <delay duration> z <zero duration> o <one duration> [e <symbol> <duration>] c <cmd symbols> [q] [s #samples] [@] " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Options: " ) ;
PrintAndLogEx ( NORMAL , " h This help " ) ;
2020-09-17 23:17:28 +08:00
PrintAndLogEx ( NORMAL , " d <duration> delay OFF period, (0 for bitbang mode) " ) ;
PrintAndLogEx ( NORMAL , " z <duration> ZERO time period " ) ;
PrintAndLogEx ( NORMAL , " o <duration> ONE time period " ) ;
PrintAndLogEx ( NORMAL , " e <symbol> <duration> Extra symbol definition and duration (up to %i) " , LF_CMDREAD_MAX_EXTRA_SYMBOLS ) ;
PrintAndLogEx ( NORMAL , " b <duration> B period " ) ;
PrintAndLogEx ( NORMAL , " c <cmd> Command symbols (0/1/...) " ) ;
PrintAndLogEx ( NORMAL , " q silent (optional) " ) ;
PrintAndLogEx ( NORMAL , " s #samples number of samples to collect (optional) " ) ;
PrintAndLogEx ( NORMAL , " @ run continuously until a key is pressed (optional) " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2020-09-18 05:08:29 +08:00
PrintAndLogEx ( NORMAL , " ************* " _YELLOW_ ( " All periods in decimal and in microseconds (us) " ) ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Examples: " ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _CYAN_ ( " probing for Hitag 1/Hitag S " ) " : " ) ;
2020-09-18 05:08:29 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf cmdread d 50 z 116 o 166 e W 3000 c W00110 " ) ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _CYAN_ ( " probing for Hitag 2 " ) " : " ) ;
2020-09-18 05:08:29 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf cmdread d 50 z 116 o 166 e W 3000 c W11000 " ) ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _CYAN_ ( " probing for Hitag 2, oscilloscope style " ) " : " ) ;
2020-09-18 05:08:29 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " data plot " ) ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf cmdread d 50 z 116 o 166 e W 3000 c W11000 q s 2000 @ " ) ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _CYAN_ ( " probing for Hitag (us) " ) " : " ) ;
2020-09-18 05:08:29 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf cmdread d 48 z 112 o 176 e W 3000 e S 240 e E 336 c W0S00000010000E " ) ) ;
2020-01-10 02:28:44 +08:00
PrintAndLogEx ( NORMAL , " Extras: " ) ;
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( NORMAL , " use " _YELLOW_ ( " 'lf config' " ) " to set parameters. " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-10-05 00:01:33 +08:00
}
2019-04-10 19:06:05 +08:00
static int usage_lf_read ( void ) {
2020-09-16 18:52:04 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf read [h] [q] [s #samples] [@] " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Options: " ) ;
PrintAndLogEx ( NORMAL , " h This help " ) ;
2020-09-16 18:52:04 +08:00
PrintAndLogEx ( NORMAL , " q silent (optional) " ) ;
PrintAndLogEx ( NORMAL , " s #samples number of samples to collect (optional) " ) ;
PrintAndLogEx ( NORMAL , " @ run continuously until a key is pressed (optional) " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
PrintAndLogEx ( NORMAL , " Examples: " ) ;
2020-09-16 18:52:04 +08:00
PrintAndLogEx ( NORMAL , " lf read " ) ;
PrintAndLogEx ( NORMAL , " - collecting quietly 12000 samples: " ) ;
PrintAndLogEx ( NORMAL , " lf read q s 12000 - " ) ;
PrintAndLogEx ( NORMAL , " - oscilloscope style: " ) ;
PrintAndLogEx ( NORMAL , " data plot " ) ;
PrintAndLogEx ( NORMAL , " lf read q s 3000 @ " ) ;
2020-01-10 02:28:44 +08:00
PrintAndLogEx ( NORMAL , " Extras: " ) ;
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( NORMAL , " use " _YELLOW_ ( " 'lf config' " ) " to set parameters. " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
}
static int usage_lf_sim ( void ) {
2020-10-23 07:31:33 +08:00
PrintAndLogEx ( NORMAL , " Simulate low frequency tag from graphbuffer. " ) ;
2019-05-24 01:16:06 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf sim [h] <gap> " ) ;
2019-05-23 22:51:19 +08:00
PrintAndLogEx ( NORMAL , " Options: " ) ;
2019-05-24 01:16:06 +08:00
PrintAndLogEx ( NORMAL , " h This help " ) ;
PrintAndLogEx ( NORMAL , " <gap> Start gap (in microseconds) " ) ;
2019-05-23 22:51:19 +08:00
PrintAndLogEx ( NORMAL , " Examples: " ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf sim 240 " ) " - start simulating with 240ms gap " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf sim " ) ) ;
2020-01-10 02:28:44 +08:00
PrintAndLogEx ( NORMAL , " Extras: " ) ;
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( NORMAL , " use " _YELLOW_ ( " 'lf config' " ) " to set parameters. " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-10-21 15:07:36 +08:00
}
2019-04-10 19:06:05 +08:00
static int usage_lf_sniff ( void ) {
2020-10-23 07:31:33 +08:00
PrintAndLogEx ( NORMAL , " Sniff low frequency signal. " ) ;
2020-09-20 17:12:38 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf sniff [h] [q] [s #samples] [@] " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Options: " ) ;
2019-05-22 20:32:30 +08:00
PrintAndLogEx ( NORMAL , " h This help " ) ;
2020-09-20 17:12:38 +08:00
PrintAndLogEx ( NORMAL , " q silent (optional) " ) ;
PrintAndLogEx ( NORMAL , " s #samples number of samples to collect (optional) " ) ;
PrintAndLogEx ( NORMAL , " @ run continuously until a key is pressed (optional) " ) ;
PrintAndLogEx ( NORMAL , " Examples: " ) ;
PrintAndLogEx ( NORMAL , " lf sniff " ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _CYAN_ ( " oscilloscope style " ) " : " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " data plot " ) ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf sniff q s 3000 @ " ) ) ;
2020-01-10 02:28:44 +08:00
PrintAndLogEx ( NORMAL , " Extras: " ) ;
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( NORMAL , " use " _YELLOW_ ( " 'lf config' " ) " to set parameters. " ) ;
PrintAndLogEx ( NORMAL , " use " _YELLOW_ ( " 'data plot' " ) " to look at it " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-10-21 15:07:36 +08:00
}
2019-04-10 19:06:05 +08:00
static int usage_lf_config ( void ) {
2019-10-04 03:46:06 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf config [h] [L | H | q <divisor> | f <freq>] [b <bps>] [d <decim>] [a 0|1] " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Options: " ) ;
2019-09-29 08:43:01 +08:00
PrintAndLogEx ( NORMAL , " h This help " ) ;
PrintAndLogEx ( NORMAL , " L Low frequency (125 kHz) " ) ;
PrintAndLogEx ( NORMAL , " H High frequency (134 kHz) " ) ;
2019-10-04 03:46:06 +08:00
PrintAndLogEx ( NORMAL , " q <divisor> Manually set freq divisor. %d -> 134 kHz, %d -> 125 kHz " , LF_DIVISOR_134 , LF_DIVISOR_125 ) ;
PrintAndLogEx ( NORMAL , " f <freq> Manually set frequency in kHz " ) ;
2019-09-29 08:43:01 +08:00
PrintAndLogEx ( NORMAL , " b <bps> Sets resolution of bits per sample. Default (max): 8 " ) ;
2020-01-10 02:28:44 +08:00
PrintAndLogEx ( NORMAL , " d <decimate> Sets decimation. A value of N saves only 1 in N samples. Default: 1 " ) ;
2019-09-29 08:43:01 +08:00
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 " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Examples: " ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf config " ) " - shows current config " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf config b 8 L " ) " - samples at 125 kHz, 8bps. " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf config H b 4 d 3 " ) " - samples at 134 kHz, averages three samples into one, stored with " ) ;
2020-01-10 02:28:44 +08:00
PrintAndLogEx ( NORMAL , " a resolution of 4 bits per sample. " ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf read " ) " - performs a read (active field) " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf sniff " ) " - performs a sniff (no active field) " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-10-21 15:07:36 +08:00
}
2019-04-10 19:06:05 +08:00
static int usage_lf_simfsk ( void ) {
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf simfsk [h] [c <clock>] [H <fcHigh>] [L <fcLow>] [d <hexdata>] " ) ;
PrintAndLogEx ( NORMAL , " there are about four FSK modulations to know of. " ) ;
PrintAndLogEx ( NORMAL , " FSK1 - where fc/8 = high and fc/5 = low " ) ;
PrintAndLogEx ( NORMAL , " FSK1a - is inverted FSK1, ie: fc/5 = high and fc/8 = low " ) ;
PrintAndLogEx ( NORMAL , " FSK2 - where fc/10 = high and fc/8 = low " ) ;
PrintAndLogEx ( NORMAL , " FSK2a - is inverted FSK2, ie: fc/10 = high and fc/8 = low " ) ;
PrintAndLogEx ( NORMAL , " " ) ;
PrintAndLogEx ( NORMAL , " Options: " ) ;
PrintAndLogEx ( NORMAL , " h This help " ) ;
PrintAndLogEx ( NORMAL , " c <clock> Manually set clock - can autodetect if using DemodBuffer " ) ;
PrintAndLogEx ( NORMAL , " H <fcHigh> Manually set the larger Field Clock " ) ;
PrintAndLogEx ( NORMAL , " L <fcLow> Manually set the smaller Field Clock " ) ;
//PrintAndLogEx(NORMAL, " s TBD- -STT to enable a gap between playback repetitions - default: no gap");
PrintAndLogEx ( NORMAL , " d <hexdata> Data to sim as hex - omit to sim from DemodBuffer " ) ;
PrintAndLogEx ( NORMAL , " \n NOTE: if you set one clock manually set them all manually " ) ;
PrintAndLogEx ( NORMAL , " " ) ;
PrintAndLogEx ( NORMAL , " Examples: " ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf simfsk c 40 H 8 L 5 d 010203 " ) " - FSK1 rf/40 data 010203 " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf simfsk c 40 H 5 L 8 d 010203 " ) " - FSK1a rf/40 data 010203 " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf simfsk c 64 H 10 L 8 d 010203 " ) " - FSK2 rf/64 data 010203 " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf simfsk c 64 H 8 L 10 d 010203 " ) " - FSK2a rf/64 data 010203 " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-10-21 15:07:36 +08:00
}
2019-04-10 19:06:05 +08:00
static int usage_lf_simask ( void ) {
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf simask [c <clock>] [i] [b|m|r] [s] [d <raw hex to sim>] " ) ;
PrintAndLogEx ( NORMAL , " Options: " ) ;
PrintAndLogEx ( NORMAL , " h This help " ) ;
PrintAndLogEx ( NORMAL , " c <clock> Manually set clock - can autodetect if using DemodBuffer " ) ;
PrintAndLogEx ( NORMAL , " i invert data " ) ;
PrintAndLogEx ( NORMAL , " b sim ask/biphase " ) ;
PrintAndLogEx ( NORMAL , " m sim ask/manchester - Default " ) ;
PrintAndLogEx ( NORMAL , " r sim ask/raw " ) ;
PrintAndLogEx ( NORMAL , " s add t55xx Sequence Terminator gap - default: no gaps (only manchester) " ) ;
PrintAndLogEx ( NORMAL , " d <hexdata> Data to sim as hex - omit to sim from DemodBuffer " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-10-21 15:07:36 +08:00
}
2019-04-10 19:06:05 +08:00
static int usage_lf_simpsk ( void ) {
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf simpsk [1|2|3] [c <clock>] [i] [r <carrier>] [d <raw hex to sim>] " ) ;
PrintAndLogEx ( NORMAL , " Options: " ) ;
PrintAndLogEx ( NORMAL , " h This help " ) ;
PrintAndLogEx ( NORMAL , " c <clock> Manually set clock - can autodetect if using DemodBuffer " ) ;
PrintAndLogEx ( NORMAL , " i invert data " ) ;
PrintAndLogEx ( NORMAL , " 1 set PSK1 (default) " ) ;
PrintAndLogEx ( NORMAL , " 2 set PSK2 " ) ;
PrintAndLogEx ( NORMAL , " 3 set PSK3 " ) ;
PrintAndLogEx ( NORMAL , " r <carrier> 2|4|8 are valid carriers: default = 2 " ) ;
PrintAndLogEx ( NORMAL , " d <hexdata> Data to sim as hex - omit to sim from DemodBuffer " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-10-21 15:07:36 +08:00
}
2019-04-10 19:06:05 +08:00
static int usage_lf_find ( void ) {
2018-02-21 15:31:24 +08:00
PrintAndLogEx ( NORMAL , " Usage: lf search [h] <0|1> [u] " ) ;
PrintAndLogEx ( NORMAL , " " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Options: " ) ;
PrintAndLogEx ( NORMAL , " h This help " ) ;
PrintAndLogEx ( NORMAL , " <0|1> Use data from Graphbuffer, if not set, try reading data from tag. " ) ;
2018-02-21 15:31:24 +08:00
PrintAndLogEx ( NORMAL , " u Search for Unknown tags, if not set, reads only known tags. " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( NORMAL , " Examples: " ) ;
2020-09-28 16:19:27 +08:00
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf search " ) " - try reading data from tag & search for known tags " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf search 1 " ) " - use data from GraphBuffer & search for known tags " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf search u " ) " - try reading data from tag & search for known and unknown tags " ) ;
PrintAndLogEx ( NORMAL , _YELLOW_ ( " lf search 1 u " ) " - use data from GraphBuffer & search for known and unknown tags " ) ;
2019-05-23 22:51:19 +08:00
return PM3_SUCCESS ;
2015-11-10 18:42:59 +08:00
}
2019-09-24 19:06:43 +08:00
2019-10-25 06:55:16 +08:00
static int CmdLFTune ( const char * Cmd ) {
2020-12-21 08:45:03 +08:00
CLIParserContext * ctx ;
CLIParserInit ( & ctx , " lf tune " ,
" Continuously measure LF antenna tuning. \n "
" Press button or <Enter> to interrupt. " ,
2020-12-21 09:06:43 +08:00
" lf tune \n "
" lf tune --mixed "
2020-12-21 08:45:03 +08:00
) ;
char q_str [ 60 ] ;
snprintf ( q_str , sizeof ( q_str ) , " Frequency divisor. %d -> 134 kHz, %d -> 125 kHz " , LF_DIVISOR_134 , LF_DIVISOR_125 ) ;
void * argtable [ ] = {
arg_param_begin ,
2020-12-21 09:06:43 +08:00
arg_u64_0 ( " n " , " iter " , " <dec> " , " number of iterations (default: 0=infinite) " ) ,
2020-12-21 08:45:03 +08:00
arg_u64_0 ( " q " , " divisor " , " <dec> " , q_str ) ,
arg_dbl0 ( " f " , " freq " , " <float> " , " Frequency in kHz " ) ,
arg_lit0 ( NULL , " bar " , " bar style " ) ,
arg_lit0 ( NULL , " mix " , " mixed style " ) ,
arg_lit0 ( NULL , " value " , " values style " ) ,
arg_param_end
} ;
CLIExecWithReturn ( ctx , Cmd , argtable , true ) ;
uint32_t iter = arg_get_u32_def ( ctx , 1 , 0 ) ;
uint8_t divisor = arg_get_u32_def ( ctx , 2 , LF_DIVISOR_125 ) ;
double freq = arg_get_dbl_def ( ctx , 3 , 125 ) ;
bool is_bar = arg_get_lit ( ctx , 4 ) ;
bool is_mix = arg_get_lit ( ctx , 5 ) ;
bool is_value = arg_get_lit ( ctx , 6 ) ;
CLIParserFree ( ctx ) ;
if ( divisor < 19 ) {
PrintAndLogEx ( ERR , " divisor must be between 19 and 255 " ) ;
return PM3_EINVARG ;
2019-10-04 03:18:37 +08:00
}
2020-12-21 08:45:03 +08:00
if ( ( freq < 47 ) | | ( freq > 600 ) ) {
PrintAndLogEx ( ERR , " freq must be between 47 and 600 " ) ;
return PM3_EINVARG ;
}
divisor = LF_FREQ2DIV ( freq ) ;
if ( ( is_bar + is_mix + is_value ) > 1 ) {
PrintAndLogEx ( ERR , " Select only one output style " ) ;
return PM3_EINVARG ;
}
barMode_t style = session . bar_mode ;
if ( is_bar )
style = STYLE_BAR ;
if ( is_mix )
style = STYLE_MIXED ;
if ( is_value )
style = STYLE_VALUE ;
2019-09-24 19:06:43 +08:00
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( INFO , " Measuring LF antenna at " _YELLOW_ ( " %.2f " ) " kHz, click " _GREEN_ ( " pm3 button " ) " or press " _GREEN_ ( " Enter " ) " to exit " , LF_DIV2FREQ ( divisor ) ) ;
2019-09-24 19:06:43 +08:00
2019-10-04 03:18:37 +08:00
uint8_t params [ ] = { 1 , 0 } ;
params [ 1 ] = divisor ;
2019-09-24 19:06:43 +08:00
PacketResponseNG resp ;
clearCommandBuffer ( ) ;
2020-02-24 16:44:48 +08:00
2019-10-04 03:18:37 +08:00
SendCommandNG ( CMD_MEASURE_ANTENNA_TUNING_LF , params , sizeof ( params ) ) ;
2019-09-24 19:06:43 +08:00
if ( ! WaitForResponseTimeout ( CMD_MEASURE_ANTENNA_TUNING_LF , & resp , 1000 ) ) {
PrintAndLogEx ( WARNING , " Timeout while waiting for Proxmark LF initialization, aborting " ) ;
return PM3_ETIMEOUT ;
}
2020-02-24 16:44:48 +08:00
2019-10-04 03:18:37 +08:00
params [ 0 ] = 2 ;
2020-12-21 08:45:03 +08:00
2020-12-21 09:06:43 +08:00
// #define MAX_ADC_LF_VOLTAGE 140800
2020-12-21 08:45:03 +08:00
uint32_t max = 71000 ;
bool first = true ;
print_progress ( 0 , max , style ) ;
2019-09-24 19:06:43 +08:00
// loop forever (till button pressed) if iter = 0 (default)
for ( uint8_t i = 0 ; iter = = 0 | | i < iter ; i + + ) {
2020-02-24 16:44:48 +08:00
if ( kbd_enter_pressed ( ) ) {
2019-09-24 19:06:43 +08:00
break ;
}
2020-02-24 16:44:48 +08:00
2019-10-04 03:18:37 +08:00
SendCommandNG ( CMD_MEASURE_ANTENNA_TUNING_LF , params , sizeof ( params ) ) ;
2019-09-24 19:06:43 +08:00
if ( ! WaitForResponseTimeout ( CMD_MEASURE_ANTENNA_TUNING_LF , & resp , 1000 ) ) {
2020-02-24 16:44:48 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2019-09-24 19:06:43 +08:00
PrintAndLogEx ( WARNING , " Timeout while waiting for Proxmark LF measure, aborting " ) ;
2020-12-21 08:45:03 +08:00
break ;
2019-09-24 19:06:43 +08:00
}
2020-02-24 16:44:48 +08:00
if ( ( resp . status = = PM3_EOPABORTED ) | | ( resp . length ! = sizeof ( uint32_t ) ) ) {
2020-12-21 08:45:03 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2019-09-24 19:06:43 +08:00
break ;
2020-02-24 16:44:48 +08:00
}
2019-09-24 21:44:16 +08:00
uint32_t volt = resp . data . asDwords [ 0 ] ;
2020-12-21 08:45:03 +08:00
if ( first ) {
max = ( volt * 1.03 ) ;
first = false ;
}
if ( volt > max ) {
max = ( volt * 1.03 ) ;
}
print_progress ( volt , max , style ) ;
2019-09-24 19:06:43 +08:00
}
2020-02-24 16:44:48 +08:00
2019-10-04 03:18:37 +08:00
params [ 0 ] = 3 ;
SendCommandNG ( CMD_MEASURE_ANTENNA_TUNING_LF , params , sizeof ( params ) ) ;
2019-09-24 19:06:43 +08:00
if ( ! WaitForResponseTimeout ( CMD_MEASURE_ANTENNA_TUNING_LF , & resp , 1000 ) ) {
PrintAndLogEx ( WARNING , " Timeout while waiting for Proxmark LF shutdown, aborting " ) ;
return PM3_ETIMEOUT ;
}
2020-12-21 08:45:03 +08:00
PrintAndLogEx ( NORMAL , " \x1b %c[2K \r " , 30 ) ;
2020-03-16 05:41:05 +08:00
PrintAndLogEx ( INFO , " Done. " ) ;
2019-09-24 19:06:43 +08:00
return PM3_SUCCESS ;
}
2015-11-10 18:42:59 +08:00
2015-10-17 05:16:46 +08:00
/* send a LF command before reading */
2019-03-10 18:20:22 +08:00
int CmdLFCommandRead ( const char * Cmd ) {
2016-07-31 01:36:48 +08:00
2019-05-24 01:16:06 +08:00
if ( ! session . pm3_present ) return PM3_ENOTTY ;
2019-03-10 06:35:06 +08:00
bool errors = false ;
2020-09-16 18:52:04 +08:00
bool verbose = true ;
bool continuous = false ;
uint32_t samples = 0 ;
2019-04-19 23:03:39 +08:00
uint16_t datalen = 0 ;
2019-04-20 07:08:07 +08:00
2020-09-17 23:17:28 +08:00
const uint8_t payload_header_size = 12 + ( 3 * LF_CMDREAD_MAX_EXTRA_SYMBOLS ) ;
2019-05-20 21:15:45 +08:00
struct p {
uint32_t delay ;
2020-09-17 23:17:28 +08:00
uint16_t period_0 ;
uint16_t period_1 ;
uint8_t symbol_extra [ LF_CMDREAD_MAX_EXTRA_SYMBOLS ] ;
uint16_t period_extra [ LF_CMDREAD_MAX_EXTRA_SYMBOLS ] ;
2020-09-16 18:52:04 +08:00
uint32_t samples : 31 ;
bool verbose : 1 ;
uint8_t data [ PM3_CMD_DATA_SIZE - payload_header_size ] ;
2019-05-24 01:16:06 +08:00
} PACKED payload ;
2020-09-16 18:52:04 +08:00
payload . samples = samples ;
payload . verbose = verbose ;
2020-09-17 23:17:28 +08:00
uint8_t index_extra = 0 ;
2019-05-20 21:15:45 +08:00
2019-03-10 06:35:06 +08:00
uint8_t cmdp = 0 ;
while ( param_getchar ( Cmd , cmdp ) ! = 0x00 & & ! errors ) {
switch ( tolower ( param_getchar ( Cmd , cmdp ) ) ) {
2019-03-10 07:00:59 +08:00
case ' h ' :
return usage_lf_cmdread ( ) ;
2019-05-20 21:15:45 +08:00
case ' c ' : // cmd bytes 1010
datalen = param_getstr ( Cmd , cmdp + 1 , ( char * ) & payload . data , sizeof ( payload . data ) ) ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2019-05-20 21:15:45 +08:00
case ' d ' : // delay
payload . delay = param_get32ex ( Cmd , cmdp + 1 , 0 , 10 ) ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2019-05-20 21:15:45 +08:00
case ' z ' : // zero
2020-09-17 23:17:28 +08:00
payload . period_0 = param_get32ex ( Cmd , cmdp + 1 , 0 , 10 ) & 0xFFFF ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2019-05-20 21:15:45 +08:00
case ' o ' : // ones
2020-09-17 23:17:28 +08:00
payload . period_1 = param_get32ex ( Cmd , cmdp + 1 , 0 , 10 ) & 0xFFFF ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2020-09-17 23:17:28 +08:00
case ' e ' : // extra symbol definition
if ( index_extra < LF_CMDREAD_MAX_EXTRA_SYMBOLS - 1 ) {
payload . symbol_extra [ index_extra ] = param_getchar ( Cmd , cmdp + 1 ) ;
payload . period_extra [ index_extra ] = param_get32ex ( Cmd , cmdp + 2 , 0 , 10 ) & 0xFFFF ;
index_extra + + ;
cmdp + = 3 ;
} else {
PrintAndLogEx ( WARNING , " Too many extra symbols, please define up to %i symbols " , LF_CMDREAD_MAX_EXTRA_SYMBOLS ) ;
errors = true ;
}
break ;
2020-09-16 18:52:04 +08:00
case ' s ' :
samples = param_get32ex ( Cmd , cmdp + 1 , 0 , 10 ) ;
payload . samples = samples ;
cmdp + = 2 ;
break ;
case ' q ' :
verbose = false ;
payload . verbose = verbose ;
cmdp + + ;
break ;
case ' @ ' :
continuous = true ;
cmdp + + ;
break ;
2019-03-10 07:00:59 +08:00
default :
PrintAndLogEx ( WARNING , " Unknown parameter '%c' " , param_getchar ( Cmd , cmdp ) ) ;
errors = true ;
break ;
2019-03-10 06:35:06 +08:00
}
}
2019-10-13 06:48:26 +08:00
// bitbang mode
if ( payload . delay = = 0 ) {
2020-09-17 23:17:28 +08:00
if ( payload . period_0 < 7 | | payload . period_1 < 7 ) {
2020-01-19 21:51:39 +08:00
PrintAndLogEx ( WARNING , " warning periods cannot be less than 7us in bit bang mode " ) ;
2019-10-13 06:48:26 +08:00
return PM3_EINVARG ;
}
}
2019-10-01 05:18:48 +08:00
2019-03-10 06:35:06 +08:00
//Validations
if ( errors | | cmdp = = 0 ) return usage_lf_cmdread ( ) ;
2020-09-16 18:52:04 +08:00
if ( continuous ) {
PrintAndLogEx ( INFO , " Press " _GREEN_ ( " Enter " ) " to exit " ) ;
}
if ( verbose ) {
PrintAndLogEx ( SUCCESS , " Sending command... " ) ;
}
2019-03-10 06:35:06 +08:00
2020-09-16 18:52:04 +08:00
int ret = PM3_SUCCESS ;
do {
clearCommandBuffer ( ) ;
SendCommandNG ( CMD_LF_MOD_THEN_ACQ_RAW_ADC , ( uint8_t * ) & payload , payload_header_size + datalen ) ;
2019-10-01 01:39:34 +08:00
2020-09-16 18:52:04 +08:00
PacketResponseNG resp ;
2019-03-10 06:35:06 +08:00
2020-09-16 18:52:04 +08:00
uint8_t i = 10 ;
// 20sec wait loop
while ( ! WaitForResponseTimeout ( CMD_LF_MOD_THEN_ACQ_RAW_ADC , & resp , 2000 ) & & i ! = 0 ) {
if ( verbose ) {
PrintAndLogEx ( NORMAL , " . " NOLF ) ;
}
i - - ;
}
if ( verbose ) {
PrintAndLogEx ( NORMAL , " " ) ;
}
if ( resp . status = = PM3_SUCCESS ) {
if ( i ) {
if ( verbose ) {
PrintAndLogEx ( SUCCESS , " downloading response signal data " ) ;
}
getSamples ( samples , false ) ;
ret = PM3_SUCCESS ;
} else {
PrintAndLogEx ( WARNING , " timeout while waiting for reply. " ) ;
return PM3_ETIMEOUT ;
}
2019-10-01 01:39:34 +08:00
} else {
2020-09-16 18:52:04 +08:00
PrintAndLogEx ( WARNING , " command failed. " ) ;
return PM3_ESOFT ;
2019-10-01 01:39:34 +08:00
}
2020-09-16 18:52:04 +08:00
if ( kbd_enter_pressed ( ) ) {
break ;
}
} while ( continuous ) ;
return ret ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}
2019-03-10 18:20:22 +08:00
int CmdFlexdemod ( const char * Cmd ) {
2019-04-10 18:23:40 +08:00
( void ) Cmd ; // Cmd is not used so far
2019-02-25 03:11:05 +08:00
# ifndef LONG_WAIT
# define LONG_WAIT 100
# endif
2019-04-10 14:55:29 +08:00
int i , j , start , bit , sum ;
2019-03-10 06:35:06 +08:00
int data [ GraphTraceLen ] ;
memcpy ( data , GraphBuffer , GraphTraceLen ) ;
size_t size = GraphTraceLen ;
for ( i = 0 ; i < GraphTraceLen ; + + i )
data [ i ] = ( data [ i ] < 0 ) ? - 1 : 1 ;
for ( start = 0 ; start < size - LONG_WAIT ; start + + ) {
int first = data [ start ] ;
for ( i = start ; i < start + LONG_WAIT ; i + + ) {
if ( data [ i ] ! = first ) {
break ;
}
}
if ( i = = ( start + LONG_WAIT ) )
break ;
}
if ( start = = size - LONG_WAIT ) {
2019-03-12 06:12:31 +08:00
PrintAndLogEx ( WARNING , " nothing to wait for " ) ;
2019-05-24 01:16:06 +08:00
return PM3_ENODATA ;
2019-03-10 06:35:06 +08:00
}
data [ start ] = 4 ;
2019-03-10 07:00:59 +08:00
data [ start + 1 ] = 0 ;
2019-03-10 06:35:06 +08:00
uint8_t bits [ 64 ] = { 0x00 } ;
i = start ;
for ( bit = 0 ; bit < 64 ; bit + + ) {
sum = 0 ;
2019-04-08 02:13:30 +08:00
for ( j = 0 ; j < 16 ; j + + ) {
2019-03-10 06:35:06 +08:00
sum + = data [ i + + ] ;
}
bits [ bit ] = ( sum > 0 ) ? 1 : 0 ;
PrintAndLogEx ( NORMAL , " bit %d sum %d " , bit , sum ) ;
}
for ( bit = 0 ; bit < 64 ; bit + + ) {
sum = 0 ;
for ( j = 0 ; j < 16 ; j + + )
sum + = data [ i + + ] ;
2019-03-10 21:42:43 +08:00
if ( sum > 0 & & bits [ bit ] ! = 1 ) PrintAndLogEx ( WARNING , " oops1 at %d " , bit ) ;
2019-03-10 06:35:06 +08:00
2019-03-10 21:42:43 +08:00
if ( sum < 0 & & bits [ bit ] ! = 0 ) PrintAndLogEx ( WARNING , " oops2 at %d " , bit ) ;
2019-03-10 06:35:06 +08:00
}
// iceman, use demod buffer? blue line?
// HACK writing back to graphbuffer.
GraphTraceLen = 32 * 64 ;
i = 0 ;
for ( bit = 0 ; bit < 64 ; bit + + ) {
2019-04-10 14:55:29 +08:00
int phase = ( bits [ bit ] = = 0 ) ? 0 : 1 ;
2019-03-10 06:35:06 +08:00
for ( j = 0 ; j < 32 ; j + + ) {
GraphBuffer [ i + + ] = phase ;
phase = ! phase ;
}
}
RepaintGraphWindow ( ) ;
2019-05-24 01:16:06 +08:00
return PM3_SUCCESS ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}
2012-07-02 16:37:50 +08:00
2020-03-05 18:16:05 +08:00
int lf_getconfig ( sample_config * config ) {
if ( ! session . pm3_present ) return PM3_ENOTTY ;
if ( config = = NULL )
return PM3_EINVARG ;
clearCommandBuffer ( ) ;
SendCommandNG ( CMD_LF_SAMPLING_GET_CONFIG , NULL , 0 ) ;
PacketResponseNG resp ;
if ( ! WaitForResponseTimeout ( CMD_LF_SAMPLING_GET_CONFIG , & resp , 2000 ) ) {
PrintAndLogEx ( WARNING , " command execution time out " ) ;
return PM3_ETIMEOUT ;
}
2020-03-05 18:27:42 +08:00
memcpy ( config , resp . data . asBytes , sizeof ( sample_config ) ) ;
2020-03-05 18:16:05 +08:00
return PM3_SUCCESS ;
}
2019-10-12 05:13:52 +08:00
int lf_config ( sample_config * config ) {
if ( ! session . pm3_present ) return PM3_ENOTTY ;
clearCommandBuffer ( ) ;
2020-01-10 02:28:44 +08:00
if ( config ! = NULL )
SendCommandNG ( CMD_LF_SAMPLING_SET_CONFIG , ( uint8_t * ) config , sizeof ( sample_config ) ) ;
2020-01-13 00:28:12 +08:00
else
2020-03-05 18:16:05 +08:00
SendCommandNG ( CMD_LF_SAMPLING_PRINT_CONFIG , NULL , 0 ) ;
2020-01-13 00:28:12 +08:00
2019-10-12 05:13:52 +08:00
return PM3_SUCCESS ;
}
2019-10-04 04:11:16 +08:00
int CmdLFConfig ( const char * Cmd ) {
2019-05-24 01:16:06 +08:00
if ( ! session . pm3_present ) return PM3_ENOTTY ;
2020-01-10 02:28:44 +08:00
// if called with no params, just print the device config
if ( strlen ( Cmd ) = = 0 ) {
return lf_config ( NULL ) ;
}
2019-09-29 08:43:01 +08:00
2020-01-10 02:28:44 +08:00
sample_config config = {
2020-01-13 00:28:12 +08:00
. decimation = - 1 ,
. bits_per_sample = - 1 ,
. averaging = - 1 ,
. divisor = - 1 ,
. trigger_threshold = - 1 ,
. samples_to_skip = - 1 ,
. verbose = true
2020-01-10 02:28:44 +08:00
} ;
2020-01-13 00:28:12 +08:00
2020-01-10 02:28:44 +08:00
bool errors = false ;
2019-03-10 06:35:06 +08:00
uint8_t cmdp = 0 ;
while ( param_getchar ( Cmd , cmdp ) ! = 0x00 & & ! errors ) {
switch ( param_getchar ( Cmd , cmdp ) ) {
2019-03-10 07:00:59 +08:00
case ' h ' :
return usage_lf_config ( ) ;
case ' H ' :
2020-01-10 02:28:44 +08:00
config . divisor = LF_DIVISOR_134 ;
2019-03-10 07:00:59 +08:00
cmdp + + ;
break ;
case ' L ' :
2020-01-10 02:28:44 +08:00
config . divisor = LF_DIVISOR_125 ;
2019-03-10 07:00:59 +08:00
cmdp + + ;
break ;
case ' q ' :
2020-01-10 02:28:44 +08:00
config . divisor = param_get8ex ( Cmd , cmdp + 1 , 95 , 10 ) ;
if ( config . divisor < 19 ) {
2019-10-04 03:46:06 +08:00
PrintAndLogEx ( ERR , " divisor must be between 19 and 255 " ) ;
return PM3_EINVARG ;
}
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2019-10-04 03:46:06 +08:00
case ' f ' : {
2019-10-04 03:56:42 +08:00
int freq = param_get32ex ( Cmd , cmdp + 1 , 125 , 10 ) ;
2020-01-10 02:28:44 +08:00
config . divisor = LF_FREQ2DIV ( freq ) ;
if ( config . divisor < 19 ) {
2019-10-04 03:46:06 +08:00
PrintAndLogEx ( ERR , " freq must be between 47 and 600 " ) ;
return PM3_EINVARG ;
}
cmdp + = 2 ;
break ;
}
2020-01-10 02:28:44 +08:00
case ' t ' : {
uint8_t trigg = 0 ;
errors | = param_getdec ( Cmd , cmdp + 1 , & trigg ) ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
if ( ! errors ) {
2020-01-10 02:28:44 +08:00
config . trigger_threshold = trigg ;
g_lf_threshold_set = ( config . trigger_threshold > 0 ) ;
2019-03-10 07:00:59 +08:00
}
break ;
2020-01-10 02:28:44 +08:00
}
case ' b ' : {
2020-01-13 00:28:12 +08:00
config . bits_per_sample = param_get8ex ( Cmd , cmdp + 1 , 8 , 10 ) ;
2020-01-10 02:28:44 +08:00
// bps is limited to 8
2020-01-13 00:28:12 +08:00
if ( config . bits_per_sample > > 4 )
2020-01-10 02:28:44 +08:00
config . bits_per_sample = 8 ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2020-01-10 02:28:44 +08:00
}
case ' d ' : {
2020-01-13 00:28:12 +08:00
config . decimation = param_get8ex ( Cmd , cmdp + 1 , 1 , 10 ) ;
2020-01-10 02:28:44 +08:00
// decimation is limited to 255
2020-01-13 00:28:12 +08:00
if ( config . decimation > > 4 )
2020-01-10 02:28:44 +08:00
config . decimation = 8 ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2020-01-10 02:28:44 +08:00
}
2019-03-10 07:00:59 +08:00
case ' a ' :
2020-01-10 02:28:44 +08:00
config . averaging = ( param_getchar ( Cmd , cmdp + 1 ) = = ' 1 ' ) ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2019-09-29 08:43:01 +08:00
case ' s ' :
2020-01-10 02:28:44 +08:00
config . samples_to_skip = param_get32ex ( Cmd , cmdp + 1 , 0 , 10 ) ;
2019-10-13 06:48:26 +08:00
cmdp + = 2 ;
2019-09-29 08:43:01 +08:00
break ;
2019-03-10 07:00:59 +08:00
default :
PrintAndLogEx ( WARNING , " Unknown parameter '%c' " , param_getchar ( Cmd , cmdp ) ) ;
errors = 1 ;
break ;
2019-03-10 06:35:06 +08:00
}
}
2019-10-12 05:13:52 +08:00
// validations
2019-10-04 04:11:16 +08:00
if ( errors ) return usage_lf_config ( ) ;
2019-03-10 06:35:06 +08:00
2019-10-12 05:13:52 +08:00
return lf_config ( & config ) ;
2015-01-31 06:03:44 +08:00
}
2015-01-29 07:57:22 +08:00
2020-01-08 05:05:01 +08:00
int lf_read ( bool verbose , uint32_t samples ) {
2019-05-24 01:16:06 +08:00
if ( ! session . pm3_present ) return PM3_ENOTTY ;
2019-05-20 22:48:51 +08:00
struct p {
2020-09-16 18:52:04 +08:00
uint32_t samples : 31 ;
bool verbose : 1 ;
2019-05-20 22:48:51 +08:00
} PACKED ;
struct p payload ;
2020-01-08 05:05:01 +08:00
payload . verbose = verbose ;
2019-05-20 22:48:51 +08:00
payload . samples = samples ;
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2019-08-04 01:17:00 +08:00
SendCommandNG ( CMD_LF_ACQ_RAW_ADC , ( uint8_t * ) & payload , sizeof ( payload ) ) ;
2019-04-18 18:43:35 +08:00
PacketResponseNG resp ;
2019-03-10 06:35:06 +08:00
if ( g_lf_threshold_set ) {
2019-08-04 01:17:00 +08:00
WaitForResponse ( CMD_LF_ACQ_RAW_ADC , & resp ) ;
2019-03-10 06:35:06 +08:00
} else {
2019-08-04 01:17:00 +08:00
if ( ! WaitForResponseTimeout ( CMD_LF_ACQ_RAW_ADC , & resp , 2500 ) ) {
2020-09-06 05:57:44 +08:00
PrintAndLogEx ( WARNING , " (lf_read) command execution time out " ) ;
2019-05-20 22:48:51 +08:00
return PM3_ETIMEOUT ;
2019-03-10 06:35:06 +08:00
}
}
2019-05-20 22:48:51 +08:00
2020-09-07 16:39:15 +08:00
// response is number of bits read
uint32_t size = ( resp . data . asDwords [ 0 ] / 8 ) ;
2020-09-06 05:57:44 +08:00
getSamples ( size , verbose ) ;
2019-05-20 22:48:51 +08:00
return PM3_SUCCESS ;
2017-07-30 15:17:48 +08:00
}
2019-03-10 18:20:22 +08:00
int CmdLFRead ( const char * Cmd ) {
2019-03-09 15:59:13 +08:00
2019-05-24 01:16:06 +08:00
if ( ! session . pm3_present ) return PM3_ENOTTY ;
2019-03-10 06:35:06 +08:00
bool errors = false ;
2020-01-08 05:05:01 +08:00
bool verbose = true ;
2020-09-16 08:38:28 +08:00
bool continuous = false ;
2019-03-10 06:35:06 +08:00
uint32_t samples = 0 ;
uint8_t cmdp = 0 ;
while ( param_getchar ( Cmd , cmdp ) ! = 0x00 & & ! errors ) {
switch ( tolower ( param_getchar ( Cmd , cmdp ) ) ) {
2019-03-10 07:00:59 +08:00
case ' h ' :
return usage_lf_read ( ) ;
2020-09-16 18:52:04 +08:00
case ' s ' :
2019-08-14 02:30:19 +08:00
samples = param_get32ex ( Cmd , cmdp + 1 , 0 , 10 ) ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
break ;
2020-09-16 18:52:04 +08:00
case ' q ' :
2020-01-08 05:05:01 +08:00
verbose = false ;
cmdp + + ;
break ;
2020-09-16 18:52:04 +08:00
case ' @ ' :
2020-09-16 08:38:28 +08:00
continuous = true ;
cmdp + + ;
break ;
2019-03-10 07:00:59 +08:00
default :
PrintAndLogEx ( WARNING , " Unknown parameter '%c' " , param_getchar ( Cmd , cmdp ) ) ;
errors = true ;
break ;
2019-03-10 06:35:06 +08:00
}
}
//Validations
if ( errors ) return usage_lf_read ( ) ;
2020-09-16 08:38:28 +08:00
if ( continuous ) {
PrintAndLogEx ( INFO , " Press " _GREEN_ ( " Enter " ) " to exit " ) ;
}
int ret = PM3_SUCCESS ;
do {
ret = lf_read ( verbose , samples ) ;
if ( kbd_enter_pressed ( ) ) {
break ;
}
} while ( continuous ) ;
return ret ;
2015-01-31 06:03:44 +08:00
}
2015-01-29 07:57:22 +08:00
2020-09-20 17:12:38 +08:00
int lf_sniff ( bool verbose , uint32_t samples ) {
2019-05-24 01:16:06 +08:00
if ( ! session . pm3_present ) return PM3_ENOTTY ;
2020-09-20 17:12:38 +08:00
struct p {
uint32_t samples : 31 ;
bool verbose : 1 ;
} PACKED ;
struct p payload ;
payload . verbose = verbose ;
payload . samples = samples ;
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2020-09-20 17:12:38 +08:00
SendCommandNG ( CMD_LF_SNIFF_RAW_ADC , ( uint8_t * ) & payload , sizeof ( payload ) ) ;
PacketResponseNG resp ;
if ( g_lf_threshold_set ) {
WaitForResponse ( CMD_LF_SNIFF_RAW_ADC , & resp ) ;
} else {
if ( ! WaitForResponseTimeout ( CMD_LF_SNIFF_RAW_ADC , & resp , 2500 ) ) {
PrintAndLogEx ( WARNING , " (lf_read) command execution time out " ) ;
return PM3_ETIMEOUT ;
}
}
// response is number of bits read
uint32_t size = ( resp . data . asDwords [ 0 ] / 8 ) ;
getSamples ( size , verbose ) ;
2019-05-24 01:16:06 +08:00
return PM3_SUCCESS ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}
2020-09-20 17:12:38 +08:00
int CmdLFSniff ( const char * Cmd ) {
if ( ! session . pm3_present ) return PM3_ENOTTY ;
bool errors = false ;
bool verbose = true ;
bool continuous = false ;
uint32_t samples = 0 ;
uint8_t cmdp = 0 ;
while ( param_getchar ( Cmd , cmdp ) ! = 0x00 & & ! errors ) {
switch ( tolower ( param_getchar ( Cmd , cmdp ) ) ) {
case ' h ' :
return usage_lf_sniff ( ) ;
case ' s ' :
samples = param_get32ex ( Cmd , cmdp + 1 , 0 , 10 ) ;
cmdp + = 2 ;
break ;
case ' q ' :
verbose = false ;
cmdp + + ;
break ;
case ' @ ' :
continuous = true ;
cmdp + + ;
break ;
default :
PrintAndLogEx ( WARNING , " Unknown parameter '%c' " , param_getchar ( Cmd , cmdp ) ) ;
errors = true ;
break ;
}
}
//Validations
if ( errors ) return usage_lf_sniff ( ) ;
if ( continuous ) {
PrintAndLogEx ( INFO , " Press " _GREEN_ ( " Enter " ) " to exit " ) ;
}
int ret = PM3_SUCCESS ;
do {
ret = lf_sniff ( verbose , samples ) ;
if ( kbd_enter_pressed ( ) ) {
break ;
}
} while ( continuous ) ;
return ret ;
}
2020-05-03 07:13:28 +08:00
static void ChkBitstream ( void ) {
2019-03-10 06:35:06 +08:00
// convert to bitstream if necessary
2019-03-10 07:00:59 +08:00
for ( int i = 0 ; i < ( int ) ( GraphTraceLen / 2 ) ; i + + ) {
2019-03-10 06:35:06 +08:00
if ( GraphBuffer [ i ] > 1 | | GraphBuffer [ i ] < 0 ) {
CmdGetBitStream ( " " ) ;
2019-06-08 03:40:33 +08:00
PrintAndLogEx ( INFO , " Converted to bitstream " ) ;
2019-03-10 06:35:06 +08:00
break ;
}
}
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}
2019-10-12 05:13:52 +08:00
2015-04-05 12:58:57 +08:00
//Attempt to simulate any wave in buffer (one bit per output sample)
// converts GraphBuffer to bitstream (based on zero crossings) if needed.
2019-03-10 18:20:22 +08:00
int CmdLFSim ( const char * Cmd ) {
2019-05-23 22:51:19 +08:00
2019-05-24 01:16:06 +08:00
if ( ! session . pm3_present ) return PM3_ENOTTY ;
2019-05-23 22:51:19 +08:00
// sanity check
2019-06-08 03:40:33 +08:00
if ( GraphTraceLen < 20 ) {
2019-05-23 22:51:19 +08:00
PrintAndLogEx ( ERR , " No data in Graphbuffer " ) ;
return PM3_ENODATA ;
}
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
2019-05-24 01:16:06 +08:00
uint8_t cmdp = tolower ( param_getchar ( Cmd , 0 ) ) ;
if ( cmdp = = ' h ' ) return usage_lf_sim ( ) ;
2019-05-22 20:32:30 +08:00
uint16_t gap = param_get32ex ( Cmd , 0 , 0 , 10 ) & 0xFFFF ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
2019-03-10 06:35:06 +08:00
// convert to bitstream if necessary
2019-05-22 20:32:30 +08:00
ChkBitstream ( ) ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
2019-10-06 05:56:19 +08:00
PrintAndLogEx ( DEBUG , " DEBUG: Uploading %zu bytes " , GraphTraceLen ) ;
2019-05-22 20:32:30 +08:00
2020-04-30 02:33:29 +08:00
PacketResponseNG resp ;
2019-05-22 20:32:30 +08:00
struct pupload {
uint8_t flag ;
uint16_t offset ;
uint8_t data [ PM3_CMD_DATA_SIZE - 3 ] ;
2019-05-23 18:12:20 +08:00
} PACKED payload_up ;
2019-05-22 20:32:30 +08:00
2019-06-08 03:40:33 +08:00
// flag =
// b0 0
2019-05-22 20:32:30 +08:00
// 1 clear bigbuff
2019-05-23 22:51:19 +08:00
payload_up . flag = 0x1 ;
2019-03-09 15:59:13 +08:00
2019-04-30 16:10:25 +08:00
// fast push mode
conn . block_after_ACK = true ;
2019-05-01 07:38:52 +08:00
2019-03-10 06:35:06 +08:00
//can send only 512 bits at a time (1 byte sent per bit...)
2019-05-22 20:32:30 +08:00
for ( uint16_t i = 0 ; i < GraphTraceLen ; i + = PM3_CMD_DATA_SIZE - 3 ) {
size_t len = MIN ( ( GraphTraceLen - i ) , PM3_CMD_DATA_SIZE - 3 ) ;
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2019-05-22 20:32:30 +08:00
payload_up . offset = i ;
2019-06-08 03:40:33 +08:00
for ( uint16_t j = 0 ; j < len ; j + + )
payload_up . data [ j ] = GraphBuffer [ i + j ] ;
2019-08-04 01:17:00 +08:00
SendCommandNG ( CMD_LF_UPLOAD_SIM_SAMPLES , ( uint8_t * ) & payload_up , sizeof ( struct pupload ) ) ;
2020-04-30 02:33:29 +08:00
WaitForResponse ( CMD_LF_UPLOAD_SIM_SAMPLES , & resp ) ;
if ( resp . status ! = PM3_SUCCESS ) {
PrintAndLogEx ( INFO , " Bigbuf is full. " ) ;
break ;
}
2020-08-29 20:52:11 +08:00
PrintAndLogEx ( NORMAL , " . " NOLF ) ;
2019-05-22 20:32:30 +08:00
payload_up . flag = 0 ;
2019-03-10 06:35:06 +08:00
}
2019-04-30 16:10:25 +08:00
2019-05-09 04:45:20 +08:00
// Disable fast mode before last command
2019-04-30 16:10:25 +08:00
conn . block_after_ACK = false ;
2020-08-29 20:52:11 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2019-05-23 18:12:20 +08:00
PrintAndLogEx ( INFO , " Simulating " ) ;
2019-05-22 20:32:30 +08:00
struct p {
uint16_t len ;
uint16_t gap ;
2019-05-23 22:51:19 +08:00
} PACKED payload ;
2019-05-22 20:32:30 +08:00
payload . len = GraphTraceLen ;
2019-06-08 03:40:33 +08:00
payload . gap = gap ;
2016-10-20 07:16:32 +08:00
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2019-08-04 01:17:00 +08:00
SendCommandNG ( CMD_LF_SIMULATE , ( uint8_t * ) & payload , sizeof ( payload ) ) ;
2019-05-22 20:32:30 +08:00
2019-08-04 01:17:00 +08:00
WaitForResponse ( CMD_LF_SIMULATE , & resp ) ;
2019-05-22 20:32:30 +08:00
PrintAndLogEx ( INFO , " Done " ) ;
2019-05-10 02:20:54 +08:00
if ( resp . status ! = PM3_EOPABORTED )
2019-05-09 06:08:59 +08:00
return resp . status ;
return PM3_SUCCESS ;
2015-02-22 10:36:02 +08:00
}
2015-03-08 12:31:23 +08:00
2019-10-12 05:13:52 +08:00
// sim fsk data given clock, fcHigh, fcLow, invert
2015-02-20 10:35:34 +08:00
// - allow pull data from DemodBuffer
2019-03-10 18:20:22 +08:00
int CmdLFfskSim ( const char * Cmd ) {
2019-03-10 06:35:06 +08:00
//might be able to autodetect FCs and clock from Graphbuffer if using demod buffer
// otherwise will need FChigh, FClow, Clock, and bitstream
uint8_t fcHigh = 0 , fcLow = 0 , clk = 0 ;
bool errors = false , separator = false ;
char hexData [ 64 ] = { 0x00 } ; // store entered hex data
uint8_t data [ 255 ] = { 0x00 } ;
int dataLen = 0 ;
uint8_t cmdp = 0 ;
while ( param_getchar ( Cmd , cmdp ) ! = 0x00 & & ! errors ) {
2019-03-10 07:00:59 +08:00
switch ( param_getchar ( Cmd , cmdp ) ) {
2019-03-10 06:35:06 +08:00
case ' h ' :
return usage_lf_simfsk ( ) ;
case ' c ' :
2019-03-10 07:00:59 +08:00
errors | = param_getdec ( Cmd , cmdp + 1 , & clk ) ;
2019-03-10 06:35:06 +08:00
cmdp + = 2 ;
break ;
case ' H ' :
2019-03-10 07:00:59 +08:00
errors | = param_getdec ( Cmd , cmdp + 1 , & fcHigh ) ;
2019-03-10 06:35:06 +08:00
cmdp + = 2 ;
break ;
case ' L ' :
2019-03-10 07:00:59 +08:00
errors | = param_getdec ( Cmd , cmdp + 1 , & fcLow ) ;
2019-03-10 06:35:06 +08:00
cmdp + = 2 ;
break ;
case ' s ' :
2019-03-19 04:45:06 +08:00
separator = true ;
2019-03-10 06:35:06 +08:00
cmdp + + ;
break ;
case ' d ' :
2019-03-10 07:00:59 +08:00
dataLen = param_getstr ( Cmd , cmdp + 1 , hexData , sizeof ( hexData ) ) ;
2019-03-10 06:35:06 +08:00
if ( dataLen = = 0 )
errors = true ;
else
dataLen = hextobinarray ( ( char * ) data , hexData ) ;
if ( dataLen = = 0 ) errors = true ;
2019-07-14 06:35:18 +08:00
if ( errors ) PrintAndLogEx ( ERR , " Error getting hex data " ) ;
2019-03-10 06:35:06 +08:00
cmdp + = 2 ;
break ;
default :
PrintAndLogEx ( WARNING , " Unknown parameter '%c' " , param_getchar ( Cmd , cmdp ) ) ;
errors = true ;
break ;
}
}
// No args
if ( cmdp = = 0 & & DemodBufferLen = = 0 ) return usage_lf_simfsk ( ) ;
//Validations
if ( errors ) return usage_lf_simfsk ( ) ;
int firstClockEdge = 0 ;
2019-03-10 07:00:59 +08:00
if ( dataLen = = 0 ) { //using DemodBuffer
if ( clk = = 0 | | fcHigh = = 0 | | fcLow = = 0 ) { //manual settings must set them all
2019-03-10 06:35:06 +08:00
uint8_t ans = fskClocks ( & fcHigh , & fcLow , & clk , & firstClockEdge ) ;
2019-03-10 07:00:59 +08:00
if ( ans = = 0 ) {
2019-03-10 06:35:06 +08:00
if ( ! fcHigh ) fcHigh = 10 ;
if ( ! fcLow ) fcLow = 8 ;
if ( ! clk ) clk = 50 ;
}
}
} else {
2019-04-07 03:46:00 +08:00
setDemodBuff ( data , dataLen , 0 ) ;
2019-03-10 06:35:06 +08:00
}
//default if not found
if ( clk = = 0 ) clk = 50 ;
if ( fcHigh = = 0 ) fcHigh = 10 ;
if ( fcLow = = 0 ) fcLow = 8 ;
size_t size = DemodBufferLen ;
2019-05-24 05:07:12 +08:00
if ( size > ( PM3_CMD_DATA_SIZE - sizeof ( lf_fsksim_t ) ) ) {
2019-12-14 19:57:25 +08:00
PrintAndLogEx ( WARNING , " DemodBuffer too long for current implementation - length: %zu - max: %zu " , size , PM3_CMD_DATA_SIZE - sizeof ( lf_fsksim_t ) ) ;
2019-05-24 05:07:12 +08:00
size = PM3_CMD_DATA_SIZE - sizeof ( lf_fsksim_t ) ;
2019-03-10 06:35:06 +08:00
}
2019-05-24 01:16:06 +08:00
2019-05-24 05:07:12 +08:00
lf_fsksim_t * payload = calloc ( 1 , sizeof ( lf_fsksim_t ) + size ) ;
payload - > fchigh = fcHigh ;
payload - > fclow = fcLow ;
payload - > separator = separator ;
payload - > clock = clk ;
memcpy ( payload - > data , DemodBuffer , size ) ;
2019-05-24 01:16:06 +08:00
PrintAndLogEx ( INFO , " Simulating " ) ;
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2019-08-04 01:17:00 +08:00
SendCommandNG ( CMD_LF_FSK_SIMULATE , ( uint8_t * ) payload , sizeof ( lf_fsksim_t ) + size ) ;
2019-05-24 06:32:17 +08:00
free ( payload ) ;
2019-03-10 06:35:06 +08:00
setClockGrid ( clk , 0 ) ;
2019-05-09 06:08:59 +08:00
PacketResponseNG resp ;
2019-08-04 01:17:00 +08:00
WaitForResponse ( CMD_LF_FSK_SIMULATE , & resp ) ;
2019-05-24 01:16:06 +08:00
PrintAndLogEx ( INFO , " Done " ) ;
2019-05-10 02:20:54 +08:00
if ( resp . status ! = PM3_EOPABORTED )
2019-05-09 06:08:59 +08:00
return resp . status ;
return PM3_SUCCESS ;
2015-02-20 10:35:34 +08:00
}
2019-10-12 05:13:52 +08:00
// sim ask data given clock, invert, manchester or raw, separator
2015-02-20 10:35:34 +08:00
// - allow pull data from DemodBuffer
2019-03-10 18:20:22 +08:00
int CmdLFaskSim ( const char * Cmd ) {
2019-03-10 06:35:06 +08:00
// autodetect clock from Graphbuffer if using demod buffer
// needs clock, invert, manchester/raw as m or r, separator as s, and bitstream
uint8_t encoding = 1 , separator = 0 , clk = 0 , invert = 0 ;
bool errors = false ;
char hexData [ 64 ] = { 0x00 } ;
uint8_t data [ 255 ] = { 0x00 } ; // store entered hex data
int dataLen = 0 ;
uint8_t cmdp = 0 ;
2019-03-10 07:00:59 +08:00
while ( param_getchar ( Cmd , cmdp ) ! = 0x00 & & ! errors ) {
2019-03-10 06:35:06 +08:00
switch ( tolower ( param_getchar ( Cmd , cmdp ) ) ) {
2019-03-10 07:00:59 +08:00
case ' h ' :
return usage_lf_simask ( ) ;
2019-03-10 06:35:06 +08:00
case ' i ' :
invert = 1 ;
cmdp + + ;
break ;
case ' c ' :
2019-03-10 07:00:59 +08:00
errors | = param_getdec ( Cmd , cmdp + 1 , & clk ) ;
2019-03-10 06:35:06 +08:00
cmdp + = 2 ;
break ;
case ' b ' :
encoding = 2 ; //biphase
cmdp + + ;
break ;
case ' m ' :
encoding = 1 ; //manchester
cmdp + + ;
break ;
case ' r ' :
encoding = 0 ; //raw
cmdp + + ;
break ;
case ' s ' :
separator = 1 ;
cmdp + + ;
break ;
case ' d ' :
2019-03-10 07:00:59 +08:00
dataLen = param_getstr ( Cmd , cmdp + 1 , hexData , sizeof ( hexData ) ) ;
2019-03-10 06:35:06 +08:00
if ( dataLen = = 0 )
errors = true ;
else
dataLen = hextobinarray ( ( char * ) data , hexData ) ;
if ( dataLen = = 0 ) errors = true ;
2019-07-14 06:35:18 +08:00
if ( errors ) PrintAndLogEx ( ERR , " Error getting hex data, datalen: %d " , dataLen ) ;
2019-03-10 06:35:06 +08:00
cmdp + = 2 ;
break ;
default :
PrintAndLogEx ( WARNING , " Unknown parameter '%c' " , param_getchar ( Cmd , cmdp ) ) ;
errors = true ;
break ;
}
}
// No args
if ( cmdp = = 0 & & DemodBufferLen = = 0 ) return usage_lf_simask ( ) ;
//Validations
if ( errors ) return usage_lf_simask ( ) ;
2019-03-10 07:00:59 +08:00
if ( dataLen = = 0 ) { //using DemodBuffer
2019-03-10 06:35:06 +08:00
if ( clk = = 0 )
clk = GetAskClock ( " 0 " , false ) ;
} else {
2019-04-07 03:46:00 +08:00
setDemodBuff ( data , dataLen , 0 ) ;
2019-03-10 06:35:06 +08:00
}
if ( clk = = 0 ) clk = 64 ;
if ( encoding = = 0 ) clk / = 2 ; //askraw needs to double the clock speed
size_t size = DemodBufferLen ;
2019-05-24 19:06:08 +08:00
if ( size > ( PM3_CMD_DATA_SIZE - sizeof ( lf_asksim_t ) ) ) {
2019-12-14 19:57:25 +08:00
PrintAndLogEx ( WARNING , " DemodBuffer too long for current implementation - length: %zu - max: %zu " , size , PM3_CMD_DATA_SIZE - sizeof ( lf_asksim_t ) ) ;
2019-05-24 19:06:08 +08:00
size = PM3_CMD_DATA_SIZE - sizeof ( lf_asksim_t ) ;
2019-03-10 06:35:06 +08:00
}
2019-05-24 19:06:08 +08:00
lf_asksim_t * payload = calloc ( 1 , sizeof ( lf_asksim_t ) + size ) ;
payload - > encoding = encoding ;
payload - > invert = invert ;
payload - > separator = separator ;
payload - > clock = clk ;
memcpy ( payload - > data , DemodBuffer , size ) ;
PrintAndLogEx ( INFO , " Simulating " ) ;
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2019-08-04 01:17:00 +08:00
SendCommandNG ( CMD_LF_ASK_SIMULATE , ( uint8_t * ) payload , sizeof ( lf_asksim_t ) + size ) ;
2019-05-24 19:06:08 +08:00
free ( payload ) ;
2019-05-09 06:08:59 +08:00
PacketResponseNG resp ;
2019-08-04 01:17:00 +08:00
WaitForResponse ( CMD_LF_ASK_SIMULATE , & resp ) ;
2019-05-24 19:06:08 +08:00
PrintAndLogEx ( INFO , " Done " ) ;
2019-05-10 02:20:54 +08:00
if ( resp . status ! = PM3_EOPABORTED )
2019-05-09 06:08:59 +08:00
return resp . status ;
return PM3_SUCCESS ;
2015-02-20 10:35:34 +08:00
}
2019-10-12 05:13:52 +08:00
// sim psk data given carrier, clock, invert
2015-02-22 10:36:02 +08:00
// - allow pull data from DemodBuffer or parameters
2019-03-10 18:20:22 +08:00
int CmdLFpskSim ( const char * Cmd ) {
2019-03-10 06:35:06 +08:00
//might be able to autodetect FC and clock from Graphbuffer if using demod buffer
//will need carrier, Clock, and bitstream
2019-03-10 07:00:59 +08:00
uint8_t carrier = 0 , clk = 0 ;
uint8_t invert = 0 ;
2019-03-10 06:35:06 +08:00
bool errors = false ;
char hexData [ 64 ] = { 0x00 } ; // store entered hex data
uint8_t data [ 255 ] = { 0x00 } ;
int dataLen = 0 ;
uint8_t cmdp = 0 ;
uint8_t pskType = 1 ;
while ( param_getchar ( Cmd , cmdp ) ! = 0x00 & & ! errors ) {
switch ( tolower ( param_getchar ( Cmd , cmdp ) ) ) {
case ' h ' :
return usage_lf_simpsk ( ) ;
case ' i ' :
invert = 1 ;
cmdp + + ;
break ;
case ' c ' :
2019-03-10 07:00:59 +08:00
errors | = param_getdec ( Cmd , cmdp + 1 , & clk ) ;
cmdp + = 2 ;
2019-03-10 06:35:06 +08:00
break ;
case ' r ' :
2019-03-10 07:00:59 +08:00
errors | = param_getdec ( Cmd , cmdp + 1 , & carrier ) ;
2019-03-10 06:35:06 +08:00
cmdp + = 2 ;
break ;
case ' 1 ' :
pskType = 1 ;
cmdp + + ;
break ;
case ' 2 ' :
pskType = 2 ;
cmdp + + ;
break ;
case ' 3 ' :
pskType = 3 ;
cmdp + + ;
break ;
case ' d ' :
2019-03-10 07:00:59 +08:00
dataLen = param_getstr ( Cmd , cmdp + 1 , hexData , sizeof ( hexData ) ) ;
2019-03-10 06:35:06 +08:00
if ( dataLen = = 0 )
errors = true ;
else
dataLen = hextobinarray ( ( char * ) data , hexData ) ;
if ( dataLen = = 0 ) errors = true ;
2019-07-14 06:35:18 +08:00
if ( errors ) PrintAndLogEx ( ERR , " Error getting hex data " ) ;
2019-03-10 07:00:59 +08:00
cmdp + = 2 ;
2019-03-10 06:35:06 +08:00
break ;
default :
PrintAndLogEx ( WARNING , " Unknown parameter '%c' " , param_getchar ( Cmd , cmdp ) ) ;
errors = true ;
break ;
2019-03-10 07:00:59 +08:00
}
2019-03-10 06:35:06 +08:00
}
// No args
if ( cmdp = = 0 & & DemodBufferLen = = 0 )
errors = true ;
//Validations
if ( errors ) return usage_lf_simpsk ( ) ;
2019-03-10 07:00:59 +08:00
if ( dataLen = = 0 ) { //using DemodBuffer
2019-12-14 19:57:25 +08:00
PrintAndLogEx ( INFO , " Getting Clocks " ) ;
2019-03-10 06:35:06 +08:00
2019-03-10 07:00:59 +08:00
if ( clk = = 0 ) clk = GetPskClock ( " " , false ) ;
2019-12-14 19:57:25 +08:00
PrintAndLogEx ( INFO , " clk: %d " , clk ) ;
2019-03-10 06:35:06 +08:00
2020-10-09 23:02:48 +08:00
if ( ! carrier ) carrier = GetPskCarrier ( false ) ;
2019-12-14 19:57:25 +08:00
PrintAndLogEx ( INFO , " carrier: %d " , carrier ) ;
2019-03-10 06:35:06 +08:00
} else {
2019-04-07 03:46:00 +08:00
setDemodBuff ( data , dataLen , 0 ) ;
2019-03-10 06:35:06 +08:00
}
2019-03-18 23:59:21 +08:00
if ( clk = = 0 ) clk = 32 ;
2019-03-10 06:35:06 +08:00
2019-03-10 07:00:59 +08:00
if ( carrier ! = 2 & & carrier ! = 4 & & carrier ! = 8 )
2019-03-10 06:35:06 +08:00
carrier = 2 ;
2019-03-10 07:00:59 +08:00
if ( pskType ! = 1 ) {
if ( pskType = = 2 ) {
2019-03-10 06:35:06 +08:00
//need to convert psk2 to psk1 data before sim
psk2TOpsk1 ( DemodBuffer , DemodBufferLen ) ;
} else {
2019-12-14 19:57:25 +08:00
PrintAndLogEx ( WARNING , " Sorry, PSK3 not yet available " ) ;
2019-03-10 06:35:06 +08:00
}
}
size_t size = DemodBufferLen ;
2019-05-24 21:11:30 +08:00
if ( size > ( PM3_CMD_DATA_SIZE - sizeof ( lf_psksim_t ) ) ) {
2019-12-14 19:57:25 +08:00
PrintAndLogEx ( WARNING , " DemodBuffer too long for current implementation - length: %zu - max: %zu " , size , PM3_CMD_DATA_SIZE - sizeof ( lf_psksim_t ) ) ;
2019-05-24 21:11:30 +08:00
size = PM3_CMD_DATA_SIZE - sizeof ( lf_psksim_t ) ;
2019-03-10 06:35:06 +08:00
}
2019-05-24 21:11:30 +08:00
lf_psksim_t * payload = calloc ( 1 , sizeof ( lf_psksim_t ) + size ) ;
payload - > carrier = carrier ;
payload - > invert = invert ;
payload - > clock = clk ;
memcpy ( payload - > data , DemodBuffer , size ) ;
PrintAndLogEx ( INFO , " Simulating " ) ;
2019-05-24 19:22:50 +08:00
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2019-08-04 01:17:00 +08:00
SendCommandNG ( CMD_LF_PSK_SIMULATE , ( uint8_t * ) payload , sizeof ( lf_psksim_t ) + size ) ;
2019-05-24 21:11:30 +08:00
free ( payload ) ;
2019-05-09 06:08:59 +08:00
PacketResponseNG resp ;
2019-08-04 01:17:00 +08:00
WaitForResponse ( CMD_LF_PSK_SIMULATE , & resp ) ;
2019-05-24 19:22:50 +08:00
PrintAndLogEx ( INFO , " Done " ) ;
2019-05-10 02:20:54 +08:00
if ( resp . status ! = PM3_EOPABORTED )
2019-05-09 06:08:59 +08:00
return resp . status ;
return PM3_SUCCESS ;
2015-02-22 10:36:02 +08:00
}
2015-02-20 10:35:34 +08:00
2019-03-10 18:20:22 +08:00
int CmdLFSimBidir ( const char * Cmd ) {
2019-04-10 18:23:40 +08:00
( void ) Cmd ; // Cmd is not used so far
2019-03-10 06:35:06 +08:00
// Set ADC to twice the carrier for a slight supersampling
// HACK: not implemented in ARMSRC.
PrintAndLogEx ( INFO , " Not implemented yet. " ) ;
2019-10-01 20:30:30 +08:00
// SendCommandMIX(CMD_LF_SIMULATE_BIDIR, 47, 384, 0, NULL, 0);
2019-05-24 01:16:06 +08:00
return PM3_SUCCESS ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}
2019-11-19 19:17:08 +08:00
// ICEMAN, Verichip is Animal tag. Tested against correct reader
/*
2019-03-10 18:20:22 +08:00
int CmdVchDemod ( const char * Cmd ) {
2019-10-01 20:30:30 +08:00
if ( GraphTraceLen < 4096 ) {
PrintAndLogEx ( DEBUG , " debug; VchDemod - too few samples " ) ;
return PM3_EINVARG ;
}
2019-03-10 06:35:06 +08:00
// Is this the entire sync pattern, or does this also include some
// data bits that happen to be the same everywhere? That would be
// lovely to know.
static const int SyncPattern [ ] = {
1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ,
1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 ,
1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ,
1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 ,
1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ,
1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 ,
1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ,
1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 ,
1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ,
1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 ,
} ;
2019-11-19 19:17:08 +08:00
// iceman, using correlate as preamble detect seems way better than our current memcompare
2019-03-10 06:35:06 +08:00
// So first, we correlate for the sync pattern, and mark that.
int bestCorrel = 0 , bestPos = 0 ;
int i , j , sum = 0 ;
// It does us no good to find the sync pattern, with fewer than 2048 samples after it.
for ( i = 0 ; i < ( GraphTraceLen - 2048 ) ; i + + ) {
for ( j = 0 ; j < ARRAYLEN ( SyncPattern ) ; j + + ) {
2019-03-10 07:00:59 +08:00
sum + = GraphBuffer [ i + j ] * SyncPattern [ j ] ;
2019-03-10 06:35:06 +08:00
}
if ( sum > bestCorrel ) {
bestCorrel = sum ;
bestPos = i ;
}
}
PrintAndLogEx ( NORMAL , " best sync at %d [metric %d] " , bestPos , bestCorrel ) ;
char bits [ 257 ] ;
bits [ 256 ] = ' \0 ' ;
int worst = INT_MAX , worstPos = 0 ;
for ( i = 0 ; i < 2048 ; i + = 8 ) {
sum = 0 ;
for ( j = 0 ; j < 8 ; j + + )
2019-03-10 07:00:59 +08:00
sum + = GraphBuffer [ bestPos + i + j ] ;
2019-03-10 06:35:06 +08:00
if ( sum < 0 )
2019-03-10 07:00:59 +08:00
bits [ i / 8 ] = ' . ' ;
2019-03-10 06:35:06 +08:00
else
2019-03-10 07:00:59 +08:00
bits [ i / 8 ] = ' 1 ' ;
2019-03-10 06:35:06 +08:00
2019-03-10 07:00:59 +08:00
if ( abs ( sum ) < worst ) {
2019-03-10 06:35:06 +08:00
worst = abs ( sum ) ;
worstPos = i ;
}
}
PrintAndLogEx ( NORMAL , " bits: " ) ;
PrintAndLogEx ( NORMAL , " %s " , bits ) ;
PrintAndLogEx ( NORMAL , " worst metric: %d at pos %d " , worst , worstPos ) ;
// clone
2019-03-10 07:00:59 +08:00
if ( strcmp ( Cmd , " clone " ) = = 0 ) {
2019-03-10 06:35:06 +08:00
GraphTraceLen = 0 ;
char * s ;
2019-03-10 07:00:59 +08:00
for ( s = bits ; * s ; s + + ) {
for ( j = 0 ; j < 16 ; j + + ) {
GraphBuffer [ GraphTraceLen + + ] = ( * s = = ' 1 ' ) ? 1 : 0 ;
2019-03-10 06:35:06 +08:00
}
2019-03-10 07:00:59 +08:00
}
2019-03-10 06:35:06 +08:00
RepaintGraphWindow ( ) ;
}
2019-05-24 01:16:06 +08:00
return PM3_SUCCESS ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}
2019-11-19 19:17:08 +08:00
*/
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
2019-04-14 03:54:04 +08:00
static bool CheckChipType ( bool getDeviceData ) {
2017-02-27 04:32:51 +08:00
2019-03-10 06:35:06 +08:00
bool retval = false ;
if ( ! getDeviceData ) return retval ;
save_restoreGB ( GRAPH_SAVE ) ;
save_restoreDB ( GRAPH_SAVE ) ;
//check for em4x05/em4x69 chips first
uint32_t word = 0 ;
2020-10-21 03:59:33 +08:00
if ( em4x05_isblock0 ( & word ) ) {
2020-09-06 05:57:44 +08:00
PrintAndLogEx ( SUCCESS , " Chipset detection: " _GREEN_ ( " EM4x05 / EM4x69 " ) ) ;
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( HINT , " Hint: try " _YELLOW_ ( " `lf em 4x05` " ) " commands " ) ;
2019-03-10 06:35:06 +08:00
retval = true ;
goto out ;
}
2019-07-13 06:38:30 +08:00
2019-03-10 06:35:06 +08:00
//check for t55xx chip...
if ( tryDetectP1 ( true ) ) {
2019-10-10 13:56:39 +08:00
PrintAndLogEx ( SUCCESS , " Chipset detection: " _GREEN_ ( " T55xx " ) ) ;
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( HINT , " Hint: try " _YELLOW_ ( " `lf t55xx` " ) " commands " ) ;
2019-03-10 06:35:06 +08:00
retval = true ;
2020-09-11 02:49:23 +08:00
goto out ;
2019-03-10 06:35:06 +08:00
}
2020-08-13 18:25:04 +08:00
2020-06-30 23:43:47 +08:00
// check for em4x50 chips
if ( detect_4x50_block ( ) ) {
PrintAndLogEx ( SUCCESS , " Chipset detection: " _GREEN_ ( " EM4x50 " ) ) ;
PrintAndLogEx ( HINT , " Hint: try " _YELLOW_ ( " `lf em 4x50` " ) " commands " ) ;
2020-12-06 06:47:03 +08:00
retval = true ;
goto out ;
}
// check for em4x70 chips
if ( detect_4x70_block ( ) ) {
PrintAndLogEx ( SUCCESS , " Chipset detection: " _GREEN_ ( " EM4x70 " ) ) ;
PrintAndLogEx ( HINT , " Hint: try " _YELLOW_ ( " `lf em 4x70` " ) " commands " ) ;
2020-06-30 23:43:47 +08:00
retval = true ;
goto out ;
}
2019-03-12 06:12:31 +08:00
2020-09-06 05:57:44 +08:00
PrintAndLogEx ( NORMAL , " Couldn't identify a chipset " ) ;
2019-03-10 06:35:06 +08:00
out :
save_restoreGB ( GRAPH_RESTORE ) ;
save_restoreDB ( GRAPH_RESTORE ) ;
return retval ;
2017-02-27 04:32:51 +08:00
}
2019-03-10 18:20:22 +08:00
int CmdLFfind ( const char * Cmd ) {
2019-11-19 19:17:08 +08:00
int retval = PM3_SUCCESS ;
2019-03-10 06:35:06 +08:00
int ans = 0 ;
size_t minLength = 2000 ;
char cmdp = tolower ( param_getchar ( Cmd , 0 ) ) ;
char testRaw = param_getchar ( Cmd , 1 ) ;
if ( strlen ( Cmd ) > 3 | | cmdp = = ' h ' ) return usage_lf_find ( ) ;
if ( cmdp = = ' u ' ) testRaw = ' u ' ;
2019-05-01 05:52:40 +08:00
bool isOnline = ( session . pm3_present & & ( cmdp ! = ' 1 ' ) ) ;
2019-03-10 06:35:06 +08:00
if ( isOnline )
2020-01-08 05:05:01 +08:00
lf_read ( false , 30000 ) ;
2019-03-10 06:35:06 +08:00
if ( GraphTraceLen < minLength ) {
PrintAndLogEx ( FAILED , " Data in Graphbuffer was too small. " ) ;
2019-05-22 21:40:58 +08:00
return PM3_ESOFT ;
2019-03-10 06:35:06 +08:00
}
2020-08-28 13:59:25 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( INFO , " NOTE: some demods output possible binary " ) ;
PrintAndLogEx ( INFO , " if it finds something that looks like a tag " ) ;
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( INFO , " False Positives " _YELLOW_ ( " ARE " ) " possible " ) ;
2019-03-11 21:55:02 +08:00
PrintAndLogEx ( INFO , " " ) ;
2019-10-10 13:56:39 +08:00
PrintAndLogEx ( INFO , " Checking for known tags... " ) ;
PrintAndLogEx ( INFO , " " ) ;
2019-03-10 06:35:06 +08:00
// only run these tests if device is online
if ( isOnline ) {
2020-01-21 22:22:36 +08:00
if ( IfPm3Hitag ( ) ) {
if ( readHitagUid ( ) ) {
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Hitag " ) " found! " ) ;
2020-01-21 22:22:36 +08:00
return PM3_SUCCESS ;
}
}
2020-06-29 03:41:21 +08:00
if ( IfPm3EM4x50 ( ) ) {
2020-06-30 23:43:47 +08:00
if ( read_em4x50_uid ( ) = = PM3_SUCCESS ) {
2020-06-29 03:41:21 +08:00
PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " EM4x50 ID " ) " found! " ) ;
return PM3_SUCCESS ;
}
}
2019-03-10 06:35:06 +08:00
// only run if graphbuffer is just noise as it should be for hitag
// The improved noise detection will find Cotag.
if ( getSignalProperties ( ) - > isnoise ) {
2020-08-28 13:59:25 +08:00
PrintAndLogEx ( INPLACE , " Searching for MOTOROLA tag... " ) ;
2019-10-12 05:13:52 +08:00
if ( readMotorolaUid ( ) ) {
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Motorola FlexPass ID " ) " found! " ) ;
2019-10-13 06:48:26 +08:00
return PM3_SUCCESS ;
2019-10-12 05:13:52 +08:00
}
2020-12-02 00:06:49 +08:00
PrintAndLogEx ( INPLACE , " Searching for COTAG tag... " ) ;
2019-10-12 05:13:52 +08:00
if ( readCOTAGUid ( ) ) {
2020-04-22 08:22:55 +08:00
PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " COTAG ID " ) " found! " ) ;
2019-10-13 06:48:26 +08:00
return PM3_SUCCESS ;
2019-05-02 05:26:06 +08:00
}
2019-03-10 06:35:06 +08:00
2020-08-28 13:59:25 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2019-10-10 13:56:39 +08:00
PrintAndLogEx ( FAILED , _RED_ ( " No data found! " ) ) ;
PrintAndLogEx ( INFO , " Signal looks like noise. Maybe not an LF tag? " ) ;
2020-08-28 13:59:25 +08:00
PrintAndLogEx ( NORMAL , " " ) ;
2019-05-22 21:40:58 +08:00
return PM3_ESOFT ;
2019-03-10 06:35:06 +08:00
}
}
2020-09-28 17:50:20 +08:00
if ( demodVisa2k ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Visa2000 ID " ) " found! " ) ; goto out ; }
2020-10-12 18:27:00 +08:00
if ( demodDestron ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " FDX-A FECAVA Destron ID " ) " found! " ) ; goto out ; } // to do before HID
2020-09-28 17:50:20 +08:00
if ( demodHID ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " HID Prox ID " ) " found! " ) ; goto out ; }
if ( demodAWID ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " AWID ID " ) " found! " ) ; goto out ; }
if ( demodIOProx ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " IO Prox ID " ) " found! " ) ; goto out ; }
if ( demodParadox ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Paradox ID " ) " found! " ) ; goto out ; }
if ( demodNexWatch ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " NexWatch ID " ) " found! " ) ; goto out ; }
if ( demodIndala ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Indala ID " ) " found! " ) ; goto out ; }
if ( demodEM410x ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " EM410x ID " ) " found! " ) ; goto out ; }
2020-10-12 04:38:52 +08:00
if ( demodFDXB ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " FDX-B ID " ) " found! " ) ; goto out ; }
2020-09-28 17:50:20 +08:00
if ( demodGuard ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Guardall G-Prox II ID " ) " found! " ) ; goto out ; }
if ( demodIdteck ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Idteck ID " ) " found! " ) ; goto out ; }
if ( demodJablotron ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Jablotron ID " ) " found! " ) ; goto out ; }
if ( demodNedap ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " NEDAP ID " ) " found! " ) ; goto out ; }
if ( demodNoralsy ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Noralsy ID " ) " found! " ) ; goto out ; }
if ( demodKeri ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " KERI ID " ) " found! " ) ; goto out ; }
if ( demodPac ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " PAC/Stanley ID " ) " found! " ) ; goto out ; }
if ( demodPresco ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Presco ID " ) " found! " ) ; goto out ; }
if ( demodPyramid ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Pyramid ID " ) " found! " ) ; goto out ; }
if ( demodSecurakey ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Securakey ID " ) " found! " ) ; goto out ; }
if ( demodViking ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " Viking ID " ) " found! " ) ; goto out ; }
if ( demodGallagher ( true ) = = PM3_SUCCESS ) { PrintAndLogEx ( SUCCESS , " \n Valid " _GREEN_ ( " GALLAGHER ID " ) " found! " ) ; goto out ; }
2020-08-28 13:59:25 +08:00
// if (demodTI() == PM3_SUCCESS) { PrintAndLogEx(SUCCESS, "\nValid " _GREEN_("Texas Instrument ID") " found!"); goto out;}
// if (demodFermax() == PM3_SUCCESS) { PrintAndLogEx(SUCCESS, "\nValid " _GREEN_("Fermax ID") " found!"); goto out;}
2019-03-11 21:55:02 +08:00
2019-05-09 07:07:34 +08:00
PrintAndLogEx ( FAILED , _RED_ ( " No known 125/134 kHz tags found! " ) ) ;
2019-03-10 06:35:06 +08:00
2019-03-10 07:00:59 +08:00
if ( testRaw = = ' u ' ) {
2019-03-10 06:35:06 +08:00
//test unknown tag formats (raw mode)
2019-03-11 21:55:02 +08:00
PrintAndLogEx ( INFO , " \n Checking for unknown tags: \n " ) ;
ans = AutoCorrelate ( GraphBuffer , GraphBuffer , GraphTraceLen , 8000 , false , false ) ;
2019-03-10 06:35:06 +08:00
if ( ans > 0 ) {
2019-03-11 21:55:02 +08:00
PrintAndLogEx ( INFO , " Possible auto correlation of %d repeating samples " , ans ) ;
2019-03-10 06:35:06 +08:00
2019-03-10 07:00:59 +08:00
if ( ans % 8 = = 0 )
2019-03-10 06:35:06 +08:00
PrintAndLogEx ( INFO , " Possible %d bytes " , ( ans / 8 ) ) ;
}
2019-03-10 07:00:59 +08:00
//fsk
if ( GetFskClock ( " " , false ) ) {
2020-09-28 17:50:20 +08:00
if ( FSKrawDemod ( 0 , 0 , 0 , 0 , true ) = = PM3_SUCCESS ) {
2019-03-11 21:55:02 +08:00
PrintAndLogEx ( NORMAL , " \n Unknown FSK Modulated Tag found! " ) ;
2019-03-10 07:00:59 +08:00
goto out ;
2019-03-10 06:35:06 +08:00
}
}
bool st = true ;
2020-09-28 17:50:20 +08:00
if ( ASKDemod_ext ( 0 , 0 , 0 , 0 , false , true , false , 1 , & st ) = = PM3_SUCCESS ) {
2019-03-11 21:55:02 +08:00
PrintAndLogEx ( NORMAL , " \n Unknown ASK Modulated and Manchester encoded Tag found! " ) ;
2019-03-12 06:12:31 +08:00
PrintAndLogEx ( NORMAL , " if it does not look right it could instead be ASK/Biphase - try " _YELLOW_ ( " 'data rawdemod ab' " ) ) ;
2019-03-10 07:00:59 +08:00
goto out ;
2019-03-10 06:35:06 +08:00
}
2019-05-22 20:32:30 +08:00
if ( CmdPSK1rawDemod ( " " ) = = PM3_SUCCESS ) {
2019-03-11 21:55:02 +08:00
PrintAndLogEx ( NORMAL , " Possible unknown PSK1 Modulated Tag found above! " ) ;
2019-03-12 06:12:31 +08:00
PrintAndLogEx ( NORMAL , " Could also be PSK2 - try " _YELLOW_ ( " 'data rawdemod p2' " ) ) ;
2019-03-11 21:55:02 +08:00
PrintAndLogEx ( NORMAL , " Could also be PSK3 - [currently not supported] " ) ;
2019-03-12 06:12:31 +08:00
PrintAndLogEx ( NORMAL , " Could also be NRZ - try " _YELLOW_ ( " 'data rawdemod nr " ) ) ;
2019-03-10 06:35:06 +08:00
goto out ;
}
2019-03-12 06:12:31 +08:00
PrintAndLogEx ( FAILED , _RED_ ( " \n No data found! " ) ) ;
2019-03-10 06:35:06 +08:00
}
2019-11-19 19:17:08 +08:00
retval = PM3_ESOFT ;
2017-07-31 18:31:39 +08:00
out :
2019-03-10 06:35:06 +08:00
// identify chipset
2019-07-13 06:38:30 +08:00
if ( CheckChipType ( isOnline ) = = false ) {
PrintAndLogEx ( DEBUG , " Automatic chip type detection " _RED_ ( " failed " ) ) ;
2020-06-09 00:43:34 +08:00
retval = false ;
2019-06-08 22:10:04 +08:00
}
2019-11-19 19:17:08 +08:00
return retval ;
2014-12-31 05:08:33 +08:00
}
2017-02-26 06:00:20 +08:00
static command_t CommandTable [ ] = {
2020-10-23 04:16:44 +08:00
{ " ----------- " , CmdHelp , AlwaysAvailable , " -------------- " _CYAN_ ( " Low Frequency " ) " -------------- " } ,
2019-05-02 02:48:15 +08:00
{ " awid " , CmdLFAWID , AlwaysAvailable , " { AWID RFIDs... } " } ,
{ " cotag " , CmdLFCOTAG , AlwaysAvailable , " { COTAG CHIPs... } " } ,
2020-10-12 18:27:00 +08:00
{ " destron " , CmdLFDestron , AlwaysAvailable , " { FDX-A Destron RFIDs... } " } ,
2020-12-04 07:11:57 +08:00
{ " em " , CmdLFEM , AlwaysAvailable , " { EM CHIPs & RFIDs... } " } ,
2020-10-12 04:38:52 +08:00
{ " fdxb " , CmdLFFdxB , AlwaysAvailable , " { FDX-B RFIDs... } " } ,
2019-10-09 03:45:40 +08:00
{ " gallagher " , CmdLFGallagher , AlwaysAvailable , " { GALLAGHER RFIDs... } " } ,
2019-05-02 02:48:15 +08:00
{ " gproxii " , CmdLFGuard , AlwaysAvailable , " { Guardall Prox II RFIDs... } " } ,
2020-03-10 17:41:16 +08:00
{ " hid " , CmdLFHID , AlwaysAvailable , " { HID Prox RFIDs... } " } ,
2019-05-02 02:48:15 +08:00
{ " hitag " , CmdLFHitag , AlwaysAvailable , " { Hitag CHIPs... } " } ,
2020-09-29 03:09:26 +08:00
{ " idteck " , CmdLFIdteck , AlwaysAvailable , " { Idteck RFIDs... } " } ,
2019-05-02 02:48:15 +08:00
{ " indala " , CmdLFINDALA , AlwaysAvailable , " { Indala RFIDs... } " } ,
{ " io " , CmdLFIO , AlwaysAvailable , " { ioProx RFIDs... } " } ,
{ " jablotron " , CmdLFJablotron , AlwaysAvailable , " { Jablotron RFIDs... } " } ,
{ " keri " , CmdLFKeri , AlwaysAvailable , " { KERI RFIDs... } " } ,
2020-03-02 20:59:41 +08:00
{ " motorola " , CmdLFMotorola , AlwaysAvailable , " { Motorola RFIDs... } " } ,
2019-05-02 02:48:15 +08:00
{ " nedap " , CmdLFNedap , AlwaysAvailable , " { Nedap RFIDs... } " } ,
{ " nexwatch " , CmdLFNEXWATCH , AlwaysAvailable , " { NexWatch RFIDs... } " } ,
{ " noralsy " , CmdLFNoralsy , AlwaysAvailable , " { Noralsy RFIDs... } " } ,
{ " pac " , CmdLFPac , AlwaysAvailable , " { PAC/Stanley RFIDs... } " } ,
{ " paradox " , CmdLFParadox , AlwaysAvailable , " { Paradox RFIDs... } " } ,
{ " pcf7931 " , CmdLFPCF7931 , AlwaysAvailable , " { PCF7931 CHIPs... } " } ,
{ " presco " , CmdLFPresco , AlwaysAvailable , " { Presco RFIDs... } " } ,
{ " pyramid " , CmdLFPyramid , AlwaysAvailable , " { Farpointe/Pyramid RFIDs... } " } ,
{ " securakey " , CmdLFSecurakey , AlwaysAvailable , " { Securakey RFIDs... } " } ,
{ " ti " , CmdLFTI , AlwaysAvailable , " { TI CHIPs... } " } ,
{ " t55xx " , CmdLFT55XX , AlwaysAvailable , " { T55xx CHIPs... } " } ,
{ " viking " , CmdLFViking , AlwaysAvailable , " { Viking RFIDs... } " } ,
{ " visa2000 " , CmdLFVisa2k , AlwaysAvailable , " { Visa2000 RFIDs... } " } ,
2020-09-25 01:51:57 +08:00
{ " ----------- " , CmdHelp , AlwaysAvailable , " --------------------- " _CYAN_ ( " General " ) " --------------------- " } ,
{ " help " , CmdHelp , AlwaysAvailable , " This help " } ,
2019-10-04 04:11:16 +08:00
{ " config " , CmdLFConfig , IfPm3Lf , " Get/Set config for LF sampling, bit/sample, decimation, frequency " } ,
2020-01-10 02:28:44 +08:00
{ " cmdread " , CmdLFCommandRead , IfPm3Lf , " Modulate LF reader field to send command before read (all periods in microseconds) " } ,
{ " read " , CmdLFRead , IfPm3Lf , " Read LF tag " } ,
{ " search " , CmdLFfind , AlwaysAvailable , " Read and Search for valid known tag (in offline mode it you can load first then search) " } ,
{ " sim " , CmdLFSim , IfPm3Lf , " Simulate LF tag from buffer with optional GAP (in microseconds) " } ,
2020-09-25 01:51:57 +08:00
{ " simask " , CmdLFaskSim , IfPm3Lf , " Simulate " _YELLOW_ ( " LF ASK tag " ) " from demodbuffer or input " } ,
{ " simfsk " , CmdLFfskSim , IfPm3Lf , " Simulate " _YELLOW_ ( " LF FSK tag " ) " from demodbuffer or input " } ,
{ " simpsk " , CmdLFpskSim , IfPm3Lf , " Simulate " _YELLOW_ ( " LF PSK tag " ) " from demodbuffer or input " } ,
// {"simpsk", CmdLFnrzSim, IfPm3Lf, "Simulate " _YELLOW_("LF NRZ tag") " from demodbuffer or input"},
2019-05-02 06:02:38 +08:00
{ " simbidir " , CmdLFSimBidir , IfPm3Lf , " Simulate LF tag (with bidirectional data transmission between reader and tag) " } ,
{ " sniff " , CmdLFSniff , IfPm3Lf , " Sniff LF traffic between reader and tag " } ,
2019-09-24 19:06:43 +08:00
{ " tune " , CmdLFTune , IfPm3Lf , " Continuously measure LF antenna tuning " } ,
2019-10-01 20:30:30 +08:00
// {"vchdemod", CmdVchDemod, AlwaysAvailable, "['clone'] -- Demodulate samples for VeriChip"},
2019-11-19 19:17:08 +08:00
// {"flexdemod", CmdFlexdemod, AlwaysAvailable, "Demodulate samples for Motorola FlexPass"},
2019-05-02 02:48:15 +08:00
{ NULL , NULL , NULL , NULL }
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
} ;
2019-03-10 18:20:22 +08:00
int CmdLF ( const char * Cmd ) {
2019-03-10 06:35:06 +08:00
clearCommandBuffer ( ) ;
2019-04-19 06:47:51 +08:00
return CmdsParse ( CommandTable , Cmd ) ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}
2019-03-10 18:20:22 +08:00
int CmdHelp ( const char * Cmd ) {
2019-04-10 18:23:40 +08:00
( void ) Cmd ; // Cmd is not used so far
2019-03-10 06:35:06 +08:00
CmdsHelp ( CommandTable ) ;
2019-05-22 20:32:30 +08:00
return PM3_SUCCESS ;
Client cleanup and restructuring. Stage 1...
Next Step is refactoring some of the giant functions which are
just copy/paste of some other ones with just a few line changes,
removing unnecessary 'goto' etc.
The MS Windows version is broken with this commit but will be fixed
soon. Everything can't be done all at once :P
The commands are now hierarchical, for example:
"hf 14a read" vs. "hf 14b read".
You can also request help:
"hf help", "data help", "hf 15 help" etc.
Indents are now space-based, not tab-based anymore. Hopefully
no one will be trolling about it, considering the suicide-prone work
being done here ;)
client/cmdhw.c, client/proxusb.c, client/cmdhw.h, client/proxusb.h,
client/cmdmain.c, client/cmdlfhid.c, client/cmdmain.h, client/cmdlfhid.h,
client/data.c, client/data.h, client/cmdhf.c, client/cmdlf.c,
client/cmdhf.h, client/cmdhf15.c, client/cmdhf14b.c, client/cmdlf.h,
client/cmdhf15.h, client/cmdhf14b.h, client/cmddata.c, client/cmddata.h,
client/ui.c, client/cmdparser.c, client/cmdlfti.c, client/ui.h,
client/cmdlfem4x.c, client/cmdparser.h, client/cmdlfti.h, client/cmdlfem4x.h,
client/graph.c, client/graph.h, client/cmdhf14a.c, client/cmdhf14a.h,
client/cmdhflegic.c, client/cmdhflegic.c: New files.
client/cli.c, client/flasher.c, client/snooper.c, client/proxmark3.c,
client/proxmark3.h, client/Makefile: Update accordingly.
client/flash.h, client/flash.c, client/proxgui.cpp: Cosmetic changes.
client/translate.h, client/command.c, client/gui.c,
client/usb.c, client/prox.h: Remove.
include/usb_cmd.h (CMD_ACQUIRE_RAW_ADC_SAMPLES_ISO_14443_SIM): Remove dead cmd.
common/crc16.h: New file.
common/crc16.c: Modify accordingly.
common/iso14443crc.h: New file.
common/iso14443_crc.c: Rename to
common/iso14443crc.c: and modify accordingly.
armsrc/lfops.c, armsrc/iso14443.c,
armsrc/iso14443a.c: include .h files from
the common directory instead of including the c files.
common/Makefile.common, armsrc/Makefile: Modify accordingly.
2010-02-04 09:27:07 +08:00
}