Added monitor option to toggle target power
This commit is contained in:
parent
72ae78a185
commit
c9089f5851
@ -47,6 +47,7 @@ static bool cmd_swdp_scan(void);
|
|||||||
static bool cmd_targets(target *t);
|
static bool cmd_targets(target *t);
|
||||||
static bool cmd_morse(void);
|
static bool cmd_morse(void);
|
||||||
static bool cmd_connect_srst(target *t, int argc, const char **argv);
|
static bool cmd_connect_srst(target *t, int argc, const char **argv);
|
||||||
|
static bool cmd_target_power(target *t, int argc, const char **argv);
|
||||||
#ifdef PLATFORM_HAS_TRACESWO
|
#ifdef PLATFORM_HAS_TRACESWO
|
||||||
static bool cmd_traceswo(void);
|
static bool cmd_traceswo(void);
|
||||||
#endif
|
#endif
|
||||||
@ -59,6 +60,7 @@ const struct command_s cmd_list[] = {
|
|||||||
{"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" },
|
||||||
{"connect_srst", (cmd_handler)cmd_connect_srst, "Configure connect under SRST: (enable|disable)" },
|
{"connect_srst", (cmd_handler)cmd_connect_srst, "Configure connect under SRST: (enable|disable)" },
|
||||||
|
{"tpwr", (cmd_handler)cmd_target_power, "Supplies power to the target: (enable|disable)"},
|
||||||
#ifdef PLATFORM_HAS_TRACESWO
|
#ifdef PLATFORM_HAS_TRACESWO
|
||||||
{"traceswo", (cmd_handler)cmd_traceswo, "Start trace capture" },
|
{"traceswo", (cmd_handler)cmd_traceswo, "Start trace capture" },
|
||||||
#endif
|
#endif
|
||||||
@ -221,6 +223,16 @@ static bool cmd_connect_srst(target *t, int argc, const char **argv)
|
|||||||
connect_assert_srst = !strcmp(argv[1], "enable");
|
connect_assert_srst = !strcmp(argv[1], "enable");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
static bool cmd_target_power(target *t, int argc, const char **argv)
|
||||||
|
{
|
||||||
|
(void)t;
|
||||||
|
if (argc == 1)
|
||||||
|
gdb_outf("Target Power: %s\n",
|
||||||
|
!platform_target_get_power() ? "enabled" : "disabled");
|
||||||
|
else
|
||||||
|
platform_target_set_power(!strncmp(argv[1], "enable", strlen(argv[1])));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef PLATFORM_HAS_TRACESWO
|
#ifdef PLATFORM_HAS_TRACESWO
|
||||||
static bool cmd_traceswo(void)
|
static bool cmd_traceswo(void)
|
||||||
|
@ -153,7 +153,13 @@ void platform_srst_set_val(bool assert)
|
|||||||
gpio_set_val(SRST_PORT, SRST_PIN, !assert);
|
gpio_set_val(SRST_PORT, SRST_PIN, !assert);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
bool platform_target_get_power(void) {
|
||||||
|
return gpio_get(PWR_BR_PORT, PWR_BR_PIN);
|
||||||
|
}
|
||||||
|
void platform_target_set_power(bool power)
|
||||||
|
{
|
||||||
|
gpio_set_val(PWR_BR_PORT, PWR_BR_PIN, !power);
|
||||||
|
}
|
||||||
void platform_delay(uint32_t delay)
|
void platform_delay(uint32_t delay)
|
||||||
{
|
{
|
||||||
timeout_counter = delay;
|
timeout_counter = delay;
|
||||||
|
@ -231,3 +231,5 @@ static inline uint16_t _gpio_get(uint32_t gpioport, uint16_t gpios)
|
|||||||
void assert_boot_pin(void);
|
void assert_boot_pin(void);
|
||||||
void setup_vbus_irq(void);
|
void setup_vbus_irq(void);
|
||||||
void platform_srst_set_val(bool assert);
|
void platform_srst_set_val(bool assert);
|
||||||
|
bool platform_target_get_power(void);
|
||||||
|
void platform_target_set_power(bool power);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user