From 09bb073239279be4df77a40377da66a741f43c5c Mon Sep 17 00:00:00 2001
From: oharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60>
Date: Tue, 5 Aug 2008 14:58:37 +0000
Subject: [PATCH] GDB monitor commands now also get halted state upon e.g.
 "reset halt".

git-svn-id: svn://svn.berlios.de/openocd/trunk@892 b42882b7-edfa-0310-969c-e2dbd0fdcd60
---
 src/openocd.c              | 20 ++++++++++++++++++++
 src/server/telnet_server.c | 18 ------------------
 2 files changed, 20 insertions(+), 18 deletions(-)

diff --git a/src/openocd.c b/src/openocd.c
index c694b6a8a..67d890ecd 100644
--- a/src/openocd.c
+++ b/src/openocd.c
@@ -74,6 +74,22 @@ void exit_handler(void)
 		jtag->quit();
 }
 
+static int log_target_callback_event_handler(struct target_s *target, enum target_event event, void *priv)
+{
+	switch (event)
+	{
+		case TARGET_EVENT_HALTED:
+			target_arch_state(target);
+			break;
+		default:
+			break;
+	}
+
+	return ERROR_OK;
+}
+
+
+
 /* OpenOCD can't really handle failure of this command. Patches welcome! :-) */
 int handle_init_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc)
 {
@@ -128,6 +144,10 @@ int handle_init_command(struct command_context_s *cmd_ctx, char *cmd, char **arg
 	gdb_init();
 	tcl_init(); /* allows tcl to just connect without going thru telnet */
 
+	target_register_event_callback(log_target_callback_event_handler, cmd_ctx);
+
+	
+	
 	return ERROR_OK;
 }
 
diff --git a/src/server/telnet_server.c b/src/server/telnet_server.c
index 004f4ac38..c5b6bf5f9 100644
--- a/src/server/telnet_server.c
+++ b/src/server/telnet_server.c
@@ -144,20 +144,6 @@ void telnet_log_callback(void *priv, const char *file, int line,
 		telnet_write(connection, "\b", 1);
 }
 
-int telnet_target_callback_event_handler(struct target_s *target, enum target_event event, void *priv)
-{
-	switch (event)
-	{
-		case TARGET_EVENT_HALTED:
-			target_arch_state(target);
-			break;
-		default:
-			break;
-	}
-
-	return ERROR_OK;
-}
-
 int telnet_new_connection(connection_t *connection)
 {
 	telnet_connection_t *telnet_connection = malloc(sizeof(telnet_connection_t));
@@ -197,8 +183,6 @@ int telnet_new_connection(connection_t *connection)
 	telnet_connection->next_history = 0;
 	telnet_connection->current_history = 0;
 
-	target_register_event_callback(telnet_target_callback_event_handler, connection->cmd_ctx);
-
 	log_add_callback(telnet_log_callback, connection);
 
 
@@ -601,8 +585,6 @@ int telnet_connection_closed(connection_t *connection)
 		LOG_ERROR("BUG: connection->priv == NULL");
 	}
 
-	target_unregister_event_callback(telnet_target_callback_event_handler, connection->cmd_ctx);
-
 	return ERROR_OK;
 }
 
-- 
GitLab