mirror of
https://github.com/Proxmark/proxmark3.git
synced 2025-07-07 05:31:17 -07:00
added functionality: dump card memory, save|load card memory.
50% fixed problem with readline lib
This commit is contained in:
parent
8556b852ed
commit
ab8b654efa
4 changed files with 135 additions and 11 deletions
|
@ -636,6 +636,7 @@ void MifareECardLoad(uint32_t arg0, uint32_t arg1, uint32_t arg2, uint8_t *datai
|
||||||
|
|
||||||
// variables
|
// variables
|
||||||
byte_t dataoutbuf[16];
|
byte_t dataoutbuf[16];
|
||||||
|
byte_t dataoutbuf2[16];
|
||||||
uint8_t uid[8];
|
uint8_t uid[8];
|
||||||
|
|
||||||
// clear trace
|
// clear trace
|
||||||
|
@ -687,6 +688,15 @@ void MifareECardLoad(uint32_t arg0, uint32_t arg1, uint32_t arg2, uint8_t *datai
|
||||||
break;
|
break;
|
||||||
};
|
};
|
||||||
emlSetMem(dataoutbuf, sectorNo * 4 + 2, 1);
|
emlSetMem(dataoutbuf, sectorNo * 4 + 2, 1);
|
||||||
|
|
||||||
|
// get block 3 bytes 6-9
|
||||||
|
if(mifare_classic_readblock(pcs, cuid, sectorNo * 4 + 3, dataoutbuf)) {
|
||||||
|
if (MF_DBGLEVEL >= 1) Dbprintf("Read block 3 error");
|
||||||
|
break;
|
||||||
|
};
|
||||||
|
emlGetMem(dataoutbuf2, sectorNo * 4 + 3, 1);
|
||||||
|
memcpy(&dataoutbuf2[6], &dataoutbuf[6], 4);
|
||||||
|
emlSetMem(dataoutbuf2, sectorNo * 4 + 3, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mifare_classic_halt(pcs, cuid)) {
|
if(mifare_classic_halt(pcs, cuid)) {
|
||||||
|
@ -699,14 +709,15 @@ void MifareECardLoad(uint32_t arg0, uint32_t arg1, uint32_t arg2, uint8_t *datai
|
||||||
|
|
||||||
// ----------------------------- crypto1 destroy
|
// ----------------------------- crypto1 destroy
|
||||||
crypto1_destroy(pcs);
|
crypto1_destroy(pcs);
|
||||||
|
|
||||||
|
FpgaWriteConfWord(FPGA_MAJOR_MODE_OFF);
|
||||||
|
LEDsoff();
|
||||||
|
|
||||||
if (MF_DBGLEVEL >= 2) DbpString("EMUL FILL SECTORS FINISHED");
|
if (MF_DBGLEVEL >= 2) DbpString("EMUL FILL SECTORS FINISHED");
|
||||||
|
|
||||||
// add trace trailer
|
// add trace trailer
|
||||||
memset(uid, 0x44, 4);
|
memset(uid, 0x44, 4);
|
||||||
LogTrace(uid, 4, 0, 0, TRUE);
|
LogTrace(uid, 4, 0, 0, TRUE);
|
||||||
|
|
||||||
Dbprintf("Loaded.");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
118
client/cmdhfmf.c
118
client/cmdhfmf.c
|
@ -427,7 +427,7 @@ int CmdHF14AMfNested(const char *Cmd)
|
||||||
for (i = 0; i < SectorsCnt; i++) {
|
for (i = 0; i < SectorsCnt; i++) {
|
||||||
mfEmlGetMem(keyBlock, i * 4 + 3, 1);
|
mfEmlGetMem(keyBlock, i * 4 + 3, 1);
|
||||||
if (e_sector[i].foundKey[0])
|
if (e_sector[i].foundKey[0])
|
||||||
num_to_bytes(e_sector[i].Key[1], 6, keyBlock);
|
num_to_bytes(e_sector[i].Key[0], 6, keyBlock);
|
||||||
if (e_sector[i].foundKey[1])
|
if (e_sector[i].foundKey[1])
|
||||||
num_to_bytes(e_sector[i].Key[1], 6, &keyBlock[10]);
|
num_to_bytes(e_sector[i].Key[1], 6, &keyBlock[10]);
|
||||||
mfEmlSetMem(keyBlock, i * 4 + 3, 1);
|
mfEmlSetMem(keyBlock, i * 4 + 3, 1);
|
||||||
|
@ -617,13 +617,125 @@ int CmdHF14AMfESet(const char *Cmd)
|
||||||
|
|
||||||
int CmdHF14AMfELoad(const char *Cmd)
|
int CmdHF14AMfELoad(const char *Cmd)
|
||||||
{
|
{
|
||||||
PrintAndLog("No code here (");
|
FILE * f;
|
||||||
|
char filename[20];
|
||||||
|
char * fnameptr = filename;
|
||||||
|
char buf[64];
|
||||||
|
uint8_t buf8[64];
|
||||||
|
int i, len, blockNum;
|
||||||
|
|
||||||
|
memset(filename, 0, sizeof(filename));
|
||||||
|
memset(buf, 0, sizeof(buf));
|
||||||
|
|
||||||
|
if (param_getchar(Cmd, 0) == 'h') {
|
||||||
|
PrintAndLog("It loads emul dump from the file `filename.eml`");
|
||||||
|
PrintAndLog("Usage: hf mf eload <file name w/o `.eml`>");
|
||||||
|
PrintAndLog(" sample: hf mf eload filename");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = strlen(Cmd);
|
||||||
|
if (len > 14) len = 14;
|
||||||
|
|
||||||
|
if (len < 1) {
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(filename, Cmd, len);
|
||||||
|
fnameptr += len;
|
||||||
|
|
||||||
|
sprintf(fnameptr, ".eml");
|
||||||
|
|
||||||
|
// open file
|
||||||
|
f = fopen(filename, "r");
|
||||||
|
if (f == NULL) {
|
||||||
|
PrintAndLog("File not found or locked.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
blockNum = 0;
|
||||||
|
while(!feof(f)){
|
||||||
|
memset(buf, 0, sizeof(buf));
|
||||||
|
fgets(buf, sizeof(buf), f);
|
||||||
|
if (strlen(buf) < 32){
|
||||||
|
PrintAndLog("File content error. Block data must include 32 HEX symbols");
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
for (i = 0; i < 32; i += 2)
|
||||||
|
sscanf(&buf[i], "%02x", (unsigned int *)&buf8[i / 2]);
|
||||||
|
// PrintAndLog("data[%02d]:%s", blockNum, sprint_hex(buf8, 16));
|
||||||
|
|
||||||
|
if (mfEmlSetMem(buf8, blockNum, 1)) {
|
||||||
|
PrintAndLog("Cant set emul block: %d", blockNum);
|
||||||
|
return 3;
|
||||||
|
}
|
||||||
|
blockNum++;
|
||||||
|
|
||||||
|
if (blockNum >= 16 * 4) break;
|
||||||
|
}
|
||||||
|
fclose(f);
|
||||||
|
|
||||||
|
if (blockNum != 16 * 4){
|
||||||
|
PrintAndLog("File content error. There must be 64 blocks");
|
||||||
|
return 4;
|
||||||
|
}
|
||||||
|
PrintAndLog("Loaded from file: %s", filename);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int CmdHF14AMfESave(const char *Cmd)
|
int CmdHF14AMfESave(const char *Cmd)
|
||||||
{
|
{
|
||||||
PrintAndLog("No code here (");
|
FILE * f;
|
||||||
|
char filename[20];
|
||||||
|
char * fnameptr = filename;
|
||||||
|
uint8_t buf[64];
|
||||||
|
int i, j, len;
|
||||||
|
|
||||||
|
memset(filename, 0, sizeof(filename));
|
||||||
|
memset(buf, 0, sizeof(buf));
|
||||||
|
|
||||||
|
if (param_getchar(Cmd, 0) == 'h') {
|
||||||
|
PrintAndLog("It saves emul dump into the file `filename.eml` or `cardID.eml`");
|
||||||
|
PrintAndLog("Usage: hf mf esave [file name w/o `.eml`]");
|
||||||
|
PrintAndLog(" sample: hf mf esave ");
|
||||||
|
PrintAndLog(" hf mf esave filename");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = strlen(Cmd);
|
||||||
|
if (len > 14) len = 14;
|
||||||
|
|
||||||
|
if (len < 1) {
|
||||||
|
// get filename
|
||||||
|
if (mfEmlGetMem(buf, 0, 1)) {
|
||||||
|
PrintAndLog("Cant get block: %d", 0);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
for (j = 0; j < 7; j++, fnameptr += 2)
|
||||||
|
sprintf(fnameptr, "%02x", buf[j]);
|
||||||
|
} else {
|
||||||
|
memcpy(filename, Cmd, len);
|
||||||
|
fnameptr += len;
|
||||||
|
}
|
||||||
|
|
||||||
|
sprintf(fnameptr, ".eml");
|
||||||
|
|
||||||
|
// open file
|
||||||
|
f = fopen(filename, "w+");
|
||||||
|
|
||||||
|
// put hex
|
||||||
|
for (i = 0; i < 16 * 4; i++) {
|
||||||
|
if (mfEmlGetMem(buf, i, 1)) {
|
||||||
|
PrintAndLog("Cant get block: %d", i);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
for (j = 0; j < 16; j++)
|
||||||
|
fprintf(f, "%02x", buf[j]);
|
||||||
|
fprintf(f,"\n");
|
||||||
|
}
|
||||||
|
fclose(f);
|
||||||
|
|
||||||
|
PrintAndLog("Saved to file: %s", filename);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -105,12 +105,12 @@ void UsbCommandReceived(UsbCommand *UC)
|
||||||
}
|
}
|
||||||
memcpy(s, UC->d.asBytes, UC->arg[0]);
|
memcpy(s, UC->d.asBytes, UC->arg[0]);
|
||||||
s[UC->arg[0]] = '\0';
|
s[UC->arg[0]] = '\0';
|
||||||
PrintAndLog("#db# %s", s);
|
PrintAndLog("#db# %s ", s);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
case CMD_DEBUG_PRINT_INTEGERS:
|
case CMD_DEBUG_PRINT_INTEGERS:
|
||||||
PrintAndLog("#db# %08x, %08x, %08x\r\n", UC->arg[0], UC->arg[1], UC->arg[2]);
|
PrintAndLog("#db# %08x, %08x, %08x \r\n", UC->arg[0], UC->arg[1], UC->arg[2]);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case CMD_MEASURED_ANTENNA_TUNING: {
|
case CMD_MEASURED_ANTENNA_TUNING: {
|
||||||
|
@ -158,7 +158,7 @@ void UsbCommandReceived(UsbCommand *UC)
|
||||||
unexpected_response:
|
unexpected_response:
|
||||||
|
|
||||||
if(UC->cmd != CMD_ACK)
|
if(UC->cmd != CMD_ACK)
|
||||||
PrintAndLog("unrecognized command %08x\n", UC->cmd);
|
PrintAndLog("unrecognized command %08x \n", UC->cmd);
|
||||||
else
|
else
|
||||||
memcpy(¤t_response, UC, sizeof(UsbCommand));
|
memcpy(¤t_response, UC, sizeof(UsbCommand));
|
||||||
received_command = UC->cmd;
|
received_command = UC->cmd;
|
||||||
|
|
|
@ -42,9 +42,10 @@ static void *usb_receiver(void *targ)
|
||||||
putchar(0x08);
|
putchar(0x08);
|
||||||
UsbCommandReceived(&cmdbuf);
|
UsbCommandReceived(&cmdbuf);
|
||||||
// there is a big bug )
|
// there is a big bug )
|
||||||
if (cmdbuf.cmd > 0x0100 && cmdbuf.cmd < 0x0110) { // debug commands
|
if (cmdbuf.cmd >= 0x0100 && cmdbuf.cmd <= 0x0110) { // debug commands
|
||||||
rl_on_new_line_with_prompt();
|
printf(">");
|
||||||
rl_forced_update_display();
|
// rl_on_new_line_with_prompt();
|
||||||
|
// rl_forced_update_display();
|
||||||
}
|
}
|
||||||
fflush(NULL);
|
fflush(NULL);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue