FreeCalypso > hg > freecalypso-tools
view loadtools/ltexit.c @ 505:7bf0d909c87e
fc-loadtool flash ID check: change of reset after the check logic
This change only affects those flash configurations that have ID checks
enabled. The logic for resetting the flash after the ID check has been
changed as follows:
1) If the check fails, we return without attempting to reset the flash.
2) If the check is successful, we reset the flash using the configured
method (could be AMD or Intel or Intel W30) instead of always doing an
AMD flash reset as the original code did.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 27 May 2019 19:58:01 +0000 |
parents | 96332d875fc9 |
children | aba969153d20 |
line wrap: on
line source
/* * This module implements the loadtool exit command, along with its * options for jump-reboot and Iota power-off. */ #include <stdio.h> #include <string.h> #include <strings.h> #include <stdlib.h> static void exit_bare(rc) { exit(rc); } static void exit_gta02_cutpwr(rc) { #ifdef GTA0x_AP_BUILD set_gta_modem_power_ctrl(0); #endif exit(rc); } static void exit_iotaoff(rc) { static char *poweroff_argv[2] = {"poweroff", 0}; tpinterf_make_cmd(poweroff_argv); tpinterf_send_cmd(); exit(rc); } static void exit_jump0(rc) { static char *jump0_argv[3] = {"jump", "0", 0}; tpinterf_make_cmd(jump0_argv); tpinterf_send_cmd(); exit(rc); } void (*default_exit)() = exit_bare; static struct kwtab { char *kw; void (*func)(); } exit_modes[] = { {"bare", exit_bare}, {"gta02-cutpwr", exit_gta02_cutpwr}, {"iota-off", exit_iotaoff}, {"jump0", exit_jump0}, {0, 0} }; cmd_exit(argc, argv) char **argv; { struct kwtab *tp; if (argc < 2) default_exit(0); for (tp = exit_modes; tp->kw; tp++) if (!strcmp(tp->kw, argv[1])) break; if (!tp->func) { fprintf(stderr, "error: \"%s\" is not an understood exit mode\n", argv[1]); return(-1); } tp->func(0); } /* called from hwparam.c config file parser */ void set_default_exit_mode(arg, filename_for_errs, lineno_for_errs) char *arg; char *filename_for_errs; int lineno_for_errs; { char *cp; struct kwtab *tp; while (isspace(*arg)) arg++; if (!*arg) { fprintf(stderr, "%s line %d: exit-mode setting requires an argument\n", filename_for_errs, lineno_for_errs); exit(1); } for (cp = arg; *cp && !isspace(*cp); cp++) ; *cp = '\0'; for (tp = exit_modes; tp->kw; tp++) if (!strcmp(tp->kw, arg)) break; if (!tp->func) { fprintf(stderr, "%s line %d: \"%s\" is not an understood exit mode\n", filename_for_errs, lineno_for_errs, arg); exit(1); } default_exit = tp->func; }