src/flash/startup.tcl: Add preverify to program command

The preverify option allows to check whether flashing is necessary.
If the target is flashed often/automatically this can save time and
preserve the flash. This is expecially helpful in CI environments.

Change-Id: Iead0a269e1a772b751d4dd9e8b53b2fecc874624
Signed-off-by: Moritz 'Morty' Strübe <moritz.struebe@redheads.de>
Reviewed-on: http://openocd.zylin.com/5292
Tested-by: jenkins
Reviewed-by: Paul Fertser <fercerpav@gmail.com>
Reviewed-by: Spencer Oliver <spen@spen-soft.co.uk>
Reviewed-by: Tarek BOCHKATI <tarek.bouchkati@gmail.com>
This commit is contained in:
Moritz 'Morty' Strübe 2019-08-29 09:07:06 +02:00 committed by Spencer Oliver
parent b4a7ff291c
commit 51ce53d044
2 changed files with 50 additions and 31 deletions

View File

@ -5138,7 +5138,7 @@ command or the flash driver then it defaults to 0xff.
@end deffn @end deffn
@anchor{program} @anchor{program}
@deffn Command {program} filename [verify] [reset] [exit] [offset] @deffn Command {program} filename [preverify] [verify] [reset] [exit] [offset]
This is a helper script that simplifies using OpenOCD as a standalone This is a helper script that simplifies using OpenOCD as a standalone
programmer. The only required parameter is @option{filename}, the others are optional. programmer. The only required parameter is @option{filename}, the others are optional.
@xref{Flash Programming}. @xref{Flash Programming}.
@ -7528,6 +7528,7 @@ The script is executed as follows and by default the following actions will be p
@item 'init' is executed. @item 'init' is executed.
@item 'reset init' is called to reset and halt the target, any 'reset init' scripts are executed. @item 'reset init' is called to reset and halt the target, any 'reset init' scripts are executed.
@item @code{flash write_image} is called to erase and write any flash using the filename given. @item @code{flash write_image} is called to erase and write any flash using the filename given.
@item If the @option{preverify} parameter is given, the target is "verified" first and only flashed if this fails.
@item @code{verify_image} is called if @option{verify} parameter is given. @item @code{verify_image} is called if @option{verify} parameter is given.
@item @code{reset run} is called if @option{reset} parameter is given. @item @code{reset run} is called if @option{reset} parameter is given.
@item OpenOCD is shutdown if @option{exit} parameter is given. @item OpenOCD is shutdown if @option{exit} parameter is given.

View File

@ -17,9 +17,12 @@ proc program_error {description exit} {
proc program {filename args} { proc program {filename args} {
set exit 0 set exit 0
set needsflash 1
foreach arg $args { foreach arg $args {
if {[string equal $arg "verify"]} { if {[string equal $arg "preverify"]} {
set preverify 1
} elseif {[string equal $arg "verify"]} {
set verify 1 set verify 1
} elseif {[string equal $arg "reset"]} { } elseif {[string equal $arg "reset"]} {
set reset 1 set reset 1
@ -30,6 +33,15 @@ proc program {filename args} {
} }
} }
# Set variables
set filename \{$filename\}
if {[info exists address]} {
set flash_args "$filename $address"
} else {
set flash_args "$filename"
}
# make sure init is called # make sure init is called
if {[catch {init}] != 0} { if {[catch {init}] != 0} {
program_error "** OpenOCD init failed **" 1 program_error "** OpenOCD init failed **" 1
@ -40,40 +52,46 @@ proc program {filename args} {
program_error "** Unable to reset target **" $exit program_error "** Unable to reset target **" $exit
} }
# Check whether programming is needed
if {[info exists preverify]} {
echo "**pre-verifying**"
if {[catch {eval verify_image $flash_args}] == 0} {
echo "**Verified OK - No flashing**"
set needsflash 0
}
}
# start programming phase # start programming phase
echo "** Programming Started **" if {$needsflash == 1} {
set filename \{$filename\} echo "** Programming Started **"
if {[info exists address]} {
set flash_args "$filename $address" if {[catch {eval flash write_image erase $flash_args}] == 0} {
} else { echo "** Programming Finished **"
set flash_args "$filename" if {[info exists verify]} {
# verify phase
echo "** Verify Started **"
if {[catch {eval verify_image $flash_args}] == 0} {
echo "** Verified OK **"
} else {
program_error "** Verify Failed **" $exit
}
}
} else {
program_error "** Programming Failed **" $exit
}
} }
if {[catch {eval flash write_image erase $flash_args}] == 0} { if {[info exists reset]} {
echo "** Programming Finished **" # reset target if requested
if {[info exists verify]} { if {$exit == 1} {
# verify phase # also disable target polling, we are shutting down anyway
echo "** Verify Started **" poll off
if {[catch {eval verify_image $flash_args}] == 0} {
echo "** Verified OK **"
} else {
program_error "** Verify Failed **" $exit
}
} }
echo "** Resetting Target **"
if {[info exists reset]} { reset run
# reset target if requested
if {$exit == 1} {
# also disable target polling, we are shutting down anyway
poll off
}
echo "** Resetting Target **"
reset run
}
} else {
program_error "** Programming Failed **" $exit
} }
if {$exit == 1} { if {$exit == 1} {
shutdown shutdown
} }
@ -81,7 +99,7 @@ proc program {filename args} {
} }
add_help_text program "write an image to flash, address is only required for binary images. verify, reset, exit are optional" add_help_text program "write an image to flash, address is only required for binary images. verify, reset, exit are optional"
add_usage_text program "<filename> \[address\] \[verify\] \[reset\] \[exit\]" add_usage_text program "<filename> \[address\] \[pre-verify\] \[verify\] \[reset\] \[exit\]"
# stm32f0x uses the same flash driver as the stm32f1x # stm32f0x uses the same flash driver as the stm32f1x
# this alias enables the use of either name. # this alias enables the use of either name.