X-Git-Url: http://cvs.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/902cb3c00b49535f0de9a3b6d5ba0c54260ccac1..c00f0dbfda703611c4373ce5cbbff772c8942de1:/client/proxmark3.c diff --git a/client/proxmark3.c b/client/proxmark3.c index cff94903..a6274bc1 100644 --- a/client/proxmark3.c +++ b/client/proxmark3.c @@ -21,18 +21,25 @@ #include "proxgui.h" #include "cmdmain.h" #include "uart.h" -#include "messages.h" #include "ui.h" +#include "sleep.h" static serial_port sp; +static UsbCommand txcmd; +static volatile bool txcmd_pending = false; void SendCommand(UsbCommand *c) { #if 0 printf("Sending %d bytes\n", sizeof(UsbCommand)); #endif - if (!uart_send(sp,(byte_t*)c,sizeof(UsbCommand))) { - ERR("Sending bytes to proxmark failed"); +/* + if (txcmd_pending) { + ERR("Sending command failed, previous command is still pending"); } +*/ + while(txcmd_pending); + txcmd = *c; + txcmd_pending = true; } struct receiver_arg { @@ -60,6 +67,7 @@ struct main_loop_arg { //} byte_t rx[0x1000000]; +byte_t* prx = rx; static void *uart_receiver(void *targ) { struct receiver_arg *arg = (struct receiver_arg*)targ; @@ -67,24 +75,32 @@ static void *uart_receiver(void *targ) { size_t cmd_count; while (arg->run) { - if (uart_receive(sp,rx,&rxlen)) { - if ((rxlen % sizeof(UsbCommand)) != 0) { - PrintAndLog("ERROR: received %zd bytes, which does not seem to be one or more command(s)\n",rxlen); + rxlen = sizeof(UsbCommand); + if (uart_receive(sp,prx,&rxlen)) { + prx += rxlen; + if (((prx-rx) % sizeof(UsbCommand)) != 0) { continue; } - cmd_count = rxlen / sizeof(UsbCommand); -// printf("received %zd bytes, which represents %zd commands\n",rxlen, cmd_count); + cmd_count = (prx-rx) / sizeof(UsbCommand); + // printf("received %d bytes, which represents %d commands\n",(prx-rx), cmd_count); for (size_t i=0; i\n\n",argv[0]); + printf("\tLinux example:'%s /dev/ttyACM0'\n\n", argv[0]); return 1; } @@ -204,11 +222,16 @@ int main(int argc, char* argv[]) { offline = 0; } */ + sp = uart_open(argv[1]); if (sp == INVALID_SERIAL_PORT) { printf("ERROR: invalid serial port\n"); marg.usb_present = 0; offline = 1; + } else if (sp == CLAIMED_SERIAL_PORT) { + printf("ERROR: serial port is claimed by another process\n"); + marg.usb_present = 0; + offline = 1; } else { marg.usb_present = 1; offline = 0;