#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_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 RWD_TIME_FUZZ 20 // rather generous 13us, since the peak detector + hysteresis fuzz quite a bit
//FIXED time between sending frame and now listening frame. 330us
uint32_t starttime = GET_TICKS;
- //if ( bits == 6 || bits == 7) {
- // its about 9+9 ticks delay from end-send to here.
- //WaitTicks( 495 - 9 - 9 );
- WaitTicks( 477 );
- //} else {
-// WaitTicks( 477 );
-// }
+ // its about 9+9 ticks delay from end-send to here.
+ //WaitTicks( 495 - 9 - 9 );
+ WaitTicks( 477 );
next_bit_at = GET_TICKS + TAG_BIT_PERIOD;
// Switch on carrier and let the tag charge for 1ms
HIGH(GPIO_SSC_DOUT);
- WaitUS(1000);
+ WaitUS(2000);
ResetTicks();
AT91C_BASE_PIOA->PIO_PER = GPIO_SSC_DOUT;
// 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);
clear_trace();
//WaitTicks(366);
WaitTicks(330);
- //WaitTicks(50);
frame_sendAsReader(cmd, cmd_sz);
frame_receiveAsReader(¤t_frame, 12);
frame_sendAsReader(cmd, cmd_sz);
- // wllm-rbnt doesnt have these
+
AT91C_BASE_PIOA->PIO_ODR = GPIO_SSC_DIN;
AT91C_BASE_PIOA->PIO_PER = GPIO_SSC_DIN;
edges = 0;
next_bit_at += TAG_BIT_PERIOD;
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)
edges++;
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 c = t / TAG_BIT_PERIOD;
LED_B_ON();
setup_phase_reader(iv);
+
int r = 0;
while(byte_index < bytes) {
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}};
clearCommandBuffer();
uint8_t isOK = resp.arg[0] & 0xFF;
uint16_t len = resp.arg[1] & 0x3FF;
if ( isOK ) {
- PrintAndLog("use 'hf legic decode'");
- uint8_t *data = resp.d.asBytes;
- PrintAndLog("\nData |");
+ uint8_t *data = malloc(len);
+ 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(" %s|\n", sprint_hex(data, len));
+ print_hex_break( data, len, 32);
} else {
PrintAndLog("failed reading tag");
}