mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2024-12-29 11:52:59 +08:00
commits after xcode crash
This commit is contained in:
parent
20bc2b060b
commit
438cada2cf
7 changed files with 116 additions and 1 deletions
|
@ -1163,6 +1163,10 @@ static void PacketReceived(PacketCommandNG *packet) {
|
||||||
em4x50_chk((uint8_t *)packet->data.asBytes);
|
em4x50_chk((uint8_t *)packet->data.asBytes);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case CMD_LF_EM4X50_TEST: {
|
||||||
|
em4x50_test((em4x50_test_t *)packet->data.asBytes);
|
||||||
|
break;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_EM4x70
|
#ifdef WITH_EM4x70
|
||||||
|
|
|
@ -431,7 +431,6 @@ static int find_double_listen_window(bool bcommand) {
|
||||||
// send RM for request mode
|
// send RM for request mode
|
||||||
em4x50_reader_send_bit(0);
|
em4x50_reader_send_bit(0);
|
||||||
em4x50_reader_send_bit(0);
|
em4x50_reader_send_bit(0);
|
||||||
|
|
||||||
LED_B_OFF();
|
LED_B_OFF();
|
||||||
|
|
||||||
return PM3_SUCCESS;
|
return PM3_SUCCESS;
|
||||||
|
@ -724,13 +723,27 @@ static bool em4x50_sim_send_word(uint32_t word) {
|
||||||
|
|
||||||
static bool em4x50_sim_send_listen_window(void) {
|
static bool em4x50_sim_send_listen_window(void) {
|
||||||
|
|
||||||
|
bool cond = false;
|
||||||
uint16_t check = 0;
|
uint16_t check = 0;
|
||||||
|
uint32_t tval1[5 * EM4X50_T_TAG_FULL_PERIOD] = {0};
|
||||||
|
uint32_t tval2[5 * EM4X50_T_TAG_FULL_PERIOD] = {0};
|
||||||
|
|
||||||
|
StartTicks();
|
||||||
|
|
||||||
for (int t = 0; t < 5 * EM4X50_T_TAG_FULL_PERIOD; t++) {
|
for (int t = 0; t < 5 * EM4X50_T_TAG_FULL_PERIOD; t++) {
|
||||||
|
|
||||||
|
cond = ((t >= 3 * EM4X50_T_TAG_FULL_PERIOD) && (t < 4 * EM4X50_T_TAG_FULL_PERIOD));
|
||||||
|
|
||||||
// wait until SSC_CLK goes HIGH
|
// wait until SSC_CLK goes HIGH
|
||||||
|
if (cond) {
|
||||||
|
AT91C_BASE_TC1->TC_CCR = AT91C_TC_SWTRG;
|
||||||
|
AT91C_BASE_TC0->TC_CCR = AT91C_TC_SWTRG;
|
||||||
|
while (AT91C_BASE_TC0->TC_CV > 0);
|
||||||
|
}
|
||||||
|
|
||||||
while (!(AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_CLK)) {
|
while (!(AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_CLK)) {
|
||||||
WDT_HIT();
|
WDT_HIT();
|
||||||
|
|
||||||
if (check == 1000) {
|
if (check == 1000) {
|
||||||
if (BUTTON_PRESS())
|
if (BUTTON_PRESS())
|
||||||
return false;
|
return false;
|
||||||
|
@ -738,6 +751,8 @@ static bool em4x50_sim_send_listen_window(void) {
|
||||||
}
|
}
|
||||||
++check;
|
++check;
|
||||||
}
|
}
|
||||||
|
if (cond)
|
||||||
|
tval1[t] = GetTicks();
|
||||||
|
|
||||||
if (t >= 4 * EM4X50_T_TAG_FULL_PERIOD)
|
if (t >= 4 * EM4X50_T_TAG_FULL_PERIOD)
|
||||||
SHORT_COIL();
|
SHORT_COIL();
|
||||||
|
@ -753,6 +768,12 @@ static bool em4x50_sim_send_listen_window(void) {
|
||||||
check = 0;
|
check = 0;
|
||||||
|
|
||||||
// wait until SSC_CLK goes LOW
|
// wait until SSC_CLK goes LOW
|
||||||
|
if (cond) {
|
||||||
|
AT91C_BASE_TC1->TC_CCR = AT91C_TC_SWTRG;
|
||||||
|
AT91C_BASE_TC0->TC_CCR = AT91C_TC_SWTRG;
|
||||||
|
while (AT91C_BASE_TC0->TC_CV > 0);
|
||||||
|
}
|
||||||
|
|
||||||
while (AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_CLK) {
|
while (AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_CLK) {
|
||||||
WDT_HIT();
|
WDT_HIT();
|
||||||
if (check == 1000) {
|
if (check == 1000) {
|
||||||
|
@ -762,8 +783,16 @@ static bool em4x50_sim_send_listen_window(void) {
|
||||||
}
|
}
|
||||||
++check;
|
++check;
|
||||||
}
|
}
|
||||||
|
if (cond)
|
||||||
|
tval2[t] = GetTicks();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (int t = 0; t < 5 * EM4X50_T_TAG_FULL_PERIOD; t++) {
|
||||||
|
//if (tval[t] > 4)
|
||||||
|
Dbprintf("%3i probably RM intialization found: delta = %i %i", t, tval1[t], tval2[t]);
|
||||||
|
}
|
||||||
|
Dbprintf("");
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1281,3 +1310,39 @@ void em4x50_sim(uint8_t *filename) {
|
||||||
lf_finalize();
|
lf_finalize();
|
||||||
reply_ng(CMD_LF_EM4X50_SIM, status, NULL, 0);
|
reply_ng(CMD_LF_EM4X50_SIM, status, NULL, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void em4x50_test(em4x50_test_t *ett) {
|
||||||
|
|
||||||
|
int status = PM3_EFAILED;
|
||||||
|
|
||||||
|
em4x50_setup_read();
|
||||||
|
|
||||||
|
if (ett->field) {
|
||||||
|
LOW(GPIO_SSC_DOUT);
|
||||||
|
LED_A_ON();
|
||||||
|
|
||||||
|
if (DBGLEVEL >= DBG_DEBUG)
|
||||||
|
Dbprintf("switched field on");
|
||||||
|
|
||||||
|
status = 1;
|
||||||
|
} else {
|
||||||
|
HIGH(GPIO_SSC_DOUT);
|
||||||
|
LED_A_OFF();
|
||||||
|
|
||||||
|
if (DBGLEVEL >= DBG_DEBUG)
|
||||||
|
Dbprintf("switched field off");
|
||||||
|
|
||||||
|
status = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (BUTTON_PRESS() == false) {
|
||||||
|
|
||||||
|
if (AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_CLK) {
|
||||||
|
Dbprintf("field on");
|
||||||
|
} else if (!(AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_CLK)){
|
||||||
|
Dbprintf("field on");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
reply_ng(CMD_LF_EM4X50_TEST, status, NULL, 0);
|
||||||
|
}
|
||||||
|
|
|
@ -22,5 +22,6 @@ void em4x50_login(uint32_t *password);
|
||||||
void em4x50_sim(uint8_t *filename);
|
void em4x50_sim(uint8_t *filename);
|
||||||
void em4x50_reader(void);
|
void em4x50_reader(void);
|
||||||
void em4x50_chk(uint8_t *filename);
|
void em4x50_chk(uint8_t *filename);
|
||||||
|
void em4x50_test(em4x50_test_t *ett);
|
||||||
|
|
||||||
#endif /* EM4X50_H */
|
#endif /* EM4X50_H */
|
||||||
|
|
|
@ -1158,6 +1158,43 @@ int CmdEM4x50Sim(const char *Cmd) {
|
||||||
return resp.status;
|
return resp.status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int CmdEM4x50Test(const char *Cmd) {
|
||||||
|
CLIParserContext *ctx;
|
||||||
|
CLIParserInit(&ctx, "lf em 4x50 test",
|
||||||
|
"perform EM4x50 tests.",
|
||||||
|
"lf em 4x50 test --field 1 -> reader field on \n"
|
||||||
|
);
|
||||||
|
|
||||||
|
void *argtable[] = {
|
||||||
|
arg_param_begin,
|
||||||
|
arg_lit0("", "field", "field off/on"),
|
||||||
|
arg_param_end
|
||||||
|
};
|
||||||
|
|
||||||
|
CLIExecWithReturn(ctx, Cmd, argtable, true);
|
||||||
|
|
||||||
|
em4x50_test_t ett;
|
||||||
|
ett.field = arg_get_lit(ctx, 1);
|
||||||
|
CLIParserFree(ctx);
|
||||||
|
|
||||||
|
// start
|
||||||
|
clearCommandBuffer();
|
||||||
|
PacketResponseNG resp;
|
||||||
|
SendCommandNG(CMD_LF_EM4X50_TEST, (uint8_t *)&ett, sizeof(ett));
|
||||||
|
WaitForResponse(CMD_LF_EM4X50_TEST, &resp);
|
||||||
|
|
||||||
|
// print response
|
||||||
|
if (resp.status == 1) {
|
||||||
|
PrintAndLogEx(SUCCESS, "Field switched " _GREEN_("on"));
|
||||||
|
} else if (resp.status == 0) {
|
||||||
|
PrintAndLogEx(SUCCESS, "Field switched " _GREEN_("off"));
|
||||||
|
} else {
|
||||||
|
PrintAndLogEx(FAILED, "Test call " _RED_("failed"));
|
||||||
|
}
|
||||||
|
|
||||||
|
return resp.status;
|
||||||
|
}
|
||||||
|
|
||||||
static command_t CommandTable[] = {
|
static command_t CommandTable[] = {
|
||||||
{"help", CmdHelp, AlwaysAvailable, "This help"},
|
{"help", CmdHelp, AlwaysAvailable, "This help"},
|
||||||
{"brute", CmdEM4x50Brute, IfPm3EM4x50, "guess password of EM4x50"},
|
{"brute", CmdEM4x50Brute, IfPm3EM4x50, "guess password of EM4x50"},
|
||||||
|
@ -1175,6 +1212,7 @@ static command_t CommandTable[] = {
|
||||||
{"eload", CmdEM4x50ELoad, IfPm3EM4x50, "upload dump of EM4x50 to emulator memory"},
|
{"eload", CmdEM4x50ELoad, IfPm3EM4x50, "upload dump of EM4x50 to emulator memory"},
|
||||||
{"esave", CmdEM4x50ESave, IfPm3EM4x50, "save emulator memory to file"},
|
{"esave", CmdEM4x50ESave, IfPm3EM4x50, "save emulator memory to file"},
|
||||||
{"eview", CmdEM4x50EView, IfPm3EM4x50, "view EM4x50 content in emulator memory"},
|
{"eview", CmdEM4x50EView, IfPm3EM4x50, "view EM4x50 content in emulator memory"},
|
||||||
|
{"test", CmdEM4x50Test, IfPm3EM4x50, "perform EM4x50 tests"},
|
||||||
{NULL, NULL, NULL, NULL}
|
{NULL, NULL, NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1188,3 +1226,4 @@ int CmdLFEM4X50(const char *Cmd) {
|
||||||
clearCommandBuffer();
|
clearCommandBuffer();
|
||||||
return CmdsParse(CommandTable, Cmd);
|
return CmdsParse(CommandTable, Cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,5 +34,6 @@ int CmdEM4x50ELoad(const char *Cmd);
|
||||||
int CmdEM4x50ESave(const char *Cmd);
|
int CmdEM4x50ESave(const char *Cmd);
|
||||||
int CmdEM4x50Chk(const char *Cmd);
|
int CmdEM4x50Chk(const char *Cmd);
|
||||||
int CmdEM4x50EView(const char *Cmd);
|
int CmdEM4x50EView(const char *Cmd);
|
||||||
|
int CmdEM4x50Test(const char *Cmd);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -46,6 +46,10 @@ typedef struct {
|
||||||
uint32_t addresses;
|
uint32_t addresses;
|
||||||
} PACKED em4x50_data_t;
|
} PACKED em4x50_data_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
bool field;
|
||||||
|
} PACKED em4x50_test_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint8_t byte[4];
|
uint8_t byte[4];
|
||||||
} PACKED em4x50_word_t;
|
} PACKED em4x50_word_t;
|
||||||
|
|
|
@ -516,6 +516,7 @@ typedef struct {
|
||||||
#define CMD_LF_EM4X50_READER 0x0251
|
#define CMD_LF_EM4X50_READER 0x0251
|
||||||
#define CMD_LF_EM4X50_ESET 0x0252
|
#define CMD_LF_EM4X50_ESET 0x0252
|
||||||
#define CMD_LF_EM4X50_CHK 0x0253
|
#define CMD_LF_EM4X50_CHK 0x0253
|
||||||
|
#define CMD_LF_EM4X50_TEST 0x0254
|
||||||
#define CMD_LF_EM4X70_INFO 0x0260
|
#define CMD_LF_EM4X70_INFO 0x0260
|
||||||
#define CMD_LF_EM4X70_WRITE 0x0261
|
#define CMD_LF_EM4X70_WRITE 0x0261
|
||||||
#define CMD_LF_EM4X70_UNLOCK 0x0262
|
#define CMD_LF_EM4X70_UNLOCK 0x0262
|
||||||
|
|
Loading…
Reference in a new issue