Fixed gaffes in reset script handling + improved error

messages a bit. The file and line # of the syntax error
in a reset script is now printed.


git-svn-id: svn://svn.berlios.de/openocd/trunk@1042 b42882b7-edfa-0310-969c-e2dbd0fdcd60
This commit is contained in:
oharboe 2008-10-13 10:30:33 +00:00
parent 0a3b6213bb
commit bc25d4fa5e
3 changed files with 48 additions and 44 deletions

View File

@ -212,11 +212,11 @@ proc ocd_process_reset { MODE } {
} }
foreach t [ target names ] { foreach t [ target names ] {
# For compatiblity with 'old scripts' # For compatiblity with 'old scripts'
$t invoke-event old-pre_reset $t invoke-event old-pre_reset
# New event script. # New event script.
$t invoke-event reset-start $t invoke-event reset-start
} }
# Init the tap controller. # Init the tap controller.
@ -224,60 +224,60 @@ proc ocd_process_reset { MODE } {
# Examine all targets. # Examine all targets.
foreach t [ target names ] { foreach t [ target names ] {
$t arp_examine $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 $t arp_reset assert $halt
$t invoke-event reset-assert-post $t invoke-event reset-assert-post
} }
# Now de-assert reset. # Now de-assert reset.
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 $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] {
# 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
# to charge # to charge
# Catch, but ignore any errors. # Catch, but ignore any errors.
catch { $t arp_waitstate halted 1000 } catch { $t arp_waitstate halted 1000 }
# Did we succeed? # Did we succeed?
set s [$t curstate] set s [$t curstate]
if { 0 != [string compare $s "halted" ] } { if { 0 != [string compare $s "halted" ] } {
return -error [format "TARGET: %s - Not halted" $t] return -error [format "TARGET: %s - Not halted" $t]
} }
} }
} }
#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] {
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 } {
$t invoke-event old-post_reset $t invoke-event old-post_reset
$t invoke-event reset-init $t invoke-event reset-init
} }
} }
} }
foreach t [ target names ] { foreach t [ target names ] {
$t invoke-event reset-end $t invoke-event reset-end
} }
} }

View File

@ -436,7 +436,8 @@ static int NEW_target_process_reset(struct command_context_s *cmd_ctx, enum targ
sprintf( buf, "ocd_process_reset %s", n->name ); sprintf( buf, "ocd_process_reset %s", n->name );
retval = Jim_Eval( interp, buf ); retval = Jim_Eval( interp, buf );
if(retval != JIM_ERR){ if(retval != JIM_OK) {
Jim_PrintErrorMessage(interp);
return ERROR_FAIL; return ERROR_FAIL;
} }
@ -3112,7 +3113,10 @@ target_handle_event( target_t *target, enum target_event e )
e, e,
Jim_Nvp_value2name_simple( nvp_target_event, e )->name, Jim_Nvp_value2name_simple( nvp_target_event, e )->name,
Jim_GetString( teap->body, NULL ) ); Jim_GetString( teap->body, NULL ) );
Jim_EvalObj( interp, teap->body ); if (Jim_EvalObj( interp, teap->body )!=JIM_OK)
{
Jim_PrintErrorMessage(interp);
}
} }
teap = teap->next; teap = teap->next;
} }
@ -3215,7 +3219,7 @@ target_configure( Jim_GetOptInfo *goi,
} }
if( goi->isconfigure ){ if( goi->isconfigure ){
if( goi->argc == 0 ){ if( goi->argc != 1 ){
Jim_WrongNumArgs( goi->interp, goi->argc, goi->argv, "-event ?event-name? ?EVENT-BODY?"); Jim_WrongNumArgs( goi->interp, goi->argc, goi->argv, "-event ?event-name? ?EVENT-BODY?");
return JIM_ERR; return JIM_ERR;
} }

View File

@ -14,7 +14,7 @@ reset_config trst_and_srst srst_pulls_trst
jtag_device 4 0x1 0xf 0xe jtag_device 4 0x1 0xf 0xe
target arm7tdmi little 0 arm7tdmi-s_r4 target arm7tdmi little 0 arm7tdmi-s_r4
[new_target_name] configure -event old-post_reset {} { [new_target_name] configure -event old-post_reset {
# Force target into ARM state # Force target into ARM state
soft_reset_halt soft_reset_halt
#do not remap 0x0000-0x0020 to anything but the flash #do not remap 0x0000-0x0020 to anything but the flash