+int CmdAWIDBrute(const char *Cmd){
+
+ uint32_t fc = 0, delay = 1000;
+ uint8_t fmtlen = 0;
+ uint8_t bits[96];
+ uint8_t *bs = bits;
+ size_t size = sizeof(bits);
+ memset(bs, 0x00, size);
+
+ char cmdp = param_getchar(Cmd, 0);
+ if (strlen(Cmd) == 0 || cmdp == 'h' || cmdp == 'H') return usage_lf_awid_brute();
+
+ fmtlen = param_get8(Cmd, 0);
+ fc = param_get32ex(Cmd, 1, 0, 10);
+ if ( !fc ) return usage_lf_awid_brute();
+
+ // delay between attemps, defaults to 1000ms.
+ delay = param_get32ex(Cmd, 2, 1000, 10);
+
+ switch(fmtlen) {
+ case 50:
+ if ((fc & 0xFFFF) != fc) {
+ fc &= 0xFFFF;
+ PrintAndLog("Facility-Code Truncated to 16-bits (AWID50): %u", fc);
+ }
+ break;
+ default:
+ if ((fc & 0xFF) != fc) {
+ fc &= 0xFF;
+ PrintAndLog("Facility-Code Truncated to 8-bits (AWID26): %u", fc);
+ }
+ break;
+ }
+
+ PrintAndLog("Bruteforceing AWID %d Reader", fmtlen);
+ PrintAndLog("Press pm3-button to abort simulation or press key");
+
+ uint64_t arg1 = (10<<8) + 8; // fcHigh = 10, fcLow = 8
+ uint64_t arg2 = 50; // clk RF/50 invert=0
+ UsbCommand c = {CMD_FSK_SIM_TAG, {arg1, arg2, size}};
+
+ for ( uint16_t cn = 1; cn < 0xFFFF; ++cn){
+
+ if (ukbhit()) {
+ UsbCommand resp;
+ UsbCommand ping = {CMD_PING};
+ clearCommandBuffer();
+ SendCommand(&ping);
+ if (WaitForResponseTimeout(CMD_ACK, &resp, 1000)) {
+ PrintAndLog("aborted via keyboard!");
+ return 0;
+ }
+ PrintAndLog("Device didnt respond to ABORT");
+ return 1;
+ }
+
+ PrintAndLog("Trying FC: %u; CN: %u", fc, cn);
+ if ( !getAWIDBits(fmtlen, fc, cn, bs)) {
+ PrintAndLog("Error with tag bitstream generation.");
+ return 1;
+ }
+ memcpy(c.d.asBytes, bs, size);
+ clearCommandBuffer();
+ SendCommand(&c);
+
+ msleep(delay);
+ }
+ return 0;
+}
+