FreeCalypso > hg > freecalypso-sw
diff loadtools/clmain.c @ 53:604648026e9c
fc-xram: baud rate switching implemented per original intent
author | Michael Spacefalcon <msokolov@ivan.Harhan.ORG> |
---|---|
date | Sun, 23 Jun 2013 05:16:47 +0000 |
parents | 16315ed6401a |
children | 278052b6afda |
line wrap: on
line diff
--- a/loadtools/clmain.c Sun Jun 23 04:34:22 2013 +0000 +++ b/loadtools/clmain.c Sun Jun 23 05:16:47 2013 +0000 @@ -7,7 +7,9 @@ #include <stdint.h> #include <stdio.h> #include <stdlib.h> +#include <termios.h> #include <unistd.h> +#include "baudrate.h" #include "srecreader.h" extern char *target_ttydev; @@ -15,6 +17,13 @@ extern char default_loadagent_image[]; extern struct srecreader xramimage; extern char hw_init_script[]; +extern struct baudrate baud_rate_table[]; +extern struct baudrate *current_baud_rate; + +extern struct baudrate *find_baudrate_by_name(); + +struct baudrate *xram_load_baudrate; +struct baudrate *xram_run_baudrate = baud_rate_table; /* 1st entry default */ main(argc, argv) char **argv; @@ -22,12 +31,22 @@ extern char *optarg; extern int optind; int c; + struct baudrate *br; - while ((c = getopt(argc, argv, "a:h:H:i:")) != EOF) + while ((c = getopt(argc, argv, "a:b:B:h:H:i:")) != EOF) switch (c) { case 'a': iramimage.filename = optarg; continue; + case 'b': + set_romload_baudrate(optarg); + continue; + case 'B': + br = find_baudrate_by_name(optarg); + if (!br) + exit(1); /* error msg already printed */ + xram_load_baudrate = br; + continue; case 'h': read_hwparam_file_shortname(optarg); continue; @@ -40,15 +59,23 @@ case '?': default: usage: fprintf(stderr, - "usage: fc-xram [options] ttyport xramimage.srec\n"); + "usage: fc-xram [options] ttyport xramimage.srec [runbaud]\n"); exit(1); } - if (argc - optind != 2) + if (argc - optind < 2) goto usage; target_ttydev = argv[optind]; xramimage.filename = argv[optind+1]; if (!iramimage.filename) iramimage.filename = default_loadagent_image; + if (argc - optind >= 3) { + if (argc - optind > 3) + goto usage; + br = find_baudrate_by_name(argv[optind+2]); + if (!br) + exit(1); /* error msg already printed */ + xram_run_baudrate = br; + } open_target_serial(); perform_romload(); @@ -61,6 +88,11 @@ if (c) exit(1); } + if (xram_load_baudrate && xram_load_baudrate != current_baud_rate) { + c = loadagent_switch_baud(xram_load_baudrate); + if (c) + exit(1); + } printf("Sending XRAM image to loadagent\n"); perform_chain_load(); tty_passthru();