Allow multiple scan routines.
This commit is contained in:
parent
b0cf7d24bd
commit
1e10b96b03
|
@ -186,7 +186,11 @@ static bool cmd_jtag_scan(target *t, int argc, char **argv)
|
||||||
int devs = -1;
|
int devs = -1;
|
||||||
volatile struct exception e;
|
volatile struct exception e;
|
||||||
TRY_CATCH (e, EXCEPTION_ALL) {
|
TRY_CATCH (e, EXCEPTION_ALL) {
|
||||||
|
#if PC_HOSTED == 1
|
||||||
|
devs = platform_jtag_scan(argc > 1 ? irlens : NULL);
|
||||||
|
#else
|
||||||
devs = jtag_scan(argc > 1 ? irlens : NULL);
|
devs = jtag_scan(argc > 1 ? irlens : NULL);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
switch (e.type) {
|
switch (e.type) {
|
||||||
case EXCEPTION_TIMEOUT:
|
case EXCEPTION_TIMEOUT:
|
||||||
|
@ -220,8 +224,12 @@ bool cmd_swdp_scan(target *t, int argc, char **argv)
|
||||||
int devs = -1;
|
int devs = -1;
|
||||||
volatile struct exception e;
|
volatile struct exception e;
|
||||||
TRY_CATCH (e, EXCEPTION_ALL) {
|
TRY_CATCH (e, EXCEPTION_ALL) {
|
||||||
|
#if PC_HOSTED == 1
|
||||||
|
devs = platform_adiv5_swdp_scan();
|
||||||
|
#else
|
||||||
devs = adiv5_swdp_scan();
|
devs = adiv5_swdp_scan();
|
||||||
}
|
#endif
|
||||||
|
}
|
||||||
switch (e.type) {
|
switch (e.type) {
|
||||||
case EXCEPTION_TIMEOUT:
|
case EXCEPTION_TIMEOUT:
|
||||||
gdb_outf("Timeout during scan. Is target stuck in WFI?\n");
|
gdb_outf("Timeout during scan. Is target stuck in WFI?\n");
|
||||||
|
|
|
@ -34,6 +34,13 @@ typedef struct target_s target;
|
||||||
typedef uint32_t target_addr;
|
typedef uint32_t target_addr;
|
||||||
struct target_controller;
|
struct target_controller;
|
||||||
|
|
||||||
|
#if defined(PC_HOSTED)
|
||||||
|
int platform_adiv5_swdp_scan(void);
|
||||||
|
int platform_jtag_scan(const uint8_t *lrlens);
|
||||||
|
#endif
|
||||||
|
int adiv5_swdp_scan(void);
|
||||||
|
int jtag_scan(const uint8_t *lrlens);
|
||||||
|
|
||||||
int adiv5_swdp_scan(void);
|
int adiv5_swdp_scan(void);
|
||||||
int jtag_scan(const uint8_t *lrlens);
|
int jtag_scan(const uint8_t *lrlens);
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include "gdb_if.h"
|
#include "gdb_if.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
|
#include "target.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@ -180,6 +181,16 @@ cable_desc_t cable_desc[] = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
int platform_adiv5_swdp_scan(void)
|
||||||
|
{
|
||||||
|
return adiv5_swdp_scan();
|
||||||
|
}
|
||||||
|
|
||||||
|
int platform_jtag_scan(const uint8_t *lrlens)
|
||||||
|
{
|
||||||
|
return jtag_scan(lrlens);
|
||||||
|
}
|
||||||
|
|
||||||
void platform_init(int argc, char **argv)
|
void platform_init(int argc, char **argv)
|
||||||
{
|
{
|
||||||
BMP_CL_OPTIONS_t cl_opts = {0};
|
BMP_CL_OPTIONS_t cl_opts = {0};
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "remote.h"
|
#include "remote.h"
|
||||||
|
#include "target.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
@ -33,6 +34,16 @@
|
||||||
#include "cl_utils.h"
|
#include "cl_utils.h"
|
||||||
static BMP_CL_OPTIONS_t cl_opts; /* Portable way to nullify the struct*/
|
static BMP_CL_OPTIONS_t cl_opts; /* Portable way to nullify the struct*/
|
||||||
|
|
||||||
|
int platform_adiv5_swdp_scan(void)
|
||||||
|
{
|
||||||
|
return adiv5_swdp_scan();
|
||||||
|
}
|
||||||
|
|
||||||
|
int platform_jtag_scan(const uint8_t *lrlens)
|
||||||
|
{
|
||||||
|
return jtag_scan(lrlens);
|
||||||
|
}
|
||||||
|
|
||||||
void platform_init(int argc, char **argv)
|
void platform_init(int argc, char **argv)
|
||||||
{
|
{
|
||||||
cl_opts.opt_idstring = "Blackmagic Debug Probe Remote";
|
cl_opts.opt_idstring = "Blackmagic Debug Probe Remote";
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
struct jtag_dev_s jtag_devs[JTAG_MAX_DEVS+1];
|
struct jtag_dev_s jtag_devs[JTAG_MAX_DEVS+1];
|
||||||
int jtag_dev_count;
|
int jtag_dev_count;
|
||||||
|
|
||||||
int jtag_scan(const uint8_t *irlens)
|
int jtag_scan_stlinkv2(const uint8_t *irlens)
|
||||||
{
|
{
|
||||||
uint32_t idcodes[JTAG_MAX_DEVS+1];
|
uint32_t idcodes[JTAG_MAX_DEVS+1];
|
||||||
(void) *irlens;
|
(void) *irlens;
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
#include "gdb_if.h"
|
#include "gdb_if.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
|
#include "target.h"
|
||||||
|
#include "target_internal.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@ -39,6 +41,34 @@ const char *platform_target_voltage(void)
|
||||||
return stlink_target_voltage();
|
return stlink_target_voltage();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int adiv5_swdp_scan_stlinkv2(void)
|
||||||
|
{
|
||||||
|
target_list_free();
|
||||||
|
ADIv5_DP_t *dp = (void*)calloc(1, sizeof(*dp));
|
||||||
|
if (stlink_enter_debug_swd())
|
||||||
|
return 0;
|
||||||
|
dp->idcode = stlink_read_coreid();
|
||||||
|
dp->dp_read = stlink_dp_read;
|
||||||
|
dp->error = stlink_dp_error;
|
||||||
|
dp->low_access = stlink_dp_low_access;
|
||||||
|
dp->abort = stlink_dp_abort;
|
||||||
|
|
||||||
|
stlink_dp_error(dp);
|
||||||
|
adiv5_dp_init(dp);
|
||||||
|
|
||||||
|
return target_list?1:0;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
int platform_adiv5_swdp_scan(void)
|
||||||
|
{
|
||||||
|
return adiv5_swdp_scan_stlinkv2();
|
||||||
|
}
|
||||||
|
|
||||||
|
int platform_jtag_scan(const uint8_t *lrlens)
|
||||||
|
{
|
||||||
|
return jtag_scan_stlinkv2(lrlens);
|
||||||
|
}
|
||||||
|
|
||||||
void platform_init(int argc, char **argv)
|
void platform_init(int argc, char **argv)
|
||||||
{
|
{
|
||||||
stlink_init(argc, argv);
|
stlink_init(argc, argv);
|
||||||
|
|
|
@ -44,5 +44,5 @@ void stlink_check_detach(int state);
|
||||||
void platform_buffer_flush(void);
|
void platform_buffer_flush(void);
|
||||||
int platform_buffer_write(const uint8_t *data, int size);
|
int platform_buffer_write(const uint8_t *data, int size);
|
||||||
int platform_buffer_read(uint8_t *data, int size);
|
int platform_buffer_read(uint8_t *data, int size);
|
||||||
|
int jtag_scan_stlinkv2(const uint8_t *irlens);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -275,9 +275,9 @@ int cl_execute(BMP_CL_OPTIONS_t *opt)
|
||||||
printf("Running in Test Mode\n");
|
printf("Running in Test Mode\n");
|
||||||
printf("Target voltage: %s Volt\n", platform_target_voltage());
|
printf("Target voltage: %s Volt\n", platform_target_voltage());
|
||||||
if (opt->opt_usejtag) {
|
if (opt->opt_usejtag) {
|
||||||
num_targets = jtag_scan(NULL);
|
num_targets = platform_jtag_scan(NULL);
|
||||||
} else {
|
} else {
|
||||||
num_targets = adiv5_swdp_scan();
|
num_targets = platform_adiv5_swdp_scan();
|
||||||
}
|
}
|
||||||
if (!num_targets) {
|
if (!num_targets) {
|
||||||
DEBUG("No target found\n");
|
DEBUG("No target found\n");
|
||||||
|
|
Loading…
Reference in New Issue