openocd: fix for polling during "expr" computation
Commitc7eaaf6204
("openocd: prepare for jimtcl 0.81 'expr' syntax change") replaces the jimtcl command "expr" with an openocd version that detects the TCL syntax change and prints a warning. The openocd "expr" command will be dropped after v0.12.0, One side effect is that openocd invokes polling the target after every openocd command, causing scripts that use several "expr" commands to run much slower; see [1]. The proper fix would require openocd to invoke polling only at the time period deadline, instead of at each command. Such fix is too risky to be applied now, due to short time before v0.12.0-rc1. As a temporarily workaround, let openocd to detect the "expr" command and skip the polling. This will be dropped together with the openocd "expr" command. Change-Id: I8151aa28694817001046165a15475d64896f985e Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com> Fixes: https://sourceforge.net/p/openocd/tickets/362/ [1] Fixes:c7eaaf6204
("openocd: prepare for jimtcl 0.81 'expr' syntax change") Reviewed-on: https://review.openocd.org/c/openocd/+/7174 Tested-by: jenkins Reviewed-by: Tomas Vanek <vanekt@fbl.cz>
This commit is contained in:
parent
5d6be673c3
commit
320043c054
|
@ -936,7 +936,19 @@ static int jim_command_dispatch(Jim_Interp *interp, int argc, Jim_Obj * const *a
|
||||||
if (!command_can_run(cmd_ctx, c, Jim_GetString(argv[0], NULL)))
|
if (!command_can_run(cmd_ctx, c, Jim_GetString(argv[0], NULL)))
|
||||||
return JIM_ERR;
|
return JIM_ERR;
|
||||||
|
|
||||||
target_call_timer_callbacks_now();
|
/*
|
||||||
|
* TODO: to be removed after v0.12.0
|
||||||
|
* workaround for https://sourceforge.net/p/openocd/tickets/362/
|
||||||
|
* After syntax change of "expr" in jimtcl 0.81
|
||||||
|
* the replacement of jimtcl "expr" with openocd version in
|
||||||
|
* https://review.openocd.org/6510/
|
||||||
|
* introduces too many target polling during math expressions with
|
||||||
|
* "expr" commands.
|
||||||
|
* After v0.12.0 replace the following two lines with
|
||||||
|
* target_call_timer_callbacks();
|
||||||
|
*/
|
||||||
|
if (strcmp(c->name, "expr"))
|
||||||
|
target_call_timer_callbacks_now();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Black magic of overridden current target:
|
* Black magic of overridden current target:
|
||||||
|
|
Loading…
Reference in New Issue