]> git.zerfleddert.de Git - proxmark3-svn/blobdiff - client/cmdlfem4x.c
fixed hf mf rdbl response data (broken since r634)
[proxmark3-svn] / client / cmdlfem4x.c
index 92cdb90d2248b11483bdd09b87d173c87d7dde2b..f823750b047192c94723110eb9e5fd679839d45f 100644 (file)
@@ -11,7 +11,8 @@
 #include <stdio.h>
 #include <string.h>
 #include <inttypes.h>
 #include <stdio.h>
 #include <string.h>
 #include <inttypes.h>
-#include "proxusb.h"
+//#include "proxusb.h"
+#include "proxmark3.h"
 #include "ui.h"
 #include "graph.h"
 #include "cmdparser.h"
 #include "ui.h"
 #include "graph.h"
 #include "cmdparser.h"
@@ -427,16 +428,16 @@ int CmdReadWord(const char *Cmd)
 {
   int Word = 16; //default to invalid word
   UsbCommand c;
 {
   int Word = 16; //default to invalid word
   UsbCommand c;
-
+  
   sscanf(Cmd, "%d", &Word);
   sscanf(Cmd, "%d", &Word);
-
+  
   if (Word > 15) {
   if (Word > 15) {
-       PrintAndLog("Word must be between 0 and 15");
-       return 1;
-  }    
-
+    PrintAndLog("Word must be between 0 and 15");
+    return 1;
+  }
+  
   PrintAndLog("Reading word %d", Word);
   PrintAndLog("Reading word %d", Word);
-
+  
   c.cmd = CMD_EM4X_READ_WORD;
   c.d.asBytes[0] = 0x0; //Normal mode
   c.arg[0] = 0;
   c.cmd = CMD_EM4X_READ_WORD;
   c.d.asBytes[0] = 0x0; //Normal mode
   c.arg[0] = 0;
@@ -451,16 +452,16 @@ int CmdReadWordPWD(const char *Cmd)
   int Word = 16; //default to invalid word
   int Password = 0xFFFFFFFF; //default to blank password
   UsbCommand c;
   int Word = 16; //default to invalid word
   int Password = 0xFFFFFFFF; //default to blank password
   UsbCommand c;
-
+  
   sscanf(Cmd, "%d %x", &Word, &Password);
   sscanf(Cmd, "%d %x", &Word, &Password);
-
+  
   if (Word > 15) {
   if (Word > 15) {
-       PrintAndLog("Word must be between 0 and 15");
-       return 1;
-  }    
-
+    PrintAndLog("Word must be between 0 and 15");
+    return 1;
+  }
+  
   PrintAndLog("Reading word %d with password %08X", Word, Password);
   PrintAndLog("Reading word %d with password %08X", Word, Password);
-
+  
   c.cmd = CMD_EM4X_READ_WORD;
   c.d.asBytes[0] = 0x1; //Password mode
   c.arg[0] = 0;
   c.cmd = CMD_EM4X_READ_WORD;
   c.d.asBytes[0] = 0x1; //Password mode
   c.arg[0] = 0;
@@ -473,18 +474,18 @@ int CmdReadWordPWD(const char *Cmd)
 int CmdWriteWord(const char *Cmd)
 {
   int Word = 16; //default to invalid block
 int CmdWriteWord(const char *Cmd)
 {
   int Word = 16; //default to invalid block
-  int Data = 0xFFFFFFFF; //default to blank data 
+  int Data = 0xFFFFFFFF; //default to blank data
   UsbCommand c;
   UsbCommand c;
-
+  
   sscanf(Cmd, "%x %d", &Data, &Word);
   sscanf(Cmd, "%x %d", &Data, &Word);
-
+  
   if (Word > 15) {
   if (Word > 15) {
-       PrintAndLog("Word must be between 0 and 15");
-       return 1;
-  }    
-
+    PrintAndLog("Word must be between 0 and 15");
+    return 1;
+  }
+  
   PrintAndLog("Writting word %d with data %08X", Word, Data);
   PrintAndLog("Writting word %d with data %08X", Word, Data);
-
+  
   c.cmd = CMD_EM4X_WRITE_WORD;
   c.d.asBytes[0] = 0x0; //Normal mode
   c.arg[0] = Data;
   c.cmd = CMD_EM4X_WRITE_WORD;
   c.d.asBytes[0] = 0x0; //Normal mode
   c.arg[0] = Data;
@@ -497,19 +498,19 @@ int CmdWriteWord(const char *Cmd)
 int CmdWriteWordPWD(const char *Cmd)
 {
   int Word = 8; //default to invalid word
 int CmdWriteWordPWD(const char *Cmd)
 {
   int Word = 8; //default to invalid word
-  int Data = 0xFFFFFFFF; //default to blank data 
+  int Data = 0xFFFFFFFF; //default to blank data
   int Password = 0xFFFFFFFF; //default to blank password
   UsbCommand c;
   int Password = 0xFFFFFFFF; //default to blank password
   UsbCommand c;
-
+  
   sscanf(Cmd, "%x %d %x", &Data, &Word, &Password);
   sscanf(Cmd, "%x %d %x", &Data, &Word, &Password);
-
+  
   if (Word > 15) {
   if (Word > 15) {
-       PrintAndLog("Word must be between 0 and 15");
-       return 1;
-  }    
-
+    PrintAndLog("Word must be between 0 and 15");
+    return 1;
+  }
+  
   PrintAndLog("Writting word %d with data %08X and password %08X", Word, Data, Password);
   PrintAndLog("Writting word %d with data %08X and password %08X", Word, Data, Password);
-
+  
   c.cmd = CMD_EM4X_WRITE_WORD;
   c.d.asBytes[0] = 0x1; //Password mode
   c.arg[0] = Data;
   c.cmd = CMD_EM4X_WRITE_WORD;
   c.d.asBytes[0] = 0x1; //Password mode
   c.arg[0] = Data;
@@ -520,17 +521,18 @@ int CmdWriteWordPWD(const char *Cmd)
 }
 
 
 }
 
 
+
 static command_t CommandTable[] =
 {
 static command_t CommandTable[] =
 {
-  {"help",         CmdHelp,         1, "This help"},
-  {"em410xread",   CmdEM410xRead,   1, "[clock rate] -- Extract ID from EM410x tag"},
-  {"em410xsim",    CmdEM410xSim,    0, "<UID> -- Simulate EM410x tag"},
-  {"em410xwatch",  CmdEM410xWatch,  0, "Watches for EM410x tags"},
-  {"em410xwrite",  CmdEM410xWrite,  1, "<UID> <'0' T5555> <'1' T55x7> -- Write EM410x UID to T5555(Q5) or T55x7 tag"},
-  {"em4x50read",   CmdEM4x50Read,   1, "Extract data from EM4x50 tag"},
-  {"readword",     CmdReadWord,     1, "<Word> -- Read EM4xxx word data"},
-  {"readwordPWD",  CmdReadWordPWD,  1, "<Word> <Password> -- Read EM4xxx word data in password mode"},
-  {"writeword",    CmdWriteWord,    1, "<Data> <Word> -- Write EM4xxx word data"},
+  {"help", CmdHelp, 1, "This help"},
+  {"em410xread", CmdEM410xRead, 1, "[clock rate] -- Extract ID from EM410x tag"},
+  {"em410xsim", CmdEM410xSim, 0, "<UID> -- Simulate EM410x tag"},
+  {"em410xwatch", CmdEM410xWatch, 0, "Watches for EM410x tags"},
+  {"em410xwrite", CmdEM410xWrite, 1, "<UID> <'0' T5555> <'1' T55x7> -- Write EM410x UID to T5555(Q5) or T55x7 tag"},
+  {"em4x50read", CmdEM4x50Read, 1, "Extract data from EM4x50 tag"},
+  {"readword", CmdReadWord, 1, "<Word> -- Read EM4xxx word data"},
+  {"readwordPWD", CmdReadWordPWD, 1, "<Word> <Password> -- Read EM4xxx word data in password mode"},
+  {"writeword", CmdWriteWord, 1, "<Data> <Word> -- Write EM4xxx word data"},
   {"writewordPWD", CmdWriteWordPWD, 1, "<Data> <Word> <Password> -- Write EM4xxx word data in password mode"},
   {NULL, NULL, 0, NULL}
 };
   {"writewordPWD", CmdWriteWordPWD, 1, "<Data> <Word> <Password> -- Write EM4xxx word data in password mode"},
   {NULL, NULL, 0, NULL}
 };
Impressum, Datenschutz