# HG changeset patch # User Mychaela Falconia # Date 1615089999 0 # Node ID 3f6f50103dd3393902c67aa282aae76f9ecd38ab # Parent fc1635333d813ccbf8152d6efd079ad6f89d3dee fc-simtool: update-rec-prev separate command eliminated, absorbed into regular update-rec diff -r fc1635333d81 -r 3f6f50103dd3 simtool/dispatch.c --- a/simtool/dispatch.c Sun Mar 07 03:58:49 2021 +0000 +++ b/simtool/dispatch.c Sun Mar 07 04:06:39 2021 +0000 @@ -92,7 +92,6 @@ extern int cmd_update_bin(); extern int cmd_update_bin_imm(); extern int cmd_update_rec(); -extern int cmd_update_rec_prev(); extern int cmd_user_sum(); extern int cmd_verify_chv(); extern int cmd_verify_ext(); @@ -220,7 +219,6 @@ {"update-bin", 2, 2, 0, cmd_update_bin}, {"update-bin-imm", 2, 2, 0, cmd_update_bin_imm}, {"update-rec", 2, 2, 0, cmd_update_rec}, - {"update-rec-prev", 1, 1, 0, cmd_update_rec_prev}, {"user-sum", 0, 0, 1, cmd_user_sum}, {"verify-chv1", 1, 1, 0, cmd_verify_chv}, {"verify-chv2", 1, 1, 0, cmd_verify_chv}, diff -r fc1635333d81 -r 3f6f50103dd3 simtool/writecmd.c --- a/simtool/writecmd.c Sun Mar 07 03:58:49 2021 +0000 +++ b/simtool/writecmd.c Sun Mar 07 04:06:39 2021 +0000 @@ -1,6 +1,8 @@ #include #include #include +#include +#include #include "curfile.h" cmd_update_bin(argc, argv) @@ -44,15 +46,21 @@ cmd_update_rec(argc, argv) char **argv; { - unsigned recno; + unsigned recno, mode; u_char data[255]; int rc; - recno = strtoul(argv[1], 0, 0); - if (recno < 1 || recno > 255) { - fprintf(stderr, + if (!strcmp(argv[1], "prev")) { + recno = 0; + mode = 0x03; + } else { + recno = strtoul(argv[1], 0, 0); + if (recno < 1 || recno > 255) { + fprintf(stderr, "error: record number argument is out of range\n"); - return(-1); + return(-1); + } + mode = 0x04; } rc = read_hex_data_file(argv[2], data, 255); if (rc < 0) @@ -61,21 +69,5 @@ fprintf(stderr, "error: hex data length != EF record length\n"); return(-1); } - return update_rec_op(recno, 0x04, data, curfile_record_len); + return update_rec_op(recno, mode, data, curfile_record_len); } - -cmd_update_rec_prev(argc, argv) - char **argv; -{ - u_char data[255]; - int rc; - - rc = read_hex_data_file(argv[1], data, 255); - if (rc < 0) - return(rc); - if (rc != curfile_record_len) { - fprintf(stderr, "error: hex data length != EF record length\n"); - return(-1); - } - return update_rec_op(0, 0x03, data, curfile_record_len); -}