diff options
author | fishsoupisgood <github@madingley.org> | 2020-10-27 09:21:24 +0000 |
---|---|---|
committer | fishsoupisgood <github@madingley.org> | 2020-10-27 09:21:24 +0000 |
commit | 59415c62777983cbc8a1096266149fb8f18e94a9 (patch) | |
tree | 138d39042a9a0bf04fefd5fd0640ae023d6382d4 | |
parent | b11ae5cf86000bfce35b6ec511014d8f6b04416e (diff) | |
download | galaxy_sia-59415c62777983cbc8a1096266149fb8f18e94a9.tar.gz galaxy_sia-59415c62777983cbc8a1096266149fb8f18e94a9.tar.bz2 galaxy_sia-59415c62777983cbc8a1096266149fb8f18e94a9.zip |
fix checksum alg, add better debug
-rw-r--r-- | keypad.c | 99 | ||||
-rw-r--r-- | util.c | 4 |
2 files changed, 73 insertions, 30 deletions
@@ -6,6 +6,7 @@ #include <sys/types.h> #include <sys/socket.h> #include <ncurses.h> +#include <stdarg.h> #include "util.h" @@ -44,7 +45,7 @@ #define GD_LCD_LINE_LEN 16 -#define GD_TIMEOUT 2 +#define GD_TIMEOUT 10 // Packets are // AA FN D0 D1 D2 CK @@ -70,6 +71,29 @@ typedef struct { } GD_LCD; +WINDOW *win, *dwin = NULL; +FILE *dfile = NULL; + + +void debug_print (const char *fmt, ...) +{ + + va_list va; + + if (dwin) { + va_start (va, fmt); + vw_printw (dwin, fmt, va); + va_end (va); + } + + if (dfile) { + va_start (va, fmt); + vfprintf (dfile, fmt, va); + va_end (va); + } +} + + static void endecode (unsigned char *p, size_t l) { @@ -83,22 +107,23 @@ static void endecode (unsigned char *p, size_t l) static unsigned char checksum (unsigned char *p, size_t l) { unsigned s = 0; - unsigned char q; + unsigned r = 0; unsigned i; for (i = 0; i < l; ++i) s += p[i]; s += 0xaa; - q = s & 0xff; - q += (s >> 8); - q += (s >> 16); - - return q; -} - + while (s > 0xff) { + r = s & 0xff; + r += (s >> 8); + r += (s >> 16); + s = r; + } + return s; +} void hexdump_pkt (const char *prefix, GD_PKT *p) @@ -108,37 +133,37 @@ void hexdump_pkt (const char *prefix, GD_PKT *p) size_t l = p->data_len + 2; for (i = 0; i < l; i += 16) { - fprintf (stderr, "%s %04x ", prefix, i); + debug_print ("%s %04x ", prefix, i); for (j = 0; j < 16; ++j) { k = i + j; if (k < l) - fprintf (stderr, " %02x", d[k]); + debug_print (" %02x", d[k]); else - fprintf (stderr, " "); + debug_print (" "); - if (j == 7) fprintf (stderr, " "); + if (j == 7) debug_print (" "); } - fprintf (stderr, " "); + debug_print (" "); for (j = 0; j < 16; ++j) { k = i + j; if (k < l) { if ((d[k] > 32) && (d[k] < 127)) - fprintf (stderr, "%c", d[k]); + debug_print ("%c", d[k]); else - fprintf (stderr, "."); + debug_print ("."); } else - fprintf (stderr, " "); + debug_print (" "); - if (j == 7) fprintf (stderr, " "); + if (j == 7) debug_print (" "); } - fprintf (stderr, "\n"); + debug_print ("\n"); } } @@ -148,7 +173,7 @@ int send_pkt (int fd, GD_PKT *tx) unsigned char buf[GD_MAX_PKT_LEN]; size_t len = tx->data_len + 2; - //hexdump_pkt (" >", tx); + hexdump_pkt (" >", tx); memcpy (buf, tx->pkt, len); endecode (buf, len); @@ -177,12 +202,19 @@ int recv_pkt (int fd, GD_PKT *rx, int timeout) sum = checksum (rx->pkt, len) ; - if (rx->pkt[len] != sum) return -1; + if (rx->pkt[len] != sum) { + rx->data_len = len - 1; + + hexdump_pkt ("!<", rx); + debug_print ("Bad checksum expected %02x got %02x\n", sum, rx->pkt[len]); + + return -1; + } endecode (rx->pkt, len); rx->data_len = len - 2; - //hexdump_pkt (" <", rx); + hexdump_pkt (" <", rx); return 1; @@ -297,8 +329,8 @@ void gd_to_ascii (unsigned char *c, size_t l) for (; l; l--, c++) { if (*c == 0xdb) *c = '+'; - - if (*c == 0xb0) *c = '-'; + else if (*c == 0xb0) *c = '-'; + else if ((*c > 126) || (*c < 32)) *c = '?'; } } @@ -520,7 +552,6 @@ int gd_init (int fd) return 0; } -WINDOW *win; void curses_init (void) { @@ -558,6 +589,15 @@ void curses_init (void) wrefresh (win); timeout (0); + dwin = newwin (20, 80, 16, 0); + box (dwin, 0, 0); + dwin = newwin (18, 78, 17, 1); + scrollok (dwin, TRUE); + wrefresh (dwin); + timeout (0); + + + } @@ -584,6 +624,8 @@ int gd_keypad (int fd) GD_LCD l; int ch; +// dfile = fopen ("log", "w"); + if (gd_init (fd)) { printf ("Failed to init comms with panel\n"); return -1; @@ -595,15 +637,16 @@ int gd_keypad (int fd) while ((ch = getch()) != 'q') { - gd_fn_poll (fd, &l); - curses_show (&l); - if (ch == KEY_LEFT) ch = 'a'; if (ch == KEY_RIGHT) ch = 'b'; if (ch != ERR && !gd_fn_key_press (fd, ch, &l)) curses_show (&l); + else { + gd_fn_poll (fd, &l); + curses_show (&l); + } } @@ -52,8 +52,8 @@ ssize_t read_with_timeout (int fd, void *_b, size_t len, unsigned timeout) fd_set rfds; ssize_t red, ret = 0; - tv.tv_sec = timeout / 10; - tv.tv_usec = (timeout % 10) * 100000; + tv.tv_sec = timeout / 100; + tv.tv_usec = (timeout % 100) * 10000; while (tv.tv_sec || tv.tv_usec) { FD_ZERO (&rfds); |