FreeCalypso > hg > freecalypso-tools
changeset 640:5385aca4d813
fc-loadtool module refactoring: CRC-32 functions split out
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 01 Mar 2020 18:54:29 +0000 (2020-03-01) |
parents | 963d15a808eb |
children | b4070292640a |
files | loadtools/Makefile loadtools/lacrc32.c loadtools/ltdump.c loadtools/ltmisc.c |
diffstat | 4 files changed, 66 insertions(+), 55 deletions(-) [+] |
line wrap: on
line diff
--- a/loadtools/Makefile Sun Mar 01 18:28:10 2020 +0000 +++ b/loadtools/Makefile Sun Mar 01 18:54:29 2020 +0000 @@ -16,7 +16,7 @@ LOADTOOL_OBJS= compalload.o crc32tab.o defpath.o flashid.o flashops.o \ flcmplboot.o flconf.o fldevs.o flmain.o flmisc.o flprogbin.o \ - flprogsrec.o flutil.o hexdecode.o hwparam.o labaud.o \ + flprogsrec.o flutil.o hexdecode.o hwparam.o labaud.o lacrc32.o \ ltdispatch.o ltdump.o ltexit.o lthelp.o ltmain.o ltmisc.o \ ltpassthru.o ltscript.o romload.o srecreader.o tpinterf.o \ tpinterf2.o tpinterf3.o
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/loadtools/lacrc32.c Sun Mar 01 18:54:29 2020 +0000 @@ -0,0 +1,42 @@ +/* + * This module implements the function for getting a CRC-32 computation + * from loadagent. + */ + +#include <sys/types.h> +#include <stdio.h> +#include <stdint.h> +#include <string.h> +#include <strings.h> +#include <stdlib.h> + +extern char target_response_line[]; + +crc32_on_target(area_base, area_len, retptr) + u_long area_base, area_len, *retptr; +{ + char arg1[10], arg2[10], *argv[4]; + int stat; + char *strtoul_endp; + + sprintf(arg1, "%lx", area_base); + sprintf(arg2, "%lx", area_len); + argv[0] = "crc32"; + argv[1] = arg1; + argv[2] = arg2; + argv[3] = 0; + tpinterf_make_cmd(argv); + if (tpinterf_send_cmd() < 0) + return(-1); + stat = tpinterf_capture_output_oneline(10); /* 10 s timeout */ + if (stat != 1) { +errout: fprintf(stderr, "error: malformed response to crc32 command\n"); + return(-1); + } + if (strlen(target_response_line) != 8) + goto errout; + *retptr = strtoul(target_response_line, &strtoul_endp, 16); + if (strtoul_endp != target_response_line + 8) + goto errout; + return(0); +}
--- a/loadtools/ltdump.c Sun Mar 01 18:28:10 2020 +0000 +++ b/loadtools/ltdump.c Sun Mar 01 18:54:29 2020 +0000 @@ -12,60 +12,6 @@ #include <time.h> extern uint32_t crc32_table[]; -extern char target_response_line[]; - -crc32_on_target(area_base, area_len, retptr) - u_long area_base, area_len, *retptr; -{ - char arg1[10], arg2[10], *argv[4]; - int stat; - char *strtoul_endp; - - sprintf(arg1, "%lx", area_base); - sprintf(arg2, "%lx", area_len); - argv[0] = "crc32"; - argv[1] = arg1; - argv[2] = arg2; - argv[3] = 0; - tpinterf_make_cmd(argv); - if (tpinterf_send_cmd() < 0) - return(-1); - stat = tpinterf_capture_output_oneline(10); /* 10 s timeout */ - if (stat != 1) { -errout: fprintf(stderr, "error: malformed response to crc32 command\n"); - return(-1); - } - if (strlen(target_response_line) != 8) - goto errout; - *retptr = strtoul(target_response_line, &strtoul_endp, 16); - if (strtoul_endp != target_response_line + 8) - goto errout; - return(0); -} - -cmd_crc32(argc, argv) - char **argv; -{ - u_long area_base, area_len; - char *strtoul_endp; - u_long crc_result; - int stat; - - area_base = strtoul(argv[1], &strtoul_endp, 16); - if (*strtoul_endp) { -inv: fprintf(stderr, "usage: crc32 hex-start hex-len\n"); - return(-1); - } - area_len = strtoul(argv[2], &strtoul_endp, 16); - if (*strtoul_endp) - goto inv; - stat = crc32_on_target(area_base, area_len, &crc_result); - if (stat == 0) - printf("%08lX\n", crc_result); - return(stat); -} - -/* the actual dump facility */ static FILE *dump_outfile; static int dump_save_srec;
--- a/loadtools/ltmisc.c Sun Mar 01 18:28:10 2020 +0000 +++ b/loadtools/ltmisc.c Sun Mar 01 18:54:29 2020 +0000 @@ -6,6 +6,29 @@ #include <sys/types.h> #include <stdio.h> #include <stdint.h> +#include <stdlib.h> + +cmd_crc32(argc, argv) + char **argv; +{ + u_long area_base, area_len; + char *strtoul_endp; + u_long crc_result; + int stat; + + area_base = strtoul(argv[1], &strtoul_endp, 16); + if (*strtoul_endp) { +inv: fprintf(stderr, "usage: crc32 hex-start hex-len\n"); + return(-1); + } + area_len = strtoul(argv[2], &strtoul_endp, 16); + if (*strtoul_endp) + goto inv; + stat = crc32_on_target(area_base, area_len, &crc_result); + if (stat == 0) + printf("%08lX\n", crc_result); + return(stat); +} cmd_dieid(argc, argv) char **argv;