Skip to content

Commit

Permalink
Added set default timings
Browse files Browse the repository at this point in the history
  • Loading branch information
mwalker33 committed Jul 25, 2019
1 parent 77d96ff commit 3211f35
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 6 deletions.
4 changes: 2 additions & 2 deletions armsrc/lfops.c
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@
// Note: Moved * 8 to apply when used. Saving 28 bytes here (- the *8) and 28 bytes flash.
// StartGap WriteGap Bit 0/00 Bit 1/01 Bit 10 Bit 11 ReadGap
t55xx_config T55xx_Timing = {{
{ 29 , 17 , 15 , 50 , 0 , 0 , 15 }, // Default Fixed
{ 29 , 17 , 15 , 47 , 0 , 0 , 15 }, // Default Fixed
{ 31 , 20 , 18 , 50 , 0 , 0 , 15 }, // Long Leading Ref.
{ 31 , 20 , 18 , 40 , 0 , 0 , 15 }, // Leading 0
{ 29 , 17 , 15 , 31 , 47 , 63 , 15 } // 1 of 4
Expand All @@ -125,7 +125,7 @@ t55xx_config T55xx_Timing = {{
*/
// StartGap WriteGap Bit 0/00 Bit 1/01 ReadGap Bit 10 Bit 11
t55xx_config T55xx_Timing = {{
{ 29 * 8, 17 * 8, 15 * 8, 50 * 8, 15 * 8, 0, 0 }, // Default Fixed
{ 29 * 8, 17 * 8, 15 * 8, 47 * 8, 15 * 8, 0, 0 }, // Default Fixed
{ 31 * 8, 20 * 8, 18 * 8, 50 * 8, 15 * 8, 0, 0 }, // Long Leading Ref.
{ 31 * 8, 20 * 8, 18 * 8, 40 * 8, 15 * 8, 0, 0 }, // Leading 0
{ 29 * 8, 17 * 8, 15 * 8, 31 * 8, 15 * 8, 47 * 8, 63 * 8 } // 1 of 4
Expand Down
55 changes: 51 additions & 4 deletions client/cmdlft55xx.c
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,13 @@

#include "cmdlft55xx.h"

// Some defines for readability
#define T55xx_DLMode_Fixed 0 // Default Mode
#define T55xx_DLMode_LLR 1 // Long Leading Reference
#define T55xx_DLMode_Leading0 2 // Leading Zero
#define T55xx_DLMode_1of4 3 // 1 of 4
#define T55xx_LongLeadingReference 4 // Value to tell Write Bit to send long reference

// Default configuration
t55xx_conf_block_t config = { .modulation = DEMOD_ASK, .inverted = false, .offset = 0x00, .block0 = 0x00, .Q5 = false };

Expand Down Expand Up @@ -260,7 +267,7 @@ static int usage_lf_deviceconfig() {
PrintAndLogEx(NORMAL, " p - persist to flashmemory");
PrintAndLogEx(NORMAL, " r <mode> - downlink encoding '0' fixed bit length (default), '1' long leading ref.");
PrintAndLogEx(NORMAL, " '2' leading zero, '3' 1 of 4 coding ref.");
PrintAndLogEx(NORMAL, " z - erase t55x7 timings (needs p and reboot to load defaults)");
PrintAndLogEx(NORMAL, " z - Set default t55x7 timings (use p to save if required)");
PrintAndLogEx(NORMAL, "");
PrintAndLogEx(NORMAL, "Examples:");
PrintAndLogEx(NORMAL, " lf t55xx deviceconfig a 29 b 17 c 15 d 47 e 15 - default T55XX");
Expand Down Expand Up @@ -2549,7 +2556,7 @@ static int CmdT55xxSetDeviceConfig(const char *Cmd) {
bool errors = false, shall_persist = false;
uint8_t cmdp = 0;
uint8_t downlink_mode = 0;
bool erase = false;
bool set_defaults = false;

while (param_getchar(Cmd, cmdp) != 0x00 && !errors) {
switch (tolower(param_getchar(Cmd, cmdp))) {
Expand Down Expand Up @@ -2593,7 +2600,7 @@ static int CmdT55xxSetDeviceConfig(const char *Cmd) {
cmdp++;
break;
case 'z':
erase = true;
set_defaults = true;
cmdp++;
break;
default:
Expand All @@ -2607,9 +2614,48 @@ static int CmdT55xxSetDeviceConfig(const char *Cmd) {
if (errors || cmdp == 0) return usage_lf_deviceconfig();

t55xx_config conf = {0};
if (erase) {
/* if (erase) {
memset (&conf,0xff, sizeof(conf));
printf ("Conf.m[0] %x\n",conf.m[0].start_gap);
*/
//
if (set_defaults){
// fixed bit length
conf.m[T55xx_DLMode_Fixed].start_gap = 29 * 8;
conf.m[T55xx_DLMode_Fixed].write_gap = 17 * 8;
conf.m[T55xx_DLMode_Fixed].write_0 = 15 * 8;
conf.m[T55xx_DLMode_Fixed].write_1 = 47 * 8;
conf.m[T55xx_DLMode_Fixed].read_gap = 15 * 8;
conf.m[T55xx_DLMode_Fixed].write_2 = 0;
conf.m[T55xx_DLMode_Fixed].write_3 = 0;

// long leading reference
conf.m[T55xx_DLMode_LLR].start_gap = 31 * 8;
conf.m[T55xx_DLMode_LLR].write_gap = 20 * 8;
conf.m[T55xx_DLMode_LLR].write_0 = 18 * 8;
conf.m[T55xx_DLMode_LLR].write_1 = 50 * 8;
conf.m[T55xx_DLMode_LLR].read_gap = 15 * 8;
conf.m[T55xx_DLMode_LLR].write_2 = 0;
conf.m[T55xx_DLMode_LLR].write_3 = 0;

// leading zero
conf.m[T55xx_DLMode_Leading0].start_gap = 31 * 8;
conf.m[T55xx_DLMode_Leading0].write_gap = 20 * 8;
conf.m[T55xx_DLMode_Leading0].write_0 = 18 * 8;
conf.m[T55xx_DLMode_Leading0].write_1 = 40 * 8;
conf.m[T55xx_DLMode_Leading0].read_gap = 15 * 8;
conf.m[T55xx_DLMode_Leading0].write_2 = 0;
conf.m[T55xx_DLMode_Leading0].write_3 = 0;

// 1 of 4 coding reference
conf.m[T55xx_DLMode_1of4].start_gap = 29 * 8;
conf.m[T55xx_DLMode_1of4].write_gap = 17 * 8;
conf.m[T55xx_DLMode_1of4].write_0 = 15 * 8;
conf.m[T55xx_DLMode_1of4].write_1 = 31 * 8;
conf.m[T55xx_DLMode_1of4].read_gap = 15 * 8;
conf.m[T55xx_DLMode_1of4].write_2 = 47 * 8;
conf.m[T55xx_DLMode_1of4].write_3 = 63 * 8;

}
else {

Expand All @@ -2621,6 +2667,7 @@ static int CmdT55xxSetDeviceConfig(const char *Cmd) {
conf.m[downlink_mode].write_2 = write2 * 8;
conf.m[downlink_mode].write_3 = write3 * 8;
}

clearCommandBuffer();
SendCommandOLD(CMD_SET_LF_T55XX_CONFIG, shall_persist, 0, 0, &conf, sizeof(t55xx_config));
return PM3_SUCCESS;
Expand Down
3 changes: 3 additions & 0 deletions doc/md/Use_of_Proxmark/2_Configuration-and-Verification.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@ pm3 --> lf t55xx deviceconfig a 29 b 17 c 15 d 47 e 15 p
pm3 --> lf t55xx deviceconfig r 1 a 31 b 20 c 18 d 50 e 15 p
pm3 --> lf t55xx deviceconfig r 2 a 31 b 20 c 18 d 40 e 15 p
pm3 --> lf t55xx deviceconfig r 3 a 29 b 17 c 15 d 31 e 15 f 47 g 63 p
Set all t55xx settings to defaults (will set all 4 at once)
pm3 --> lf t55xx deviceconfig z p
```

### Verify sim module firmware version
Expand Down

0 comments on commit 3211f35

Please sign in to comment.