David Brownell <david-b@pacbell.net>:

Let disabled targets be ignored during normal operation:

 - In target_examine(), ignore disabled TAPs

 - Reset handling must not poke at them either:
     * fail $target_name arp_* operations on disabled TAPs
     * in startup.tcl, don't even issue the arp_* wait ops 

ZW: removed superfluous braces from the patch to target.c.


git-svn-id: svn://svn.berlios.de/openocd/trunk@2100 b42882b7-edfa-0310-969c-e2dbd0fdcd60
__archive__
zwelch 2009-06-07 23:35:29 +00:00
parent d512fe71ea
commit 695c6c0960
2 changed files with 42 additions and 8 deletions

View File

@ -164,6 +164,11 @@ proc ocd_process_reset { MODE } {
return -error "Invalid mode: $MODE, must be one of: halt, init, or run"; return -error "Invalid mode: $MODE, must be one of: halt, init, or run";
} }
# Target event handlers *might* change which TAPs are enabled
# or disabled, so we fire all of them. But don't issue any
# of the "arp_*" commands, which may issue JTAG transactions,
# unless we know the underlying TAP is active.
foreach t [ target names ] { foreach t [ target names ] {
# New event script. # New event script.
$t invoke-event reset-start $t invoke-event reset-start
@ -172,16 +177,20 @@ proc ocd_process_reset { MODE } {
# Init the tap controller. # Init the tap controller.
jtag arp_init-reset jtag arp_init-reset
# Examine all targets. # Examine all targets on enabled taps.
foreach t [ target names ] { foreach t [ target names ] {
$t arp_examine if {[jtag tapisenabled [$t cget -chain-position]]} {
$t arp_examine
}
} }
# Let the C code know we are asserting reset. # Let the C code know we are asserting reset.
foreach t [ target names ] { foreach t [ target names ] {
$t invoke-event reset-assert-pre $t invoke-event reset-assert-pre
# C code needs to know if we expect to 'halt' # C code needs to know if we expect to 'halt'
$t arp_reset assert $halt if {[jtag tapisenabled [$t cget -chain-position]]} {
$t arp_reset assert $halt
}
$t invoke-event reset-assert-post $t invoke-event reset-assert-post
} }
@ -189,14 +198,19 @@ proc ocd_process_reset { MODE } {
foreach t [ target names ] { foreach t [ target names ] {
$t invoke-event reset-deassert-pre $t invoke-event reset-deassert-pre
# Again, de-assert code needs to know.. # Again, de-assert code needs to know..
$t arp_reset deassert $halt if {[jtag tapisenabled [$t cget -chain-position]]} {
$t arp_reset deassert $halt
}
$t invoke-event reset-deassert-post $t invoke-event reset-deassert-post
} }
# Pass 1 - Now try to halt. # Pass 1 - Now try to halt.
if { $halt } { if { $halt } {
foreach t [target names] { foreach t [target names] {
if {[jtag tapisenabled [$t cget -chain-position]] == 0} {
continue
}
# Wait upto 1 second for target to halt. Why 1sec? Cause # Wait upto 1 second for target to halt. Why 1sec? Cause
# the JTAG tap reset signal might be hooked to a slow # the JTAG tap reset signal might be hooked to a slow
# resistor/capacitor circuit - and it might take a while # resistor/capacitor circuit - and it might take a while
@ -217,6 +231,10 @@ proc ocd_process_reset { MODE } {
#Pass 2 - if needed "init" #Pass 2 - if needed "init"
if { 0 == [string compare init $MODE] } { if { 0 == [string compare init $MODE] } {
foreach t [target names] { foreach t [target names] {
if {[jtag tapisenabled [$t cget -chain-position]] == 0} {
continue
}
set err [catch "$t arp_waitstate halted 5000"] set err [catch "$t arp_waitstate halted 5000"]
# Did it halt? # Did it halt?
if { $err == 0 } { if { $err == 0 } {

View File

@ -479,12 +479,14 @@ int target_examine_one(struct target_s *target)
int target_examine(void) int target_examine(void)
{ {
int retval = ERROR_OK; int retval = ERROR_OK;
target_t *target = all_targets; target_t *target;
while (target)
for (target = all_targets; target; target = target->next)
{ {
if (!target->tap->enabled)
continue;
if ((retval = target_examine_one(target)) != ERROR_OK) if ((retval = target_examine_one(target)) != ERROR_OK)
return retval; return retval;
target = target->next;
} }
return retval; return retval;
} }
@ -3734,6 +3736,8 @@ static int tcl_target_func( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
Jim_WrongNumArgs( goi.interp, 2, argv, "[no parameters]"); Jim_WrongNumArgs( goi.interp, 2, argv, "[no parameters]");
return JIM_ERR; return JIM_ERR;
} }
if (!target->tap->enabled)
goto err_tap_disabled;
e = target->type->examine( target ); e = target->type->examine( target );
if( e != ERROR_OK ){ if( e != ERROR_OK ){
Jim_SetResult_sprintf( interp, "examine-fails: %d", e ); Jim_SetResult_sprintf( interp, "examine-fails: %d", e );
@ -3745,6 +3749,8 @@ static int tcl_target_func( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
Jim_WrongNumArgs( goi.interp, 2, argv, "[no parameters]"); Jim_WrongNumArgs( goi.interp, 2, argv, "[no parameters]");
return JIM_ERR; return JIM_ERR;
} }
if (!target->tap->enabled)
goto err_tap_disabled;
if( !(target_was_examined(target)) ){ if( !(target_was_examined(target)) ){
e = ERROR_TARGET_NOT_EXAMINED; e = ERROR_TARGET_NOT_EXAMINED;
} else { } else {
@ -3772,6 +3778,8 @@ static int tcl_target_func( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
if( e != JIM_OK ){ if( e != JIM_OK ){
return e; return e;
} }
if (!target->tap->enabled)
goto err_tap_disabled;
/* determine if we should halt or not. */ /* determine if we should halt or not. */
target->reset_halt = !!a; target->reset_halt = !!a;
/* When this happens - all workareas are invalid. */ /* When this happens - all workareas are invalid. */
@ -3789,6 +3797,8 @@ static int tcl_target_func( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
Jim_WrongNumArgs( goi.interp, 0, argv, "halt [no parameters]"); Jim_WrongNumArgs( goi.interp, 0, argv, "halt [no parameters]");
return JIM_ERR; return JIM_ERR;
} }
if (!target->tap->enabled)
goto err_tap_disabled;
target->type->halt( target ); target->type->halt( target );
return JIM_OK; return JIM_OK;
case TS_CMD_WAITSTATE: case TS_CMD_WAITSTATE:
@ -3806,6 +3816,8 @@ static int tcl_target_func( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
if( e != JIM_OK ){ if( e != JIM_OK ){
return e; return e;
} }
if (!target->tap->enabled)
goto err_tap_disabled;
e = target_wait_state( target, n->value, a ); e = target_wait_state( target, n->value, a );
if( e != ERROR_OK ){ if( e != ERROR_OK ){
Jim_SetResult_sprintf( goi.interp, Jim_SetResult_sprintf( goi.interp,
@ -3861,6 +3873,10 @@ static int tcl_target_func( Jim_Interp *interp, int argc, Jim_Obj *const *argv )
return JIM_OK; return JIM_OK;
} }
return JIM_ERR; return JIM_ERR;
err_tap_disabled:
Jim_SetResult_sprintf(interp, "[TAP is disabled]");
return JIM_ERR;
} }
static int target_create( Jim_GetOptInfo *goi ) static int target_create( Jim_GetOptInfo *goi )