- if ( index == USB_CMD_DATA_SIZE ){
-// PrintAndLog("sent %d | %d | %d", index, offset, totalbytes);
- UsbCommand c = { CMD_DOWNLOADED_SIM_SAMPLES_125K, {offset, 0, 0}};
- memcpy(c.d.asBytes, data, sizeof(data));
- clearCommandBuffer();
- SendCommand(&c);
- if ( !WaitForResponseTimeout(CMD_ACK, NULL, 1500)){
- PrintAndLog("Command execute timeout");
- fclose(f);
- return 1;
- }
- offset += index;
- totalbytes += index;
- index = 0;
- }
- }
- fclose(f);
-
- // left over bytes?
- if ( index != 0 ) {
- UsbCommand c = { CMD_DOWNLOADED_SIM_SAMPLES_125K, {offset, 0, 0}};
- memcpy(c.d.asBytes, data, 8);
- clearCommandBuffer();
- SendCommand(&c);
- if ( !WaitForResponseTimeout(CMD_ACK, NULL, 1500)){
- PrintAndLog("Command execute timeout");
- return 1;
- }
- totalbytes += index;
- }
-
- PrintAndLog("loaded %u samples", totalbytes);
- return 0;
-}
-
-// Save, filename, num of bytes, starting offset. (in decimal)
-// ie: "hf legic save nnn.txt 100 0 (saves the first 100bytes)
-// (ascii hex textfile)
-int CmdLegicSave(const char *Cmd) {
- int requested = 1024;
- int offset = 0;
- int delivered = 0;
- char filename[FILE_PATH_SIZE] = {0x00};
- uint8_t got[1024] = {0x00};
-
- memset(filename, 0, FILE_PATH_SIZE);
-
- sscanf(Cmd, " %s %i %i", filename, &requested, &offset);
-
- /* If no length given save entire legic read buffer */
- /* round up to nearest 8 bytes so the saved data can be used with legicload */
- if (requested == 0)
- requested = 1024;
-
- if (requested % 8 != 0) {
- int remainder = requested % 8;
- requested = requested + 8 - remainder;
- }
-
- if (offset + requested > sizeof(got)) {
- PrintAndLog("Tried to read past end of buffer, <bytes> + <offset> > 1024");
- return 0;
- }
-
- GetFromBigBuf(got, requested, offset);
- if ( !WaitForResponseTimeout(CMD_ACK, NULL, 2000)){
- PrintAndLog("Command execute timeout");