]> git.sur5r.net Git - openocd/commitdiff
target: DCC / target message backoff algorithm
authorØyvind Harboe <oyvind.harboe@zylin.com>
Fri, 14 Oct 2011 13:05:45 +0000 (15:05 +0200)
committerØyvind Harboe <oyvindharboe@gmail.com>
Mon, 17 Oct 2011 12:32:11 +0000 (12:32 +0000)
by immediately polling again when we have received a message from
the target instead of waiting 100ms, we can hope for much better
performance. More than 100x? :-)

Change-Id: Ieaf0c6c8b6e5addc482895670ffbf9a743e07a29
Signed-off-by: Øyvind Harboe <oyvind.harboe@zylin.com>
Reviewed-on: http://openocd.zylin.com/27
Reviewed-by: Øyvind Harboe <oyvindharboe@gmail.com>
Tested-by: Øyvind Harboe <oyvindharboe@gmail.com>
src/server/server.c

index c70a52220fb728d07710109d5fd141775ece9362..84ec1ac9bbfb1c59b66cb135bbea622d6461d70f 100644 (file)
@@ -29,6 +29,7 @@
 
 #include "server.h"
 #include <target/target.h>
+#include <target/target_request.h>
 #include "openocd.h"
 #include "tcl_server.h"
 #include "telnet_server.h"
@@ -443,6 +444,13 @@ int server_loop(struct command_context *command_context)
                        poll_ok = true;
                }
 
+               /* This is a simple back-off algorithm where we immediately
+                * re-poll if we did something this time around.
+                *
+                * This greatly improves performance of DCC.
+                */
+               poll_ok = poll_ok || target_got_message();
+
                for (service = services; service; service = service->next)
                {
                        /* handle new connections on listeners */