'fix' ao-eeprom to read two blocks at once. Work around kernel bugs.
authorKeith Packard <keithp@keithp.com>
Fri, 4 Sep 2009 22:01:32 +0000 (15:01 -0700)
committerKeith Packard <keithp@keithp.com>
Fri, 4 Sep 2009 22:01:32 +0000 (15:01 -0700)
The kernel appears to leave serial data undelivered at times. Reading
two blocks at once appears to make it relinquish the queued data.

Signed-off-by: Keith Packard <keithp@keithp.com>
ao-tools/Makefile.am
ao-tools/ao-eeprom/ao-eeprom.c
ao-tools/lib/cc-usb.c
ao-tools/lib/cc-usb.h

index 02b4785e52c0215027e4c8645e190a12d917e479..28e77b08ab7943214f5c0e6a1de36ea8a41ad86b 100644 (file)
@@ -1 +1 @@
-SUBDIRS=lib ao-rawload ao-dbg ao-bitbang ao-eeprom ao-load ao-view
+SUBDIRS=lib ao-rawload ao-dbg ao-bitbang ao-eeprom ao-list ao-load ao-view
index 726cc22cafd0e0c1a8becbe4ef52ab03c5e1b547..b865e298d2e01b6a499c6a7e270e46a682d31e2b 100644 (file)
 #include <unistd.h>
 #include <getopt.h>
 #include "cc-usb.h"
+#include "cc.h"
 
 #define NUM_BLOCK      512
 
 static const struct option options[] = {
        { .name = "tty", .has_arg = 1, .val = 'T' },
+       { .name = "device", .has_arg = 1, .val = 'D' },
        { 0, 0, 0, 0},
 };
 
 static void usage(char *program)
 {
-       fprintf(stderr, "usage: %s [--tty <tty-name>]\n", program);
+       fprintf(stderr, "usage: %s [--tty <tty-name>] [--device <device-name>\n", program);
        exit(1);
 }
 
@@ -40,23 +42,29 @@ main (int argc, char **argv)
 {
        struct cc_usb   *cc;
        int             block;
-       uint8_t         bytes[32 * (2 + 8)];
+       uint8_t         bytes[2 * 32 * (2 + 8)];
        uint8_t         *b;
        int             i, j;
        uint32_t        addr;
        char            *tty = NULL;
+       char            *device = NULL;
        int             c;
 
-       while ((c = getopt_long(argc, argv, "T:", options, NULL)) != -1) {
+       while ((c = getopt_long(argc, argv, "T:D:", options, NULL)) != -1) {
                switch (c) {
                case 'T':
                        tty = optarg;
                        break;
+               case 'D':
+                       device = optarg;
+                       break;
                default:
                        usage(argv[0]);
                        break;
                }
        }
+       if (!tty)
+               tty = cc_usbdevs_find_by_arg(device, "TeleMetrum");
        if (!tty)
                tty = getenv("ALTOS_TTY");
        if (!tty)
@@ -64,11 +72,11 @@ main (int argc, char **argv)
        cc = cc_usb_open(tty);
        if (!cc)
                exit(1);
-       for (block = 0; block < NUM_BLOCK; block++) {
+       for (block = 0; block < NUM_BLOCK; block += 2) {
                cc_queue_read(cc, bytes, sizeof (bytes));
-               cc_usb_printf(cc, "e %x\n", block);
+               cc_usb_printf(cc, "e %x\ne %x\n", block, block + 1);
                cc_usb_sync(cc);
-               for (i = 0; i < 32; i++) {
+               for (i = 0; i < 32 * 2; i++) {
                        b = bytes + (i * 10);
                        addr = block * 256 + i * 8;
                        printf ("%06x", addr);
index 81309983fd46b7487aaba7cabc005051373322be..17f059117477994458e3296adfb5d9b2ac1be65b 100644 (file)
@@ -157,7 +157,8 @@ cc_usb_dbg(int indent, uint8_t *bytes, int len)
 /*
  * Flush pending writes, fill pending reads
  */
-void
+
+int
 cc_usb_sync(struct cc_usb *cc)
 {
        int             ret;
@@ -167,7 +168,7 @@ cc_usb_sync(struct cc_usb *cc)
        fds.fd = cc->fd;
        for (;;) {
                if (cc->read_count || cc->out_count)
-                       timeout = -1;
+                       timeout = 5000;
                else
                        timeout = 0;
                fds.events = 0;
@@ -176,8 +177,13 @@ cc_usb_sync(struct cc_usb *cc)
                if (cc->out_count)
                        fds.events |= POLLOUT;
                ret = poll(&fds, 1, timeout);
-               if (ret == 0)
+               if (ret == 0) {
+                       if (timeout) {
+                               fprintf(stderr, "USB link timeout\n");
+                               exit(1);
+                       }
                        break;
+               }
                if (ret < 0) {
                        perror("poll");
                        break;
index d7acfbd2be1b70a1e59283b2af582e868c0db701..9baabd9598fbb9356f43ee33332fe3deed917414 100644 (file)
@@ -47,7 +47,7 @@ cc_usb_debug_mode(struct cc_usb *cc);
 int
 cc_usb_reset(struct cc_usb *cc);
 
-void
+int
 cc_usb_sync(struct cc_usb *cc);
 
 void