Merge pull request #129 from gsmcmullin/srst_cleanup
Cleanup of SRST handling.
This commit is contained in:
commit
da10f8a6bc
|
@ -50,8 +50,6 @@ int adiv5_swdp_scan(void)
|
||||||
ADIv5_DP_t *dp = (void*)calloc(1, sizeof(*dp));
|
ADIv5_DP_t *dp = (void*)calloc(1, sizeof(*dp));
|
||||||
|
|
||||||
swdptap_init();
|
swdptap_init();
|
||||||
if(connect_assert_srst)
|
|
||||||
jtagtap_srst(true); /* will be deasserted after attach */
|
|
||||||
/* Read the SW-DP IDCODE register to syncronise */
|
/* Read the SW-DP IDCODE register to syncronise */
|
||||||
/* This could be done with adiv_swdp_low_access(), but this doesn't
|
/* This could be done with adiv_swdp_low_access(), but this doesn't
|
||||||
* allow the ack to be checked here. */
|
* allow the ack to be checked here. */
|
||||||
|
|
|
@ -68,6 +68,7 @@ const struct command_s cmd_list[] = {
|
||||||
{NULL, NULL, NULL}
|
{NULL, NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static bool connect_assert_srst;
|
||||||
|
|
||||||
int command_process(target *t, char *cmd)
|
int command_process(target *t, char *cmd)
|
||||||
{
|
{
|
||||||
|
@ -151,6 +152,9 @@ static bool cmd_jtag_scan(target *t, int argc, char **argv)
|
||||||
irlens[argc-1] = 0;
|
irlens[argc-1] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(connect_assert_srst)
|
||||||
|
platform_srst_set_val(true); /* will be deasserted after attach */
|
||||||
|
|
||||||
int devs = -1;
|
int devs = -1;
|
||||||
volatile struct exception e;
|
volatile struct exception e;
|
||||||
TRY_CATCH (e, EXCEPTION_ALL) {
|
TRY_CATCH (e, EXCEPTION_ALL) {
|
||||||
|
@ -165,14 +169,11 @@ static bool cmd_jtag_scan(target *t, int argc, char **argv)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(devs < 0) {
|
if(devs <= 0) {
|
||||||
|
platform_srst_set_val(false);
|
||||||
gdb_out("JTAG device scan failed!\n");
|
gdb_out("JTAG device scan failed!\n");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if(devs == 0) {
|
|
||||||
gdb_out("JTAG scan found no devices!\n");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
gdb_outf("Device IR Len IDCODE Description\n");
|
gdb_outf("Device IR Len IDCODE Description\n");
|
||||||
for(int i = 0; i < jtag_dev_count; i++)
|
for(int i = 0; i < jtag_dev_count; i++)
|
||||||
gdb_outf("%d\t%d\t0x%08lX %s\n", i,
|
gdb_outf("%d\t%d\t0x%08lX %s\n", i,
|
||||||
|
@ -187,6 +188,9 @@ bool cmd_swdp_scan(void)
|
||||||
{
|
{
|
||||||
gdb_outf("Target voltage: %s\n", platform_target_voltage());
|
gdb_outf("Target voltage: %s\n", platform_target_voltage());
|
||||||
|
|
||||||
|
if(connect_assert_srst)
|
||||||
|
platform_srst_set_val(true); /* will be deasserted after attach */
|
||||||
|
|
||||||
int devs = -1;
|
int devs = -1;
|
||||||
volatile struct exception e;
|
volatile struct exception e;
|
||||||
TRY_CATCH (e, EXCEPTION_ALL) {
|
TRY_CATCH (e, EXCEPTION_ALL) {
|
||||||
|
@ -201,7 +205,8 @@ bool cmd_swdp_scan(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(devs < 0) {
|
if(devs <= 0) {
|
||||||
|
platform_srst_set_val(false);
|
||||||
gdb_out("SW-DP scan failed!\n");
|
gdb_out("SW-DP scan failed!\n");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,8 +27,6 @@
|
||||||
*/
|
*/
|
||||||
#include "general.h"
|
#include "general.h"
|
||||||
#include "exception.h"
|
#include "exception.h"
|
||||||
#include "jtagtap.h"
|
|
||||||
#include "jtag_scan.h"
|
|
||||||
#include "adiv5.h"
|
#include "adiv5.h"
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
#include "command.h"
|
#include "command.h"
|
||||||
|
@ -273,7 +271,7 @@ bool cortexm_attach(target *t)
|
||||||
|
|
||||||
target_halt_request(t);
|
target_halt_request(t);
|
||||||
tries = 10;
|
tries = 10;
|
||||||
while(!connect_assert_srst && !target_halt_wait(t) && --tries)
|
while(!platform_srst_get_val() && !target_halt_wait(t) && --tries)
|
||||||
platform_delay(2);
|
platform_delay(2);
|
||||||
if(!tries)
|
if(!tries)
|
||||||
return false;
|
return false;
|
||||||
|
@ -318,8 +316,7 @@ bool cortexm_attach(target *t)
|
||||||
t->clear_hw_wp = cortexm_clear_hw_wp;
|
t->clear_hw_wp = cortexm_clear_hw_wp;
|
||||||
t->check_hw_wp = cortexm_check_hw_wp;
|
t->check_hw_wp = cortexm_check_hw_wp;
|
||||||
|
|
||||||
if(connect_assert_srst)
|
platform_srst_set_val(false);
|
||||||
jtagtap_srst(false);
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -426,8 +423,8 @@ static void cortexm_pc_write(target *t, const uint32_t val)
|
||||||
static void cortexm_reset(target *t)
|
static void cortexm_reset(target *t)
|
||||||
{
|
{
|
||||||
if ((t->target_options & CORTEXM_TOPT_INHIBIT_SRST) == 0) {
|
if ((t->target_options & CORTEXM_TOPT_INHIBIT_SRST) == 0) {
|
||||||
jtagtap_srst(true);
|
platform_srst_set_val(true);
|
||||||
jtagtap_srst(false);
|
platform_srst_set_val(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Read DHCSR here to clear S_RESET_ST bit before reset */
|
/* Read DHCSR here to clear S_RESET_ST bit before reset */
|
||||||
|
|
|
@ -27,8 +27,6 @@ int jtagtap_init(void);
|
||||||
|
|
||||||
void jtagtap_reset(void);
|
void jtagtap_reset(void);
|
||||||
|
|
||||||
void jtagtap_srst(bool assert);
|
|
||||||
|
|
||||||
uint8_t jtagtap_next(const uint8_t TMS, const uint8_t TDI);
|
uint8_t jtagtap_next(const uint8_t TMS, const uint8_t TDI);
|
||||||
/* tap_next executes one state transision in the JTAG TAP state machine:
|
/* tap_next executes one state transision in the JTAG TAP state machine:
|
||||||
* - Ensure TCK is low
|
* - Ensure TCK is low
|
||||||
|
|
|
@ -36,6 +36,7 @@ void platform_timeout_set(uint32_t ms);
|
||||||
bool platform_timeout_is_expired(void);
|
bool platform_timeout_is_expired(void);
|
||||||
void platform_delay(uint32_t delay);
|
void platform_delay(uint32_t delay);
|
||||||
void platform_srst_set_val(bool assert);
|
void platform_srst_set_val(bool assert);
|
||||||
|
bool platform_srst_get_val(void);
|
||||||
bool platform_target_get_power(void);
|
bool platform_target_get_power(void);
|
||||||
void platform_target_set_power(bool power);
|
void platform_target_set_power(bool power);
|
||||||
void platform_request_boot(void);
|
void platform_request_boot(void);
|
||||||
|
|
|
@ -206,7 +206,6 @@ struct target_command_s {
|
||||||
};
|
};
|
||||||
|
|
||||||
extern target *target_list;
|
extern target *target_list;
|
||||||
extern bool connect_assert_srst;
|
|
||||||
|
|
||||||
target *target_new(unsigned size);
|
target *target_new(unsigned size);
|
||||||
void target_list_free(void);
|
void target_list_free(void);
|
||||||
|
|
|
@ -105,8 +105,6 @@ int jtag_scan(const uint8_t *irlens)
|
||||||
*/
|
*/
|
||||||
DEBUG("Resetting TAP\n");
|
DEBUG("Resetting TAP\n");
|
||||||
jtagtap_init();
|
jtagtap_init();
|
||||||
if(connect_assert_srst)
|
|
||||||
jtagtap_srst(true); /* will be deasserted after attach */
|
|
||||||
jtagtap_reset();
|
jtagtap_reset();
|
||||||
|
|
||||||
if (irlens) {
|
if (irlens) {
|
||||||
|
|
|
@ -78,6 +78,9 @@ void platform_init(void)
|
||||||
cdcacm_init();
|
cdcacm_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void platform_srst_set_val(bool assert) { (void)assert; }
|
||||||
|
bool platform_srst_get_val(void) { return false; }
|
||||||
|
|
||||||
const char *platform_target_voltage(void)
|
const char *platform_target_voltage(void)
|
||||||
{
|
{
|
||||||
return "ABSENT!";
|
return "ABSENT!";
|
||||||
|
|
|
@ -78,6 +78,9 @@ void platform_init(void)
|
||||||
cdcacm_init();
|
cdcacm_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void platform_srst_set_val(bool assert) { (void)assert; }
|
||||||
|
bool platform_srst_get_val(void) { return false; }
|
||||||
|
|
||||||
const char *platform_target_voltage(void)
|
const char *platform_target_voltage(void)
|
||||||
{
|
{
|
||||||
return "ABSENT!";
|
return "ABSENT!";
|
||||||
|
|
|
@ -85,6 +85,22 @@ platform_init(void)
|
||||||
0xff, 0xff);
|
0xff, 0xff);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void platform_srst_set_val(bool assert)
|
||||||
|
{
|
||||||
|
volatile int i;
|
||||||
|
if (assert) {
|
||||||
|
gpio_clear(SRST_PORT, SRST_PIN);
|
||||||
|
for(i = 0; i < 10000; i++) asm("nop");
|
||||||
|
} else {
|
||||||
|
gpio_set(SRST_PORT, SRST_PIN);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool platform_srst_get_val(void)
|
||||||
|
{
|
||||||
|
return gpio_get(SRST_PORT, SRST_PIN) == 0;
|
||||||
|
}
|
||||||
|
|
||||||
void platform_timeout_set(uint32_t ms)
|
void platform_timeout_set(uint32_t ms)
|
||||||
{
|
{
|
||||||
timeout_counter = ms / 10;
|
timeout_counter = ms / 10;
|
||||||
|
|
|
@ -67,15 +67,6 @@ void jtagtap_reset(void)
|
||||||
jtagtap_soft_reset();
|
jtagtap_soft_reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
void jtagtap_srst(bool assert)
|
|
||||||
{
|
|
||||||
(void)assert;
|
|
||||||
platform_buffer_flush();
|
|
||||||
//ftdi_write_data(ftdic, "\x80\x88\xAB", 3);
|
|
||||||
//usleep(1000);
|
|
||||||
//ftdi_write_data(ftdic, "\x80\xA8\xAB", 3);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef PROVIDE_GENERIC_TAP_TMS_SEQ
|
#ifndef PROVIDE_GENERIC_TAP_TMS_SEQ
|
||||||
void
|
void
|
||||||
jtagtap_tms_seq(uint32_t MS, int ticks)
|
jtagtap_tms_seq(uint32_t MS, int ticks)
|
||||||
|
|
|
@ -229,6 +229,14 @@ void platform_init(int argc, char **argv)
|
||||||
assert(gdb_if_init() == 0);
|
assert(gdb_if_init() == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void platform_srst_set_val(bool assert)
|
||||||
|
{
|
||||||
|
(void)assert;
|
||||||
|
platform_buffer_flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool platform_srst_get_val(void) { return false; }
|
||||||
|
|
||||||
void platform_buffer_flush(void)
|
void platform_buffer_flush(void)
|
||||||
{
|
{
|
||||||
assert(ftdi_write_data(ftdic, outbuf, bufptr) == bufptr);
|
assert(ftdi_write_data(ftdic, outbuf, bufptr) == bufptr);
|
||||||
|
|
|
@ -164,6 +164,18 @@ void platform_srst_set_val(bool assert)
|
||||||
} else {
|
} else {
|
||||||
gpio_set_val(SRST_PORT, SRST_PIN, !assert);
|
gpio_set_val(SRST_PORT, SRST_PIN, !assert);
|
||||||
}
|
}
|
||||||
|
if (assert) {
|
||||||
|
for(int i = 0; i < 10000; i++) asm("nop");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool platform_srst_get_val(void)
|
||||||
|
{
|
||||||
|
if (platform_hwversion() == 0) {
|
||||||
|
return gpio_get(SRST_PORT, SRST_SENSE_PIN) == 0;
|
||||||
|
} else {
|
||||||
|
return gpio_get(SRST_PORT, SRST_PIN) == 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool platform_target_get_power(void)
|
bool platform_target_get_power(void)
|
||||||
|
|
|
@ -80,6 +80,7 @@
|
||||||
#define PWR_BR_PIN GPIO1
|
#define PWR_BR_PIN GPIO1
|
||||||
#define SRST_PORT GPIOA
|
#define SRST_PORT GPIOA
|
||||||
#define SRST_PIN GPIO2
|
#define SRST_PIN GPIO2
|
||||||
|
#define SRST_SENSE_PIN GPIO7
|
||||||
|
|
||||||
#define USB_PU_PORT GPIOA
|
#define USB_PU_PORT GPIOA
|
||||||
#define USB_PU_PIN GPIO8
|
#define USB_PU_PIN GPIO8
|
||||||
|
@ -111,9 +112,6 @@
|
||||||
gpio_set_mode(USBUSART_PORT, GPIO_MODE_OUTPUT_2_MHZ, \
|
gpio_set_mode(USBUSART_PORT, GPIO_MODE_OUTPUT_2_MHZ, \
|
||||||
GPIO_CNF_OUTPUT_ALTFN_PUSHPULL, USBUSART_TX_PIN);
|
GPIO_CNF_OUTPUT_ALTFN_PUSHPULL, USBUSART_TX_PIN);
|
||||||
|
|
||||||
#define SRST_SET_VAL(x) \
|
|
||||||
platform_srst_set_val(x)
|
|
||||||
|
|
||||||
#define USB_DRIVER stm32f103_usb_driver
|
#define USB_DRIVER stm32f103_usb_driver
|
||||||
#define USB_IRQ NVIC_USB_LP_CAN_RX0_IRQ
|
#define USB_IRQ NVIC_USB_LP_CAN_RX0_IRQ
|
||||||
#define USB_ISR usb_lp_can_rx0_isr
|
#define USB_ISR usb_lp_can_rx0_isr
|
||||||
|
|
|
@ -118,6 +118,13 @@ void platform_srst_set_val(bool assert)
|
||||||
gpio_set(SRST_PORT, pin);
|
gpio_set(SRST_PORT, pin);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool platform_srst_get_val()
|
||||||
|
{
|
||||||
|
uint16_t pin;
|
||||||
|
pin = platform_hwversion() == 0 ? SRST_PIN_V1 : SRST_PIN_V2;
|
||||||
|
return gpio_get(SRST_PORT, pin) == 0;
|
||||||
|
}
|
||||||
|
|
||||||
const char *platform_target_voltage(void)
|
const char *platform_target_voltage(void)
|
||||||
{
|
{
|
||||||
return "unknown";
|
return "unknown";
|
||||||
|
|
|
@ -98,9 +98,6 @@
|
||||||
gpio_set_mode(USBUSART_PORT, GPIO_MODE_OUTPUT_2_MHZ, \
|
gpio_set_mode(USBUSART_PORT, GPIO_MODE_OUTPUT_2_MHZ, \
|
||||||
GPIO_CNF_OUTPUT_ALTFN_PUSHPULL, USBUSART_TX_PIN);
|
GPIO_CNF_OUTPUT_ALTFN_PUSHPULL, USBUSART_TX_PIN);
|
||||||
|
|
||||||
#define SRST_SET_VAL(x) \
|
|
||||||
platform_srst_set_val(x)
|
|
||||||
|
|
||||||
#define USB_DRIVER stm32f103_usb_driver
|
#define USB_DRIVER stm32f103_usb_driver
|
||||||
#define USB_IRQ NVIC_USB_LP_CAN_RX0_IRQ
|
#define USB_IRQ NVIC_USB_LP_CAN_RX0_IRQ
|
||||||
#define USB_ISR usb_lp_can_rx0_isr
|
#define USB_ISR usb_lp_can_rx0_isr
|
||||||
|
|
|
@ -50,19 +50,6 @@ void jtagtap_reset(void)
|
||||||
jtagtap_soft_reset();
|
jtagtap_soft_reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
void jtagtap_srst(bool assert)
|
|
||||||
{
|
|
||||||
(void)assert;
|
|
||||||
#ifdef SRST_SET_VAL
|
|
||||||
SRST_SET_VAL(assert);
|
|
||||||
if(assert) {
|
|
||||||
int i;
|
|
||||||
for(i = 0; i < 10000; i++)
|
|
||||||
asm volatile("nop");
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
inline uint8_t jtagtap_next(uint8_t dTMS, uint8_t dTDO)
|
inline uint8_t jtagtap_next(uint8_t dTMS, uint8_t dTDO)
|
||||||
{
|
{
|
||||||
uint16_t ret;
|
uint16_t ret;
|
||||||
|
|
|
@ -84,6 +84,9 @@ void platform_init(void)
|
||||||
usbuart_init();
|
usbuart_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void platform_srst_set_val(bool assert) { (void)assert; }
|
||||||
|
bool platform_srst_get_val(void) { return false; }
|
||||||
|
|
||||||
const char *platform_target_voltage(void)
|
const char *platform_target_voltage(void)
|
||||||
{
|
{
|
||||||
return "unknown";
|
return "unknown";
|
||||||
|
|
|
@ -25,18 +25,6 @@ jtagtap_reset(void)
|
||||||
jtagtap_soft_reset();
|
jtagtap_soft_reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
jtagtap_srst(bool assert)
|
|
||||||
{
|
|
||||||
volatile int i;
|
|
||||||
if (assert) {
|
|
||||||
gpio_clear(SRST_PORT, SRST_PIN);
|
|
||||||
for(i = 0; i < 10000; i++) asm("nop");
|
|
||||||
} else {
|
|
||||||
gpio_set(SRST_PORT, SRST_PIN);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t
|
uint8_t
|
||||||
jtagtap_next(const uint8_t dTMS, const uint8_t dTDO)
|
jtagtap_next(const uint8_t dTMS, const uint8_t dTDO)
|
||||||
{
|
{
|
||||||
|
|
|
@ -426,7 +426,7 @@ bool samd_probe(target *t)
|
||||||
target_add_commands(t, samd_cmd_list, "SAMD");
|
target_add_commands(t, samd_cmd_list, "SAMD");
|
||||||
|
|
||||||
/* If we're not in reset here */
|
/* If we're not in reset here */
|
||||||
if (!connect_assert_srst) {
|
if (!platform_srst_get_val()) {
|
||||||
/* We'll have to release the target from
|
/* We'll have to release the target from
|
||||||
* extended reset to make attach possible */
|
* extended reset to make attach possible */
|
||||||
if (target_mem_read32(t, SAMD_DSU_CTRLSTAT) &
|
if (target_mem_read32(t, SAMD_DSU_CTRLSTAT) &
|
||||||
|
|
|
@ -22,7 +22,6 @@
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
|
|
||||||
target *target_list = NULL;
|
target *target_list = NULL;
|
||||||
bool connect_assert_srst;
|
|
||||||
|
|
||||||
target *target_new(unsigned size)
|
target *target_new(unsigned size)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue