diff options
author | Bdale Garbee <bdale@gag.com> | 2018-08-05 11:24:13 +0800 |
---|---|---|
committer | Bdale Garbee <bdale@gag.com> | 2018-08-05 11:24:13 +0800 |
commit | a3b4f0d33e9d13fb5294397304ec0eb44ecaf1fc (patch) | |
tree | 69c563070ea7ca4a127f2ac925f18a36acb888bb /ao-tools/ao-dumplog/ao-dumplog.c | |
parent | 67da03d1382228a95d0414294703371cf32e666e (diff) | |
parent | 3a2a5a05bb6372d9003905cee7afdfcd6d38ae7e (diff) |
Merge branch 'branch-1.8' into debian
Diffstat (limited to 'ao-tools/ao-dumplog/ao-dumplog.c')
-rw-r--r-- | ao-tools/ao-dumplog/ao-dumplog.c | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/ao-tools/ao-dumplog/ao-dumplog.c b/ao-tools/ao-dumplog/ao-dumplog.c index 6d4fa5bf..41d0ac10 100644 --- a/ao-tools/ao-dumplog/ao-dumplog.c +++ b/ao-tools/ao-dumplog/ao-dumplog.c @@ -90,6 +90,8 @@ main (int argc, char **argv) int any_valid; int invalid; char serial_line[8192]; + unsigned storage_size; + int blocks; while ((c = getopt_long(argc, argv, "T:D:C:R", options, NULL)) != -1) { switch (c) { @@ -140,10 +142,21 @@ main (int argc, char **argv) cc_usb_close(cc); exit(1); } - printf ("Serial number: %d\n", serial_number); + cc_usb_printf(cc, "f\n"); + storage_size = 0; + for (;;) { + cc_usb_getline(cc, line, sizeof(line)); + if (sscanf(line, "Storage size: %u", &storage_size) == 1) + break; + } + printf ("Serial number: %d Storage size: %u\n", serial_number, storage_size); + if (storage_size) + blocks = storage_size / 256; + else + blocks = 511; done = 0; column = 0; - for (block = 0; !done && block < 511; block++) { + for (block = 0; !done && block < blocks; block++) { cc_usb_printf(cc, "e %x\n", block); if (column == 64) { putchar('\n'); |