mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-02-19 22:00:34 +08:00
Update cmdlfkeri.c
This commit is contained in:
parent
c6ceeed6d5
commit
f32efd10fe
1 changed files with 39 additions and 50 deletions
|
@ -58,50 +58,42 @@ typedef enum {Scramble = 0,Descramble = 1} KeriMSScramble_t;
|
|||
|
||||
static int CmdKeriMSScramble (KeriMSScramble_t Action, uint32_t *FC, uint32_t *ID, uint32_t *CardID)
|
||||
{
|
||||
uint8_t CardToID [] = { 0xff,0xff,0xff,0xff,0x0d,0x0c,0x11,0x05,0xff,0x06,0xff,0x12,0x08,0xff,0x00,0x07,
|
||||
0x0a,0xff,0xff,0x0b,0x04,0x01,0xff,0x13,0xff,0x14,0x02,0xff,0x03,0x09,0xff,0xff };
|
||||
uint8_t CardToFC [] = { 0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,
|
||||
0xff,0xff,0x02,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0x01,0xff };
|
||||
|
||||
uint8_t IDToCard [] = { 0x0e,0x15,0x1a,0x1c,0x14,0x07,0x09,0x0f,0x0c,0x1d,0x10,0x13,0x05,0x04,0xff,0xff,
|
||||
0xff,0x06,0x0b,0x17,0x19,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff };
|
||||
uint8_t FCToCard [] = { 0xff,0x1e,0x12,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,
|
||||
0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff };
|
||||
// 255 = Not used/Unknown other values are the bit offset in the ID/FC values
|
||||
uint8_t CardToID [] = { 255,255,255,255, 13, 12, 17, 5,255, 6,255, 18, 8,255, 0, 7,
|
||||
10,255,255, 11, 4, 1,255, 19,255, 20, 2,255, 3, 9,255,255 };
|
||||
uint8_t CardToFC [] = { 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
|
||||
255,255, 2,255,255,255,255,255,255,255,255,255,255,255, 1,255 };
|
||||
|
||||
uint8_t CardIdx; // 0 - 31
|
||||
bool BitState;
|
||||
int idx;
|
||||
|
||||
// Used to track known bit states - remove when all bit maps are known
|
||||
char IDDecodeState[33] = {0x00};
|
||||
char FCDecodeState[33] = {0x00};
|
||||
memset (IDDecodeState,'-',32);
|
||||
memset (FCDecodeState,'-',32);
|
||||
|
||||
if (Action == Descramble) {
|
||||
char IDDecodeState[33] = {0x00};
|
||||
char FCDecodeState[33] = {0x00};
|
||||
|
||||
memset (IDDecodeState,'-',32);
|
||||
memset (FCDecodeState,'-',32);
|
||||
|
||||
*FC = 0;
|
||||
*ID = 0;
|
||||
|
||||
for (CardIdx = 0; CardIdx < 32; CardIdx++) {
|
||||
// Get Bit State
|
||||
BitState = (*CardID >> CardIdx) & 1;
|
||||
//if (BitState) { // its a 1
|
||||
idx = CardToID[CardIdx];
|
||||
if ((idx >= 0) && (idx <= 32)) {
|
||||
if (BitState)
|
||||
*ID = *ID | (1 << idx);
|
||||
IDDecodeState[31-idx] = '0'+BitState;
|
||||
// Card ID
|
||||
if (CardToID[CardIdx] < 32) {
|
||||
*ID = *ID | (BitState << CardToID[CardIdx]);
|
||||
// Remove when all bits are known
|
||||
IDDecodeState[31-CardToID[CardIdx]] = '0'+BitState;
|
||||
}
|
||||
|
||||
idx = CardToFC[CardIdx];
|
||||
if ((idx >= 0) && (idx <= 32)) {
|
||||
if (BitState)
|
||||
*FC = *FC | (1 << idx);
|
||||
FCDecodeState[31-idx] = '0'+BitState;
|
||||
// Card FC
|
||||
if (CardToFC[CardIdx] < 32) {
|
||||
*FC = *FC | (BitState << CardToFC[CardIdx]);
|
||||
// Remove when all bits are known
|
||||
FCDecodeState[31-CardToFC[CardIdx]] = '0'+BitState;
|
||||
}
|
||||
}
|
||||
|
||||
// Patch for bit order group unknown
|
||||
// Patch for bit order group unknown - remove when all Keri MS Bits maps are known
|
||||
// Reverse order for easy mapping for unknowns
|
||||
// I know that these bit groups are a in the correct location, unknown order.
|
||||
if (IDDecodeState[31-17] == '1') IDDecodeState[31-17] = '?';
|
||||
|
@ -115,38 +107,34 @@ static int CmdKeriMSScramble (KeriMSScramble_t Action, uint32_t *FC, uint32_t *I
|
|||
PrintAndLogEx(SUCCESS, "BitState ID : %s",IDDecodeState);
|
||||
PrintAndLogEx(SUCCESS, "BitState FC : %s",FCDecodeState);
|
||||
}
|
||||
|
||||
if (Action == Scramble)
|
||||
{
|
||||
// PrintAndLogEx(SUCCESS, "Scramble FC : %d - ID %d",*FC,*ID);
|
||||
*CardID = 0; // set to 0
|
||||
|
||||
for (CardIdx = 0; CardIdx < 32; CardIdx++)
|
||||
{
|
||||
// Card ID
|
||||
BitState = (*ID >> CardIdx) & 1;
|
||||
if (BitState) {
|
||||
idx = IDToCard[CardIdx];
|
||||
if ((idx >= 0) && (idx <= 32)) {
|
||||
*CardID |= (1 << idx);
|
||||
}
|
||||
}
|
||||
// FC
|
||||
BitState = (*FC >> CardIdx) & 1;
|
||||
if (BitState) {
|
||||
idx = FCToCard[CardIdx];
|
||||
if ((idx >= 0) && (idx <= 32)) {
|
||||
*CardID |= (1 << idx);
|
||||
}
|
||||
}
|
||||
if (CardToID[CardIdx] < 32) {
|
||||
if ((*ID & (1 << CardToID[CardIdx])) > 0)
|
||||
*CardID |= (1 << CardIdx);
|
||||
}
|
||||
// Card FC
|
||||
if (CardToFC[CardIdx] < 32) {
|
||||
if ((*ID & (1 << CardToFC[CardIdx])) > 0)
|
||||
*CardID |= (1 << CardIdx);
|
||||
}
|
||||
}
|
||||
// Fixed bits
|
||||
|
||||
// Fixed bits and parity/check bits
|
||||
/*
|
||||
Add Parity and Fixed bits
|
||||
Bit 3 - Note Used/Fixed 1
|
||||
Bit 31 - 1 Fixed
|
||||
Bit 3 - Note Used/Fixed 1 - TBC
|
||||
Bit 31 - 1 Fixed Not in check/parity
|
||||
Bit 0,1 - 2 Bit Parity
|
||||
*/
|
||||
*CardID |= (1 << 3);
|
||||
|
||||
// Check/Parity Bits
|
||||
int Parity = 1;
|
||||
for (CardIdx = 4; CardIdx <= 31; CardIdx += 2) {
|
||||
|
@ -156,7 +144,7 @@ static int CmdKeriMSScramble (KeriMSScramble_t Action, uint32_t *FC, uint32_t *I
|
|||
|
||||
// Bit 31 was fixed but not in check/parity bits
|
||||
*CardID |= (1 << 31);
|
||||
|
||||
|
||||
PrintAndLogEx(SUCCESS, "Scrambled FC : %d - Card ID : %d to RAW : E0000000%08X",*FC,*ID,*CardID);
|
||||
}
|
||||
return PM3_SUCCESS;
|
||||
|
@ -224,6 +212,7 @@ static int CmdKeriDemod(const char *Cmd) {
|
|||
|
||||
uint32_t testCard = 0;
|
||||
CmdKeriMSScramble (Scramble,&fc,&cardid,&testCard);
|
||||
|
||||
// End Descramble test
|
||||
|
||||
if (invert) {
|
||||
|
|
Loading…
Reference in a new issue