X-Git-Url: https://git.realraum.at/?p=svn42.git;a=blobdiff_plain;f=rf433rcv%2Fpc%2Frawhid_test.c;h=cd94bdbbce830de1d478d3cbc460eee22fa232c2;hp=eaef389ff30aa771ea785395b334aa13431739c2;hb=5b00dab1a7d2ac2d8a593f0bd6e85a7194e2c9bd;hpb=f505a1c37ea1c76897991f9882de765e34f0cc98 diff --git a/rf433rcv/pc/rawhid_test.c b/rf433rcv/pc/rawhid_test.c index eaef389..cd94bdb 100644 --- a/rf433rcv/pc/rawhid_test.c +++ b/rf433rcv/pc/rawhid_test.c @@ -2,7 +2,7 @@ #include #include #include - +#include #if defined(OS_LINUX) || defined(OS_MACOSX) #include #include @@ -13,17 +13,22 @@ #include "hid.h" -static char get_keystroke(void); - void sendstr(char * tosend) { - rawhid_send(0, tosend, strlen(tosend),100); + rawhid_send(0, tosend, strlen(tosend),1000); +} + +int mtime_diff(struct timeval high,struct timeval low) +{ + int result=1000*(high.tv_sec-low.tv_sec); + result+=high.tv_usec/1000-low.tv_usec/1000; + return result; } int main (int argc, char *argv[]) { int i, r, num; - char c, buf[64]; + char buf[64]; // C-based example is 16C0:0480:FFAB:0200 r = rawhid_open(1, 0x16C0, 0x0480, 0xFFAB, 0x0200); if (r <= 0) { @@ -38,15 +43,27 @@ int main (int argc, char *argv[]) if (argc>1) { FILE * f = fopen (argv[1], "r"); + if (strcmp("-",argv[1]) == 0) + f = stdin; if (!f) return -3; + printf("Clearing Buffer\n"); sendstr("c"); // clear the buffer - buf[0]='f'; - size_t len= fread(buf+1, 1, 63, f); - for(i=len+1;i<64;i++) - buf[i]=0xff; - rawhid_send(0, buf, 64, 100); //fill the buffer - sendstr("s\x10"); // send 4 times + buf[0]='f'; + size_t len; + while ( ( len = fread(buf+1, 1, 63, f) ) ) + { + + rawhid_send(0, buf, 64, 1000); //fill the buffer + printf("Sending Buffer %d bytes\n",len); + for(i=0;i= 32) { - printf("\ngot key '%c', sending...\n", c); - buf[0] = c; - for (i=1; i<64; i++) { - buf[i] = 0; - } - rawhid_send(0, buf, 64, 100); - } + gettimeofday(&stop_time,NULL); } + sendstr("e"); + return 0; } } - -#if defined(OS_LINUX) || defined(OS_MACOSX) -// Linux (POSIX) implementation of _kbhit(). -// Morgan McGuire, morgan@cs.brown.edu -static int _kbhit() { - static const int STDIN = 0; - static int initialized = 0; - int bytesWaiting; - - if (!initialized) { - // Use termios to turn off line buffering - struct termios term; - tcgetattr(STDIN, &term); - term.c_lflag &= ~ICANON; - tcsetattr(STDIN, TCSANOW, &term); - setbuf(stdin, NULL); - initialized = 1; - } - ioctl(STDIN, FIONREAD, &bytesWaiting); - return bytesWaiting; -} -static char _getch(void) { - char c; - if (fread(&c, 1, 1, stdin) < 1) return 0; - return c; -} -#endif - - -static char get_keystroke(void) -{ - if (_kbhit()) { - char c = _getch(); - if (c >= 32) return c; - } - return 0; -} - -