X-Git-Url: http://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/7fe9b0b742d7dae9c5af1d292d11840b5c3cbfae..f397b5cc874ac7d658173199d92c30f3f717a300:/client/cmdmain.c diff --git a/client/cmdmain.c b/client/cmdmain.c index 322e5806..8f4618c9 100644 --- a/client/cmdmain.c +++ b/client/cmdmain.c @@ -1,7 +1,18 @@ +//----------------------------------------------------------------------------- +// Copyright (C) 2010 iZsh +// +// This code is licensed to you under the terms of the GNU GPL, version 2 or, +// at your option, any later version. See the LICENSE.txt file for the text of +// the license. +//----------------------------------------------------------------------------- +// Main command parser entry point +//----------------------------------------------------------------------------- + #include #include #include #include +#include "sleep.h" #include "cmdparser.h" #include "data.h" #include "usb_cmd.h" @@ -14,18 +25,20 @@ unsigned int current_command = CMD_UNKNOWN; unsigned int received_command = CMD_UNKNOWN; +UsbCommand current_response; +UsbCommand current_response_user; static int CmdHelp(const char *Cmd); static int CmdQuit(const char *Cmd); static command_t CommandTable[] = { - {"help", CmdHelp, 1, "This help"}, - {"data", CmdData, 1, "Plot window / data buffer manipulation"}, + {"help", CmdHelp, 1, "This help. Use ' help' for details of the following commands:\n"}, + {"data", CmdData, 1, "{ Plot window / data buffer manipulation... }"}, {"exit", CmdQuit, 1, "Exit program"}, - {"hf", CmdHF, 1, "HF commands"}, - {"hw", CmdHW, 1, "Hardware commands"}, - {"lf", CmdLF, 1, "LF commands"}, + {"hf", CmdHF, 1, "{ HF commands... }"}, + {"hw", CmdHW, 1, "{ Hardware commands... }"}, + {"lf", CmdLF, 1, "{ LF commands... }"}, {"quit", CmdQuit, 1, "Quit program"}, {NULL, NULL, 0, NULL} }; @@ -42,19 +55,29 @@ int CmdQuit(const char *Cmd) return 0; } -void WaitForResponse(uint32_t response_type) +UsbCommand * WaitForResponseTimeout(uint32_t response_type, uint32_t ms_timeout) { + UsbCommand * ret = NULL; + int i=0; + + for(i=0; received_command != response_type && i < ms_timeout / 10; i++) { + msleep(10); // XXX ugh + } + + // There was an evil BUG + memcpy(¤t_response_user, ¤t_response, sizeof(UsbCommand)); + ret = ¤t_response_user; + + if(received_command != response_type) + ret = NULL; + + received_command = CMD_UNKNOWN; + + return ret; +} + +UsbCommand * WaitForResponse(uint32_t response_type) { - while (received_command != response_type) { -#ifdef WIN32 - UsbCommand c; - if (ReceiveCommandPoll(&c)) - UsbCommandReceived(&c); - Sleep(0); -#else - usleep(10000); // XXX ugh -#endif - } - received_command = CMD_UNKNOWN; + return WaitForResponseTimeout(response_type, -1); } //----------------------------------------------------------------------------- @@ -125,6 +148,7 @@ void UsbCommandReceived(UsbCommand *UC) for(i=0; i<48; i++) sample_buf[i] = UC->d.asBytes[i]; received_command = UC->cmd; return; + case CMD_ACQUIRE_RAW_ADC_SAMPLES_125K: case CMD_DOWNLOADED_SIM_SAMPLES_125K: if (UC->cmd != CMD_ACK) goto unexpected_response; // got ACK @@ -132,7 +156,11 @@ void UsbCommandReceived(UsbCommand *UC) return; default: unexpected_response: - PrintAndLog("unrecognized command %08x\n", UC->cmd); - break; + + if(UC->cmd != CMD_ACK) + PrintAndLog("unrecognized command %08x\n", UC->cmd); + else + memcpy(¤t_response, UC, sizeof(UsbCommand)); + received_command = UC->cmd; } -} \ No newline at end of file +}