fixed gaffe: disable interrupts reset init script
[openocd.git] / src / target / target.c
index 08a0505f2331b003aa4423e76cd2debb53740750..d42b41a8a806f5704c61688945c671b5a8b34005 100644 (file)
@@ -2,9 +2,15 @@
  *   Copyright (C) 2005 by Dominic Rath                                    *
  *   Dominic.Rath@gmx.de                                                   *
  *                                                                         *
- *   Copyright (C) 2007,2008 Øyvind Harboe                                      *
+ *   Copyright (C) 2007,2008 Øyvind Harboe                                 *
  *   oyvind.harboe@zylin.com                                               *
  *                                                                         *
+ *   Copyright (C) 2008, Duane Ellis                                       *
+ *   openocd@duaneeellis.com                                               *
+ *                                                                         *
+ *   Copyright (C) 2008 by Spencer Oliver                                  *
+ *   spen@spen-soft.co.uk                                                  *
+ *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
  *   it under the terms of the GNU General Public License as published by  *
  *   the Free Software Foundation; either version 2 of the License, or     *
@@ -50,6 +56,8 @@
 #include <fileio.h>
 #include <image.h>
 
+static int USE_OLD_RESET = 0; // temp
+
 int cli_target_callback_event_handler(struct target_s *target, enum target_event event, void *priv);
 
 
@@ -61,6 +69,7 @@ int handle_reg_command(struct command_context_s *cmd_ctx, char *cmd, char **args
 int handle_poll_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc);
 int handle_halt_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc);
 int handle_wait_halt_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc);
+int handle_NEWreset_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc);
 int handle_reset_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc);
 int handle_soft_reset_halt_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc);
 int handle_resume_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc);
@@ -160,8 +169,9 @@ const Jim_Nvp nvp_target_event[] = {
        { .value = TARGET_EVENT_OLD_gdb_program_config , .name = "old-gdb_program_config" },
        { .value = TARGET_EVENT_OLD_post_reset         , .name = "old-post_reset" },
        { .value = TARGET_EVENT_OLD_pre_resume         , .name = "old-pre_resume" },
-       
 
+
+       { .value = TARGET_EVENT_EARLY_HALTED, .name = "early-halted" },
        { .value = TARGET_EVENT_HALTED, .name = "halted" },
        { .value = TARGET_EVENT_RESUMED, .name = "resumed" },
        { .value = TARGET_EVENT_RESUME_START, .name = "resume-start" },
@@ -188,7 +198,7 @@ const Jim_Nvp nvp_target_event[] = {
 
        { .value = TARGET_EVENT_EXAMINE_START, .name = "examine-start" },
        { .value = TARGET_EVENT_EXAMINE_START, .name = "examine-end" },
-       
+
 
        { .value = TARGET_EVENT_DEBUG_HALTED, .name = "debug-halted" },
        { .value = TARGET_EVENT_DEBUG_RESUMED, .name = "debug-resumed" },
@@ -342,7 +352,7 @@ target_t* get_target_by_num(int num)
        while (target){
                if( target->target_number == num ){
                        return target;
-               } 
+               }
                target = target->next;
        }
 
@@ -411,8 +421,28 @@ int target_resume(struct target_s *target, int current, u32 address, int handle_
        return retval;
 }
 
+
+static int NEW_target_process_reset(struct command_context_s *cmd_ctx, enum target_reset_mode reset_mode)
+{
+       char buf[100];
+       Jim_Nvp *n;
+       n = Jim_Nvp_value2name_simple( nvp_reset_modes, reset_mode );
+       if( n->name == NULL ){
+               LOG_ERROR("invalid reset mode");
+               return ERROR_FAIL;
+       }
+
+       sprintf( buf, "ocd_process_reset %s", n->name );
+       Jim_Eval( interp, buf );
+
+       /* We want any events to be processed before the prompt */
+       target_call_timer_callbacks_now();
+
+       return ERROR_OK;
+}
+
 // Next patch - this turns into TCL...
-int target_process_reset(struct command_context_s *cmd_ctx, enum target_reset_mode reset_mode)
+static int OLD_target_process_reset(struct command_context_s *cmd_ctx, enum target_reset_mode reset_mode)
 {
        int retval = ERROR_OK;
        target_t *target;
@@ -507,6 +537,16 @@ int target_process_reset(struct command_context_s *cmd_ctx, enum target_reset_mo
        return retval;
 }
 
+int target_process_reset(struct command_context_s *cmd_ctx, enum target_reset_mode reset_mode)
+{
+       if( USE_OLD_RESET ){
+               return OLD_target_process_reset( cmd_ctx, reset_mode );
+       } else {
+               return NEW_target_process_reset( cmd_ctx, reset_mode );
+       }
+}
+
+
 static int default_virt2phys(struct target_s *target, u32 virtual, u32 *physical)
 {
        *physical = virtual;
@@ -758,8 +798,15 @@ int target_call_event_callbacks(target_t *target, enum target_event event)
        target_event_callback_t *callback = target_event_callbacks;
        target_event_callback_t *next_callback;
 
-       LOG_DEBUG("target event %i (%s)", 
-                         event, 
+       if (event == TARGET_EVENT_HALTED)
+       {
+               /* execute early halted first */
+               target_call_event_callbacks(target, TARGET_EVENT_EARLY_HALTED);
+       }
+
+
+       LOG_DEBUG("target event %i (%s)",
+                         event,
                          Jim_Nvp_value2name_simple( nvp_target_event, event )->name );
 
        target_handle_event( target, event );
@@ -826,7 +873,7 @@ int target_call_timer_callbacks(void)
 /* invoke periodic callbacks immediately */
 int target_call_timer_callbacks_now(void)
 {
-       return target_call_timer_callbacks();
+       return target_call_timer_callbacks_check_time(0);
 }
 
 int target_alloc_working_area(struct target_s *target, u32 size, working_area_t **area)
@@ -1000,7 +1047,7 @@ int target_arch_state(struct target_s *target)
                return ERROR_OK;
        }
 
-       LOG_USER("target state: %s", 
+       LOG_USER("target state: %s",
                 Jim_Nvp_value2name_simple(nvp_target_state,target->state)->name);
 
        if (target->state!=TARGET_HALTED)
@@ -1355,7 +1402,8 @@ int target_register_user_commands(struct command_context_s *cmd_ctx)
        register_command(cmd_ctx,  NULL, "halt", handle_halt_command, COMMAND_EXEC, "halt target");
        register_command(cmd_ctx,  NULL, "resume", handle_resume_command, COMMAND_EXEC, "resume target [addr]");
        register_command(cmd_ctx,  NULL, "step", handle_step_command, COMMAND_EXEC, "step one instruction from current PC or [addr]");
-       register_command(cmd_ctx,  NULL, "reset", handle_reset_command, COMMAND_EXEC, "reset target [run|halt|init] - default is run");
+       register_command(cmd_ctx,  NULL, "NEWreset", handle_NEWreset_command, COMMAND_EXEC, "reset target [run|halt|init] - default is run");
+       register_command(cmd_ctx,  NULL, "reset", handle_reset_command, COMMAND_EXEC, "OLDreset target [run|halt|init] - default is run");
        register_command(cmd_ctx,  NULL, "soft_reset_halt", handle_soft_reset_halt_command, COMMAND_EXEC, "halt the target and do a soft reset");
 
        register_command(cmd_ctx,  NULL, "mdw", handle_md_command, COMMAND_EXEC, "display memory words <addr> [count]");
@@ -1394,18 +1442,18 @@ int handle_targets_command(struct command_context_s *cmd_ctx, char *cmd, char **
                        if( 0 == strcmp( args[0], target->cmd_name ) ){
                                /* MATCH */
                                goto Match;
-                       } 
+                       }
                  }
                }
                /* no match, try as number */
-               
+
                int num = strtoul(args[0], &cp, 0 );
                if( *cp != 0 ){
                        /* then it was not a number */
                        command_print( cmd_ctx, "Target: %s unknown, try one of:\n", args[0] );
                        goto DumpTargets;
                }
-                       
+
                target = get_target_by_num( num );
                if( target == NULL ){
                        command_print(cmd_ctx,"Target: %s is unknown, try one of:\n", args[0] );
@@ -1422,11 +1470,11 @@ int handle_targets_command(struct command_context_s *cmd_ctx, char *cmd, char **
        while (target)
        {
                /* XX: abcdefghij abcdefghij abcdefghij abcdefghij */
-               command_print(cmd_ctx, "%2d: %-10s %-10s %-10s %8d %s", 
+               command_print(cmd_ctx, "%2d: %-10s %-10s %-10s %8d %s",
                                          target->target_number,
                                          target->cmd_name,
-                                         target->type->name, 
-                                         Jim_Nvp_value2name_simple( nvp_target_endian, target->endianness )->name, 
+                                         target->type->name,
+                                         Jim_Nvp_value2name_simple( nvp_target_endian, target->endianness )->name,
                                          target->chain_position,
                                          Jim_Nvp_value2name_simple( nvp_target_state, target->state )->name );
                target = target->next;
@@ -1689,14 +1737,14 @@ int target_wait_state(target_t *target, enum target_state state, int ms)
                if (once)
                {
                        once=0;
-                       LOG_DEBUG("waiting for target %s...", 
+                       LOG_DEBUG("waiting for target %s...",
                              Jim_Nvp_value2name_simple(nvp_target_state,state)->name);
                }
 
                gettimeofday(&now, NULL);
                if ((now.tv_sec > timeout.tv_sec) || ((now.tv_sec == timeout.tv_sec) && (now.tv_usec >= timeout.tv_usec)))
                {
-                       LOG_ERROR("timed out while waiting for target %s", 
+                       LOG_ERROR("timed out while waiting for target %s",
                              Jim_Nvp_value2name_simple(nvp_target_state,state)->name);
                        return ERROR_FAIL;
                }
@@ -1749,6 +1797,25 @@ int handle_reset_command(struct command_context_s *cmd_ctx, char *cmd, char **ar
        return target_process_reset(cmd_ctx, reset_mode);
 }
 
+int handle_NEWreset_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc)
+{
+       int x;
+       char *cp;
+
+       if (argc >= 1){
+               x = strtol( args[0], &cp, 0 );
+               if( *cp != 0 ){
+                       command_print( cmd_ctx, "Not numeric: %s\n", args[0] );
+                       return ERROR_COMMAND_SYNTAX_ERROR;
+               }
+               USE_OLD_RESET = !!x;
+       }
+       command_print( cmd_ctx, "reset method: %d (%s)\n",
+                                  USE_OLD_RESET,
+                                  USE_OLD_RESET ? "old-method" : "new-method" );
+       return ERROR_OK;
+}
+
 int handle_resume_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc)
 {
        int retval;
@@ -2801,7 +2868,7 @@ static int jim_array2mem(Jim_Interp *interp, int argc, Jim_Obj *const *argv)
 {
        command_context_t *context;
        target_t *target;
-       
+
        context = Jim_GetAssocData(interp, "context");
        if (context == NULL){
                LOG_ERROR("array2mem: no command context");
@@ -2812,10 +2879,10 @@ static int jim_array2mem(Jim_Interp *interp, int argc, Jim_Obj *const *argv)
                LOG_ERROR("array2mem: no current target");
                return JIM_ERR;
        }
-       
+
        return target_array2mem( interp,target, argc, argv );
 }
-                          
+
 
 static int target_array2mem(Jim_Interp *interp, target_t *target, int argc, Jim_Obj *const *argv)
 {
@@ -2955,7 +3022,7 @@ target_all_handle_event( enum target_event e )
        target_t *target;
 
 
-       LOG_DEBUG( "**all*targets: event: %d, %s", 
+       LOG_DEBUG( "**all*targets: event: %d, %s",
                   e,
                   Jim_Nvp_value2name_simple( nvp_target_event, e )->name );
 
@@ -2990,7 +3057,7 @@ target_handle_event( target_t *target, enum target_event e )
                teap = teap->next;
        }
        if( !done ){
-               LOG_DEBUG( "event: %d %s - no action", 
+               LOG_DEBUG( "event: %d %s - no action",
                                   e,
                                   Jim_Nvp_value2name_simple( nvp_target_event, e )->name );
        }
@@ -2998,8 +3065,7 @@ target_handle_event( target_t *target, enum target_event e )
 
 enum target_cfg_param {
        TCFG_TYPE,
-       TCFG_EVENT, 
-       TCFG_RESET,
+       TCFG_EVENT,
        TCFG_WORK_AREA_VIRT,
        TCFG_WORK_AREA_PHYS,
        TCFG_WORK_AREA_SIZE,
@@ -3013,7 +3079,6 @@ enum target_cfg_param {
 static Jim_Nvp nvp_config_opts[] = {
        { .name = "-type",             .value = TCFG_TYPE },
        { .name = "-event",            .value = TCFG_EVENT },
-       { .name = "-reset",            .value = TCFG_RESET },
        { .name = "-work-area-virt",   .value = TCFG_WORK_AREA_VIRT },
        { .name = "-work-area-phys",   .value = TCFG_WORK_AREA_PHYS },
        { .name = "-work-area-size",   .value = TCFG_WORK_AREA_SIZE },
@@ -3021,10 +3086,10 @@ static Jim_Nvp nvp_config_opts[] = {
        { .name = "-endian" ,          .value = TCFG_ENDIAN },
        { .name = "-variant",          .value = TCFG_VARIANT },
        { .name = "-chain-position",   .value = TCFG_CHAIN_POSITION },
-       
+
        { .name = NULL, .value = -1 }
 };
-         
+
 
 static int
 target_configure( Jim_GetOptInfo *goi,
@@ -3038,7 +3103,7 @@ target_configure( Jim_GetOptInfo *goi,
 
 
        /* parse config or cget options ... */
-       while( goi->argc ){
+       while( goi->argc > 0 ){
                Jim_SetEmptyResult( goi->interp );
                //Jim_GetOpt_Debug( goi );
 
@@ -3093,7 +3158,7 @@ target_configure( Jim_GetOptInfo *goi,
                                if( goi->argc == 0 ){
                                        Jim_WrongNumArgs( goi->interp, goi->argc, goi->argv, "-event ?event-name? ?EVENT-BODY?");
                                        return JIM_ERR;
-                               }  
+                               }
                        } else {
                                if( goi->argc != 0 ){
                                        Jim_WrongNumArgs(goi->interp, goi->argc, goi->argv, "-event ?event-name?");
@@ -3101,10 +3166,10 @@ target_configure( Jim_GetOptInfo *goi,
                                }
                        }
 
-       
-                       { 
+
+                       {
                                target_event_action_t *teap;
-                               
+
                                teap = target->event_action;
                                /* replace existing? */
                                while( teap ){
@@ -3113,7 +3178,7 @@ target_configure( Jim_GetOptInfo *goi,
                                        }
                                        teap = teap->next;
                                }
-                               
+
                                if( goi->isconfigure ){
                                        if( teap == NULL ){
                                                /* create new */
@@ -3126,7 +3191,7 @@ target_configure( Jim_GetOptInfo *goi,
                                        }
                                        teap->body  = Jim_DuplicateObj( goi->interp, o );
                                        /*
-                                        * FIXME: 
+                                        * FIXME:
                                         *     Tcl/TK - "tk events" have a nice feature.
                                         *     See the "BIND" command.
                                         *    We should support that here.
@@ -3153,32 +3218,6 @@ target_configure( Jim_GetOptInfo *goi,
                        /* loop for more */
                        break;
 
-               case TCFG_RESET:
-                       if( goi->isconfigure ){
-                               e = Jim_GetOpt_Nvp( goi, nvp_reset_modes, &n );
-                               if( e != JIM_OK ){
-                                       Jim_GetOpt_NvpUnknown( goi, nvp_reset_modes, 1 );
-                                       return e;
-                               }
-                               if( n->value == RESET_UNKNOWN ){
-                                       Jim_SetResultString( interp, "'unknown' is not a valid selection",-1);
-                                       return JIM_ERR;
-                               }
-                               target->reset_mode = n->value;
-                       } else {
-                               if( goi->argc != 0 ){
-                                       goto no_params;
-                               }
-                       }
-                       n = Jim_Nvp_value2name_simple( nvp_reset_modes, target->reset_mode );
-                       if( n->name == NULL ){
-                               target->reset_mode = RESET_HALT;
-                               n = Jim_Nvp_value2name_simple( nvp_reset_modes, target->reset_mode );
-                       }
-                       Jim_SetResultString( goi->interp, n->name, -1 );
-                       /* loop for more */
-                       break;
-                       
                case TCFG_WORK_AREA_VIRT:
                        if( goi->isconfigure ){
                                target_free_all_working_areas(target);
@@ -3191,11 +3230,11 @@ target_configure( Jim_GetOptInfo *goi,
                                if( goi->argc != 0 ){
                                        goto no_params;
                                }
-                       } 
+                       }
                        Jim_SetResult( interp, Jim_NewIntObj( goi->interp, target->working_area_virt ) );
                        /* loop for more */
                        break;
-                               
+
                case TCFG_WORK_AREA_PHYS:
                        if( goi->isconfigure ){
                                target_free_all_working_areas(target);
@@ -3208,7 +3247,7 @@ target_configure( Jim_GetOptInfo *goi,
                                if( goi->argc != 0 ){
                                        goto no_params;
                                }
-                       } 
+                       }
                        Jim_SetResult( interp, Jim_NewIntObj( goi->interp, target->working_area_phys ) );
                        /* loop for more */
                        break;
@@ -3225,7 +3264,7 @@ target_configure( Jim_GetOptInfo *goi,
                                if( goi->argc != 0 ){
                                        goto no_params;
                                }
-                       } 
+                       }
                        Jim_SetResult( interp, Jim_NewIntObj( goi->interp, target->working_area_size ) );
                        /* loop for more */
                        break;
@@ -3243,7 +3282,7 @@ target_configure( Jim_GetOptInfo *goi,
                                if( goi->argc != 0 ){
                                        goto no_params;
                                }
-                       } 
+                       }
                        Jim_SetResult( interp, Jim_NewIntObj( goi->interp, target->working_area_size ) );
                        /* loop for more e*/
                        break;
@@ -3265,7 +3304,7 @@ target_configure( Jim_GetOptInfo *goi,
                        if( n->name == NULL ){
                                target->endianness = TARGET_LITTLE_ENDIAN;
                                n = Jim_Nvp_value2name_simple( nvp_target_endian, target->endianness );
-                       } 
+                       }
                        Jim_SetResultString( goi->interp, n->name, -1 );
                        /* loop for more */
                        break;
@@ -3287,7 +3326,7 @@ target_configure( Jim_GetOptInfo *goi,
                                if( goi->argc != 0 ){
                                        goto no_params;
                                }
-                       } 
+                       }
                        Jim_SetResultString( goi->interp, target->variant,-1 );
                        /* loop for more */
                        break;
@@ -3304,13 +3343,13 @@ target_configure( Jim_GetOptInfo *goi,
                                if( goi->argc != 0 ){
                                        goto no_params;
                                }
-                       } 
+                       }
                        Jim_SetResult( interp, Jim_NewIntObj( goi->interp, target->chain_position ) );
                        /* loop for more e*/
                        break;
                }
-       }
-       /* done - we return */
+       } /* while( goi->argc ) */
+               /* done - we return */
        return JIM_OK;
 }
 
@@ -3318,7 +3357,7 @@ target_configure( Jim_GetOptInfo *goi,
 /** this is the 'tcl' handler for the target specific command */
 static int
 tcl_target_func( Jim_Interp *interp,
-                                int argc, 
+                                int argc,
                                 Jim_Obj *const *argv )
 {
        Jim_GetOptInfo goi;
@@ -3334,20 +3373,21 @@ tcl_target_func( Jim_Interp *interp,
        enum {
                TS_CMD_CONFIGURE,
                TS_CMD_CGET,
-               
+
                TS_CMD_MWW, TS_CMD_MWH, TS_CMD_MWB,
                TS_CMD_MDW, TS_CMD_MDH, TS_CMD_MDB,
                TS_CMD_MRW, TS_CMD_MRH, TS_CMD_MRB,
                TS_CMD_MEM2ARRAY, TS_CMD_ARRAY2MEM,
-               TS_CMD_EXAMINE, 
+               TS_CMD_EXAMINE,
                TS_CMD_POLL,
                TS_CMD_RESET,
                TS_CMD_HALT,
                TS_CMD_WAITSTATE,
                TS_CMD_EVENTLIST,
                TS_CMD_CURSTATE,
+               TS_CMD_INVOKE_EVENT,
        };
-       
+
        static const Jim_Nvp target_options[] = {
                { .name = "configure", .value = TS_CMD_CONFIGURE },
                { .name = "cget", .value = TS_CMD_CGET },
@@ -3367,6 +3407,7 @@ tcl_target_func( Jim_Interp *interp,
                { .name = "arp_reset", .value = TS_CMD_RESET },
                { .name = "arp_halt", .value = TS_CMD_HALT },
                { .name = "arp_waitstate", .value = TS_CMD_WAITSTATE },
+               { .name = "invoke-event", .value = TS_CMD_INVOKE_EVENT },
 
                { .name = NULL, .value = -1 },
        };
@@ -3412,7 +3453,7 @@ tcl_target_func( Jim_Interp *interp,
                 * argv[2] = data
                 * argv[3] = optional count.
                 */
-                 
+
                if( (goi.argc == 3) || (goi.argc == 4) ){
                        /* all is well */
                } else {
@@ -3420,7 +3461,7 @@ tcl_target_func( Jim_Interp *interp,
                        Jim_SetResult_sprintf( goi.interp, "expected: %s ADDR DATA [COUNT]", n->name );
                        return JIM_ERR;
                }
-               
+
                e = Jim_GetOpt_Wide( &goi, &a );
                if( e != JIM_OK ){
                        goto mwx_error;
@@ -3438,7 +3479,7 @@ tcl_target_func( Jim_Interp *interp,
                } else {
                        c = 1;
                }
-                       
+
                switch( n->value ){
                case TS_CMD_MWW:
                        target_buffer_set_u32( target, target_buf, b );
@@ -3515,7 +3556,7 @@ tcl_target_func( Jim_Interp *interp,
                                Jim_SetResult_sprintf( interp, "error reading target @ 0x%08lx", (int)(a) );
                                return JIM_ERR;
                        }
-                       
+
                        Jim_fprintf( interp, interp->cookie_stdout, "0x%08x ", (int)(a) );
                        switch( b ){
                        case 4:
@@ -3549,7 +3590,7 @@ tcl_target_func( Jim_Interp *interp,
                        }
                        /* ascii-ify the bytes */
                        for( x = 0 ; x < y ; x++ ){
-                               if( (target_buf[x] >= 0x20) && 
+                               if( (target_buf[x] >= 0x20) &&
                                        (target_buf[x] <= 0x7e) ){
                                        /* good */
                                } else {
@@ -3579,7 +3620,7 @@ tcl_target_func( Jim_Interp *interp,
                break;
        case TS_CMD_EXAMINE:
                if( goi.argc ){
-                       Jim_WrongNumArgs( goi.interp, 0, argv, "[no parameters]");
+                       Jim_WrongNumArgs( goi.interp, 2, argv, "[no parameters]");
                        return JIM_ERR;
                }
                e = target->type->examine( target );
@@ -3590,7 +3631,7 @@ tcl_target_func( Jim_Interp *interp,
                return JIM_OK;
        case TS_CMD_POLL:
                if( goi.argc ){
-                       Jim_WrongNumArgs( goi.interp, 0, argv, "[no parameters]");
+                       Jim_WrongNumArgs( goi.interp, 2, argv, "[no parameters]");
                        return JIM_ERR;
                }
                if( !(target->type->examined) ){
@@ -3606,8 +3647,8 @@ tcl_target_func( Jim_Interp *interp,
                }
                break;
        case TS_CMD_RESET:
-               if( goi.argc != 1 ){
-                       Jim_WrongNumArgs( interp, 1, argv, "reset t|f|assert|deassert");
+               if( goi.argc != 2 ){
+                       Jim_WrongNumArgs( interp, 2, argv, "t|f|assert|deassert BOOL");
                        return JIM_ERR;
                }
                e = Jim_GetOpt_Nvp( &goi, nvp_assert, &n );
@@ -3615,6 +3656,13 @@ tcl_target_func( Jim_Interp *interp,
                        Jim_GetOpt_NvpUnknown( &goi, nvp_assert, 1 );
                        return e;
                }
+               // the halt or not param
+               e = Jim_GetOpt_Wide( &goi, &a);
+               if( e != JIM_OK ){
+                       return e;
+               }
+               // determine if we should halt or not.
+               target->reset_halt = !!a;
                // When this happens - all workareas are invalid.
                target_free_all_working_areas_restore(target, 0);
 
@@ -3633,7 +3681,7 @@ tcl_target_func( Jim_Interp *interp,
                target->type->halt( target );
                return JIM_OK;
        case TS_CMD_WAITSTATE:
-               // params:  <name>  statename timeoutmsecs 
+               // params:  <name>  statename timeoutmsecs
                if( goi.argc != 2 ){
                        Jim_SetResult_sprintf( goi.interp, "%s STATENAME TIMEOUTMSECS", n->name );
                        return JIM_ERR;
@@ -3648,12 +3696,12 @@ tcl_target_func( Jim_Interp *interp,
                        return e;
                }
                e = target_wait_state( target, n->value, a );
-               if( e == ERROR_OK ){
+               if( e != ERROR_OK ){
                        Jim_SetResult_sprintf( goi.interp,
-                                                                  "target: %s wait %s fails %d", 
+                                                                  "target: %s wait %s fails (%d) %s",
                                                                   target->cmd_name,
                                                                   n->name,
-                                                                  target_strerror_safe(e) );
+                                              e, target_strerror_safe(e) );
                        return JIM_ERR;
                } else {
                        return JIM_OK;
@@ -3666,12 +3714,12 @@ tcl_target_func( Jim_Interp *interp,
                        target_event_action_t *teap;
                        teap = target->event_action;
                        command_print( cmd_ctx, "Event actions for target (%d) %s\n",
-                                                  target->target_number, 
+                                                  target->target_number,
                                                   target->cmd_name );
                        command_print( cmd_ctx, "%-25s | Body", "Event");
                        command_print( cmd_ctx, "------------------------- | ----------------------------------------");
                        while( teap ){
-                               command_print( cmd_ctx, 
+                               command_print( cmd_ctx,
                                                           "%-25s | %s",
                                                           Jim_Nvp_value2name_simple( nvp_target_event, teap->event )->name,
                                                           Jim_GetString( teap->body, NULL ) );
@@ -3685,9 +3733,21 @@ tcl_target_func( Jim_Interp *interp,
                        Jim_WrongNumArgs( goi.interp, 0, argv, "[no parameters]");
                        return JIM_ERR;
                }
-               Jim_SetResultString( goi.interp, 
+               Jim_SetResultString( goi.interp,
                                                         Jim_Nvp_value2name_simple(nvp_target_state,target->state)->name,-1);
                return JIM_OK;
+       case TS_CMD_INVOKE_EVENT:
+               if( goi.argc != 1 ){
+                       Jim_SetResult_sprintf( goi.interp, "%s ?EVENTNAME?",n->name);
+                       return JIM_ERR;
+               }
+               e = Jim_GetOpt_Nvp( &goi, nvp_target_event, &n );
+               if( e != JIM_OK ){
+                       Jim_GetOpt_NvpUnknown( &goi, nvp_target_event, 1 );
+                       return e;
+               }
+               target_handle_event( target, n->value );
+               return JIM_OK;
        }
        return JIM_ERR;
 }
@@ -3695,8 +3755,8 @@ tcl_target_func( Jim_Interp *interp,
 
 static int
 target_create( Jim_GetOptInfo *goi )
-{      
-       
+{
+
        Jim_Obj *new_cmd;
        Jim_Cmd *cmd;
        const char *cp;
@@ -3721,7 +3781,7 @@ target_create( Jim_GetOptInfo *goi )
                Jim_SetResult_sprintf(goi->interp, "Command/target: %s Exists", cp);
                return JIM_ERR;
        }
-       
+
        /* TYPE */
        e = Jim_GetOpt_String( goi, &cp2, NULL );
        cp = cp2;
@@ -3736,12 +3796,12 @@ target_create( Jim_GetOptInfo *goi )
                Jim_SetResult_sprintf( goi->interp, "Unknown target type %s, try one of ", cp );
                for( x = 0 ; target_types[x] ; x++ ){
                        if( target_types[x+1] ){
-                               Jim_AppendStrings( goi->interp, 
+                               Jim_AppendStrings( goi->interp,
                                                                   Jim_GetResult(goi->interp),
                                                                   target_types[x]->name,
                                                                   ", ", NULL);
                        } else {
-                               Jim_AppendStrings( goi->interp, 
+                               Jim_AppendStrings( goi->interp,
                                                                   Jim_GetResult(goi->interp),
                                                                   " or ",
                                                                   target_types[x]->name,NULL );
@@ -3750,7 +3810,7 @@ target_create( Jim_GetOptInfo *goi )
                return JIM_ERR;
        }
 
-               
+
        /* Create it */
        target = calloc(1,sizeof(target_t));
        /* set target number */
@@ -3760,7 +3820,7 @@ target_create( Jim_GetOptInfo *goi )
        target->type = (target_type_t*)calloc(1,sizeof(target_type_t));
 
        memcpy( target->type, target_types[x], sizeof(target_type_t));
-       
+
        /* will be set by "-endian" */
        target->endianness = TARGET_ENDIAN_UNKNOWN;
 
@@ -3768,7 +3828,7 @@ target_create( Jim_GetOptInfo *goi )
        target->working_area_size   = 0x0;
        target->working_areas       = NULL;
        target->backup_working_area = 0;
-       
+
        target->state               = TARGET_UNKNOWN;
        target->debug_reason        = DBG_REASON_UNDEFINED;
        target->reg_cache           = NULL;
@@ -3776,7 +3836,7 @@ target_create( Jim_GetOptInfo *goi )
        target->watchpoints         = NULL;
        target->next                = NULL;
        target->arch_info           = NULL;
-       
+
        /* initialize trace information */
        target->trace_info = malloc(sizeof(trace_t));
        target->trace_info->num_trace_points         = 0;
@@ -3786,7 +3846,7 @@ target_create( Jim_GetOptInfo *goi )
        target->trace_info->trace_history            = NULL;
        target->trace_info->trace_history_pos        = 0;
        target->trace_info->trace_history_overflowed = 0;
-       
+
        target->dbgmsg          = NULL;
        target->dbg_msg_enabled = 0;
 
@@ -3858,9 +3918,9 @@ jim_target( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
                TG_CMD_COUNT,
        };
        const char *target_cmds[] = {
-               "create", "types", "names", "current", "number", 
+               "create", "types", "names", "current", "number",
                "count",
-               NULL // terminate 
+               NULL // terminate
        };
 
        LOG_DEBUG("Target command params:");
@@ -3887,9 +3947,9 @@ jim_target( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
                /* YES IT IS OLD SYNTAX */
                Jim_Obj *new_argv[10];
                int      new_argc;
-               
-               /* target_old_syntax 
-                * 
+
+               /* target_old_syntax
+                *
                 * argv[0] typename (above)
                 * argv[1] endian
                 * argv[2] reset method, deprecated/ignored
@@ -3936,14 +3996,14 @@ jim_target( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
                 *   argv[8] = -variant
                 *   argv[9] = "somestring"
                 */
-               
+
                /* don't let these be released */
                for( x = 0 ; x < new_argc ; x++ ){
                        Jim_IncrRefCount( new_argv[x]);
                }
                /* call our self */
                LOG_DEBUG("Target OLD SYNTAX - converted to new syntax");
-               
+
                r = jim_target( goi.interp, new_argc, new_argv );
 
                /* release? these items */
@@ -3995,7 +4055,7 @@ jim_target( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
                                                                   Jim_NewStringObj( goi.interp, target->cmd_name, -1 ) );
                        target = target->next;
                }
-               return JIM_OK;          
+               return JIM_OK;
        case TG_CMD_CREATE:
                if( goi.argc < 3 ){
                        Jim_WrongNumArgs( goi.interp, goi.argc, goi.argv, "?name  ... config options ...");
@@ -4027,17 +4087,10 @@ jim_target( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
                        Jim_WrongNumArgs( goi.interp, 0, goi.argv, "<no parameters>");
                        return JIM_ERR;
                }
-               Jim_SetResult( goi.interp, 
+               Jim_SetResult( goi.interp,
                                           Jim_NewIntObj( goi.interp, max_target_number()));
                return JIM_OK;
        }
-}
-
-
 
-/*
- * Local Variables: ***
- * c-basic-offset: 4 ***
- * tab-width: 4 ***
- * End: ***
- */
+       return JIM_ERR;
+}

Linking to existing account procedure

If you already have an account and want to add another login method you MUST first sign in with your existing account and then change URL to read https://review.openocd.org/login/?link to get to this page again but this time it'll work for linking. Thank you.

SSH host keys fingerprints

1024 SHA256:YKx8b7u5ZWdcbp7/4AeXNaqElP49m6QrwfXaqQGJAOk gerrit-code-review@openocd.zylin.com (DSA)
384 SHA256:jHIbSQa4REvwCFG4cq5LBlBLxmxSqelQPem/EXIrxjk gerrit-code-review@openocd.org (ECDSA)
521 SHA256:UAOPYkU9Fjtcao0Ul/Rrlnj/OsQvt+pgdYSZ4jOYdgs gerrit-code-review@openocd.org (ECDSA)
256 SHA256:A13M5QlnozFOvTllybRZH6vm7iSt0XLxbA48yfc2yfY gerrit-code-review@openocd.org (ECDSA)
256 SHA256:spYMBqEYoAOtK7yZBrcwE8ZpYt6b68Cfh9yEVetvbXg gerrit-code-review@openocd.org (ED25519)
+--[ED25519 256]--+
|=..              |
|+o..   .         |
|*.o   . .        |
|+B . . .         |
|Bo. = o S        |
|Oo.+ + =         |
|oB=.* = . o      |
| =+=.+   + E     |
|. .=o   . o      |
+----[SHA256]-----+
2048 SHA256:0Onrb7/PHjpo6iVZ7xQX2riKN83FJ3KGU0TvI0TaFG4 gerrit-code-review@openocd.zylin.com (RSA)