Revert "Allow to specificy if SRST is asserted and when it is released."

This reverts commit 44fc24e0e7.
This commit is contained in:
Uwe Bonnes 2018-09-10 23:11:24 +02:00 committed by Gareth McMullin
parent 9ce05ae67b
commit 6df793dbf0
1 changed files with 13 additions and 29 deletions

View File

@ -43,12 +43,6 @@ struct command_s {
const char *help; const char *help;
}; };
enum assert_srst_t{
ASSERT_NEVER = 0,
ASSERT_UNTIL_SCAN,
ASSERT_UNTIL_ATTACH
};
static bool cmd_version(void); static bool cmd_version(void);
static bool cmd_help(target *t); static bool cmd_help(target *t);
@ -56,8 +50,8 @@ static bool cmd_jtag_scan(target *t, int argc, char **argv);
static bool cmd_swdp_scan(void); static bool cmd_swdp_scan(void);
static bool cmd_targets(void); static bool cmd_targets(void);
static bool cmd_morse(void); static bool cmd_morse(void);
static bool cmd_assert_srst(target *t, int argc, const char **argv);
static bool cmd_halt_timeout(target *t, int argc, const char **argv); static bool cmd_halt_timeout(target *t, int argc, const char **argv);
static bool cmd_connect_srst(target *t, int argc, const char **argv);
static bool cmd_hard_srst(void); static bool cmd_hard_srst(void);
#ifdef PLATFORM_HAS_POWER_SWITCH #ifdef PLATFORM_HAS_POWER_SWITCH
static bool cmd_target_power(target *t, int argc, const char **argv); static bool cmd_target_power(target *t, int argc, const char **argv);
@ -76,8 +70,8 @@ const struct command_s cmd_list[] = {
{"swdp_scan", (cmd_handler)cmd_swdp_scan, "Scan SW-DP for devices" }, {"swdp_scan", (cmd_handler)cmd_swdp_scan, "Scan SW-DP for devices" },
{"targets", (cmd_handler)cmd_targets, "Display list of available targets" }, {"targets", (cmd_handler)cmd_targets, "Display list of available targets" },
{"morse", (cmd_handler)cmd_morse, "Display morse error message" }, {"morse", (cmd_handler)cmd_morse, "Display morse error message" },
{"assert_srst", (cmd_handler)cmd_assert_srst, "Assert SRST until:(never(default)| scan | attach)" },
{"halt_timeout", (cmd_handler)cmd_halt_timeout, "Timeout (ms) to wait until Cortex-M is halted: (Default 2000)" }, {"halt_timeout", (cmd_handler)cmd_halt_timeout, "Timeout (ms) to wait until Cortex-M is halted: (Default 2000)" },
{"connect_srst", (cmd_handler)cmd_connect_srst, "Configure connect under SRST: (enable|disable)" },
{"hard_srst", (cmd_handler)cmd_hard_srst, "Force a pulse on the hard SRST line - disconnects target" }, {"hard_srst", (cmd_handler)cmd_hard_srst, "Force a pulse on the hard SRST line - disconnects target" },
#ifdef PLATFORM_HAS_POWER_SWITCH #ifdef PLATFORM_HAS_POWER_SWITCH
{"tpwr", (cmd_handler)cmd_target_power, "Supplies power to the target: (enable|disable)"}, {"tpwr", (cmd_handler)cmd_target_power, "Supplies power to the target: (enable|disable)"},
@ -91,7 +85,7 @@ const struct command_s cmd_list[] = {
{NULL, NULL, NULL} {NULL, NULL, NULL}
}; };
static enum assert_srst_t assert_srst; static bool connect_assert_srst;
#ifdef PLATFORM_HAS_DEBUG #ifdef PLATFORM_HAS_DEBUG
bool debug_bmp; bool debug_bmp;
#endif #endif
@ -168,10 +162,8 @@ static bool cmd_jtag_scan(target *t, int argc, char **argv)
irlens[argc-1] = 0; irlens[argc-1] = 0;
} }
if(assert_srst != ASSERT_NEVER) if(connect_assert_srst)
platform_srst_set_val(true); platform_srst_set_val(true); /* will be deasserted after attach */
if(assert_srst == ASSERT_UNTIL_SCAN)
platform_srst_set_val(false);
int devs = -1; int devs = -1;
volatile struct exception e; volatile struct exception e;
@ -201,10 +193,8 @@ bool cmd_swdp_scan(void)
{ {
gdb_outf("Target voltage: %s\n", platform_target_voltage()); gdb_outf("Target voltage: %s\n", platform_target_voltage());
if(assert_srst != ASSERT_NEVER) if(connect_assert_srst)
platform_srst_set_val(true); platform_srst_set_val(true); /* will be deasserted after attach */
if(assert_srst == ASSERT_UNTIL_SCAN)
platform_srst_set_val(false);
int devs = -1; int devs = -1;
volatile struct exception e; volatile struct exception e;
@ -257,20 +247,14 @@ bool cmd_morse(void)
return true; return true;
} }
static bool cmd_assert_srst(target *t, int argc, const char **argv) static bool cmd_connect_srst(target *t, int argc, const char **argv)
{ {
(void)t; (void)t;
if (argc > 1) { if (argc == 1)
if (!strcmp(argv[1], "attach")) gdb_outf("Assert SRST during connect: %s\n",
assert_srst = ASSERT_UNTIL_ATTACH; connect_assert_srst ? "enabled" : "disabled");
else if (!strcmp(argv[1], "scan"))
assert_srst = ASSERT_UNTIL_SCAN;
else else
assert_srst = ASSERT_NEVER; connect_assert_srst = !strcmp(argv[1], "enable");
}
gdb_outf("Assert SRST %s\n",
(assert_srst == ASSERT_UNTIL_ATTACH) ? "until attach" :
(assert_srst == ASSERT_UNTIL_SCAN) ? "until scan" : "never");
return true; return true;
} }