summaryrefslogtreecommitdiff
path: root/src/target/armv7m.c
diff options
context:
space:
mode:
authoroharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60>2008-08-20 07:14:45 +0000
committeroharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60>2008-08-20 07:14:45 +0000
commitc4567145ae8da57070e24824b8727b79dddc99a0 (patch)
tree62be6ae1673be40719eb98a788b13c9fa024859a /src/target/armv7m.c
parente5415575bd0c452c72a8ca3d3547c26f615df593 (diff)
downloadopenocd+libswd-c4567145ae8da57070e24824b8727b79dddc99a0.tar.gz
openocd+libswd-c4567145ae8da57070e24824b8727b79dddc99a0.tar.bz2
openocd+libswd-c4567145ae8da57070e24824b8727b79dddc99a0.tar.xz
openocd+libswd-c4567145ae8da57070e24824b8727b79dddc99a0.zip
fix BUG: keep_alive() error messages
git-svn-id: svn://svn.berlios.de/openocd/trunk@949 b42882b7-edfa-0310-969c-e2dbd0fdcd60
Diffstat (limited to 'src/target/armv7m.c')
-rw-r--r--src/target/armv7m.c35
1 files changed, 15 insertions, 20 deletions
diff --git a/src/target/armv7m.c b/src/target/armv7m.c
index b862cf38..f4e8062c 100644
--- a/src/target/armv7m.c
+++ b/src/target/armv7m.c
@@ -368,29 +368,24 @@ int armv7m_run_algorithm(struct target_s *target, int num_mem_params, mem_param_
target_resume(target, 0, entry_point, 1, 1);
target_poll(target);
- while (target->state != TARGET_HALTED)
+ target_wait_state(target, TARGET_HALTED, timeout_ms);
+ if (target->state != TARGET_HALTED)
{
- usleep(5000);
- target_poll(target);
- if ((timeout_ms -= 5) <= 0)
+ if ((retval=target_halt(target))!=ERROR_OK)
+ return retval;
+ if ((retval=target_wait_state(target, TARGET_HALTED, 500))!=ERROR_OK)
{
- LOG_ERROR("timeout waiting for algorithm to complete, trying to halt target");
- target_halt(target);
- timeout_ms = 1000;
- while (target->state != TARGET_HALTED)
- {
- usleep(10000);
- target_poll(target);
- if ((timeout_ms -= 10) <= 0)
- {
- LOG_ERROR("target didn't reenter debug state, exiting");
- exit(-1);
- }
- }
- armv7m->load_core_reg_u32(target, ARMV7M_REGISTER_CORE_GP, 15, &pc);
- LOG_DEBUG("failed algoritm halted at 0x%x ", pc);
- retval = ERROR_TARGET_TIMEOUT;
+ return retval;
}
+ return ERROR_TARGET_TIMEOUT;
+ }
+
+
+ armv7m->load_core_reg_u32(target, ARMV7M_REGISTER_CORE_GP, 15, &pc);
+ if (pc != exit_point)
+ {
+ LOG_DEBUG("failed algoritm halted at 0x%x ", pc);
+ return ERROR_TARGET_TIMEOUT;
}
breakpoint_remove(target, exit_point);