From 8d0e3395a0ec1082872df71d0f982ede60e17bfb Mon Sep 17 00:00:00 2001 From: oharboe Date: Tue, 19 Aug 2008 12:17:31 +0000 Subject: [PATCH] added alive_sleep() function to let GDB alive packets be sent git-svn-id: svn://svn.berlios.de/openocd/trunk@938 b42882b7-edfa-0310-969c-e2dbd0fdcd60 --- src/helper/log.c | 17 +++++++++++++++++ src/helper/log.h | 1 + 2 files changed, 18 insertions(+) diff --git a/src/helper/log.c b/src/helper/log.c index ef1a6bb06..efe5d5bb9 100644 --- a/src/helper/log.c +++ b/src/helper/log.c @@ -385,3 +385,20 @@ void kept_alive() current_time=timeval_ms(); last_time=current_time; } + +/* if we sleep for extended periods of time, we must invoke keep_alive() intermittantly */ +void alive_sleep(int ms) +{ + int i; + for (i=0; i500) + { + sleep_a_bit=500; + } + keep_alive(); + usleep(sleep_a_bit*1000); + keep_alive(); + } +} diff --git a/src/helper/log.h b/src/helper/log.h index c329fb588..b6f166beb 100644 --- a/src/helper/log.h +++ b/src/helper/log.h @@ -61,6 +61,7 @@ extern int log_init(struct command_context_s *cmd_ctx); extern int set_log_output(struct command_context_s *cmd_ctx, FILE *output); extern void keep_alive(void); extern void kept_alive(void); +extern void alive_sleep(int ms); typedef void (*log_callback_fn)(void *priv, const char *file, int line, const char *function, const char *string);