mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-08-20 05:13:46 -07:00
CHG: changed to use BigBuff_Eml memory instead of big_buff_malloc.
CHG: downloading eml memory from device should use uint's CHG: "hf legic read" has a different printing. It now prints 32bytes / row
This commit is contained in:
parent
44d9c722f0
commit
0b0b182fe2
4 changed files with 29 additions and 21 deletions
|
@ -72,7 +72,7 @@ static void setup_timer(void) {
|
||||||
#define RWD_TIME_1 120 // READER_TIME_PAUSE 20us off, 80us on = 100us 80 * 1.5 == 120ticks
|
#define RWD_TIME_1 120 // READER_TIME_PAUSE 20us off, 80us on = 100us 80 * 1.5 == 120ticks
|
||||||
#define RWD_TIME_0 60 // READER_TIME_PAUSE 20us off, 40us on = 60us 40 * 1.5 == 60ticks
|
#define RWD_TIME_0 60 // READER_TIME_PAUSE 20us off, 40us on = 60us 40 * 1.5 == 60ticks
|
||||||
#define RWD_TIME_PAUSE 30 // 20us == 20 * 1.5 == 30ticks */
|
#define RWD_TIME_PAUSE 30 // 20us == 20 * 1.5 == 30ticks */
|
||||||
#define TAG_BIT_PERIOD 142 // 100us == 100 * 1.5 == 150ticks
|
#define TAG_BIT_PERIOD 144 // 100us == 100 * 1.5 == 150ticks
|
||||||
#define TAG_FRAME_WAIT 495 // 330us from READER frame end to TAG frame start. 330 * 1.5 == 495
|
#define TAG_FRAME_WAIT 495 // 330us from READER frame end to TAG frame start. 330 * 1.5 == 495
|
||||||
|
|
||||||
#define RWD_TIME_FUZZ 20 // rather generous 13us, since the peak detector + hysteresis fuzz quite a bit
|
#define RWD_TIME_FUZZ 20 // rather generous 13us, since the peak detector + hysteresis fuzz quite a bit
|
||||||
|
@ -279,13 +279,9 @@ static void frame_receiveAsReader(struct legic_frame * const f, uint8_t bits) {
|
||||||
|
|
||||||
//FIXED time between sending frame and now listening frame. 330us
|
//FIXED time between sending frame and now listening frame. 330us
|
||||||
uint32_t starttime = GET_TICKS;
|
uint32_t starttime = GET_TICKS;
|
||||||
//if ( bits == 6 || bits == 7) {
|
|
||||||
// its about 9+9 ticks delay from end-send to here.
|
// its about 9+9 ticks delay from end-send to here.
|
||||||
//WaitTicks( 495 - 9 - 9 );
|
//WaitTicks( 495 - 9 - 9 );
|
||||||
WaitTicks( 477 );
|
WaitTicks( 477 );
|
||||||
//} else {
|
|
||||||
// WaitTicks( 477 );
|
|
||||||
// }
|
|
||||||
|
|
||||||
next_bit_at = GET_TICKS + TAG_BIT_PERIOD;
|
next_bit_at = GET_TICKS + TAG_BIT_PERIOD;
|
||||||
|
|
||||||
|
@ -324,7 +320,7 @@ static uint32_t setup_phase_reader(uint8_t iv) {
|
||||||
|
|
||||||
// Switch on carrier and let the tag charge for 1ms
|
// Switch on carrier and let the tag charge for 1ms
|
||||||
HIGH(GPIO_SSC_DOUT);
|
HIGH(GPIO_SSC_DOUT);
|
||||||
WaitUS(1000);
|
WaitUS(2000);
|
||||||
|
|
||||||
ResetTicks();
|
ResetTicks();
|
||||||
|
|
||||||
|
@ -370,7 +366,7 @@ static void LegicCommonInit(void) {
|
||||||
AT91C_BASE_PIOA->PIO_PER = GPIO_SSC_DOUT;
|
AT91C_BASE_PIOA->PIO_PER = GPIO_SSC_DOUT;
|
||||||
|
|
||||||
// reserve a cardmem, meaning we can use the tracelog function in bigbuff easier.
|
// reserve a cardmem, meaning we can use the tracelog function in bigbuff easier.
|
||||||
cardmem = BigBuf_malloc(LEGIC_CARD_MEMSIZE);
|
cardmem = BigBuf_get_EM_addr();
|
||||||
memset(cardmem, 0x00, LEGIC_CARD_MEMSIZE);
|
memset(cardmem, 0x00, LEGIC_CARD_MEMSIZE);
|
||||||
|
|
||||||
clear_trace();
|
clear_trace();
|
||||||
|
@ -402,7 +398,6 @@ int legic_read_byte( uint16_t index, uint8_t cmd_sz) {
|
||||||
|
|
||||||
//WaitTicks(366);
|
//WaitTicks(366);
|
||||||
WaitTicks(330);
|
WaitTicks(330);
|
||||||
//WaitTicks(50);
|
|
||||||
|
|
||||||
frame_sendAsReader(cmd, cmd_sz);
|
frame_sendAsReader(cmd, cmd_sz);
|
||||||
frame_receiveAsReader(¤t_frame, 12);
|
frame_receiveAsReader(¤t_frame, 12);
|
||||||
|
@ -457,7 +452,7 @@ int legic_write_byte(uint8_t byte, uint16_t addr, uint8_t addr_sz) {
|
||||||
|
|
||||||
frame_sendAsReader(cmd, cmd_sz);
|
frame_sendAsReader(cmd, cmd_sz);
|
||||||
|
|
||||||
// wllm-rbnt doesnt have these
|
|
||||||
AT91C_BASE_PIOA->PIO_ODR = GPIO_SSC_DIN;
|
AT91C_BASE_PIOA->PIO_ODR = GPIO_SSC_DIN;
|
||||||
AT91C_BASE_PIOA->PIO_PER = GPIO_SSC_DIN;
|
AT91C_BASE_PIOA->PIO_PER = GPIO_SSC_DIN;
|
||||||
|
|
||||||
|
@ -471,13 +466,13 @@ int legic_write_byte(uint8_t byte, uint16_t addr, uint8_t addr_sz) {
|
||||||
edges = 0;
|
edges = 0;
|
||||||
next_bit_at += TAG_BIT_PERIOD;
|
next_bit_at += TAG_BIT_PERIOD;
|
||||||
while(timer->TC_CV < next_bit_at) {
|
while(timer->TC_CV < next_bit_at) {
|
||||||
int level = (AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_DIN);
|
volatile uint32_t level = (AT91C_BASE_PIOA->PIO_PDSR & GPIO_SSC_DIN);
|
||||||
if(level != old_level)
|
if(level != old_level)
|
||||||
edges++;
|
edges++;
|
||||||
|
|
||||||
old_level = level;
|
old_level = level;
|
||||||
}
|
}
|
||||||
if(edges > 20 && edges < 60) { /* expected are 42 edges */
|
if(edges > 20 ) { /* expected are 42 edges */
|
||||||
int t = timer->TC_CV;
|
int t = timer->TC_CV;
|
||||||
int c = t / TAG_BIT_PERIOD;
|
int c = t / TAG_BIT_PERIOD;
|
||||||
|
|
||||||
|
@ -618,6 +613,7 @@ void LegicRfWriter(uint16_t offset, uint16_t bytes, uint8_t iv) {
|
||||||
|
|
||||||
LED_B_ON();
|
LED_B_ON();
|
||||||
setup_phase_reader(iv);
|
setup_phase_reader(iv);
|
||||||
|
|
||||||
int r = 0;
|
int r = 0;
|
||||||
while(byte_index < bytes) {
|
while(byte_index < bytes) {
|
||||||
|
|
||||||
|
|
|
@ -414,7 +414,7 @@ int CmdLegicRFRead(const char *Cmd) {
|
||||||
PrintAndLog("LSB of IV must be SET");
|
PrintAndLog("LSB of IV must be SET");
|
||||||
}
|
}
|
||||||
|
|
||||||
//PrintAndLog("Using IV: 0x%02x | Offset: 0x%02x | Len: 0x%02x ", IV, offset, len);
|
//PrintAndLog("Using IV: 0x%02x", IV);
|
||||||
|
|
||||||
UsbCommand c = {CMD_READER_LEGIC_RF, {offset, len, IV}};
|
UsbCommand c = {CMD_READER_LEGIC_RF, {offset, len, IV}};
|
||||||
clearCommandBuffer();
|
clearCommandBuffer();
|
||||||
|
@ -424,12 +424,24 @@ int CmdLegicRFRead(const char *Cmd) {
|
||||||
uint8_t isOK = resp.arg[0] & 0xFF;
|
uint8_t isOK = resp.arg[0] & 0xFF;
|
||||||
uint16_t len = resp.arg[1] & 0x3FF;
|
uint16_t len = resp.arg[1] & 0x3FF;
|
||||||
if ( isOK ) {
|
if ( isOK ) {
|
||||||
PrintAndLog("use 'hf legic decode'");
|
|
||||||
|
|
||||||
uint8_t *data = resp.d.asBytes;
|
uint8_t *data = malloc(len);
|
||||||
PrintAndLog("\nData |");
|
if ( !data ){
|
||||||
|
PrintAndLog("Cannot allocate memory");
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
// copy data from device
|
||||||
|
GetEMLFromBigBuf(data, len, 0);
|
||||||
|
if ( !WaitForResponseTimeout(CMD_ACK, NULL, 2000)){
|
||||||
|
PrintAndLog("Command execute timeout");
|
||||||
|
if ( data )
|
||||||
|
free(data);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
PrintAndLog("\nData");
|
||||||
PrintAndLog("-----------------------------");
|
PrintAndLog("-----------------------------");
|
||||||
PrintAndLog(" %s|\n", sprint_hex(data, len));
|
print_hex_break( data, len, 32);
|
||||||
} else {
|
} else {
|
||||||
PrintAndLog("failed reading tag");
|
PrintAndLog("failed reading tag");
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ void GetFromBigBuf(uint8_t *dest, int bytes, int start_index) {
|
||||||
clearCommandBuffer();
|
clearCommandBuffer();
|
||||||
SendCommand(&c);
|
SendCommand(&c);
|
||||||
}
|
}
|
||||||
void GetEMLFromBigBuf(uint8_t *dest, int bytes, int start_index) {
|
void GetEMLFromBigBuf(uint8_t *dest, uint32_t bytes, uint32_t start_index) {
|
||||||
sample_buf = dest;
|
sample_buf = dest;
|
||||||
UsbCommand c = {CMD_DOWNLOAD_EML_BIGBUF, {start_index, bytes, 0}};
|
UsbCommand c = {CMD_DOWNLOAD_EML_BIGBUF, {start_index, bytes, 0}};
|
||||||
clearCommandBuffer();
|
clearCommandBuffer();
|
||||||
|
|
|
@ -14,5 +14,5 @@
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
extern uint8_t* sample_buf;
|
extern uint8_t* sample_buf;
|
||||||
void GetFromBigBuf(uint8_t *dest, int bytes, int start_index);
|
void GetFromBigBuf(uint8_t *dest, int bytes, int start_index);
|
||||||
void GetEMLFromBigBuf(uint8_t *dest, int bytes, int start_index);
|
void GetEMLFromBigBuf(uint8_t *dest, uint32_t bytes, uint32_t start_index);
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue