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:
parent
b4a7ff291c
commit
51ce53d044
|
@ -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.
|
||||||
|
|
|
@ -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,14 +52,18 @@ proc program {filename args} {
|
||||||
program_error "** Unable to reset target **" $exit
|
program_error "** Unable to reset target **" $exit
|
||||||
}
|
}
|
||||||
|
|
||||||
# start programming phase
|
# Check whether programming is needed
|
||||||
echo "** Programming Started **"
|
if {[info exists preverify]} {
|
||||||
set filename \{$filename\}
|
echo "**pre-verifying**"
|
||||||
if {[info exists address]} {
|
if {[catch {eval verify_image $flash_args}] == 0} {
|
||||||
set flash_args "$filename $address"
|
echo "**Verified OK - No flashing**"
|
||||||
} else {
|
set needsflash 0
|
||||||
set flash_args "$filename"
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# start programming phase
|
||||||
|
if {$needsflash == 1} {
|
||||||
|
echo "** Programming Started **"
|
||||||
|
|
||||||
if {[catch {eval flash write_image erase $flash_args}] == 0} {
|
if {[catch {eval flash write_image erase $flash_args}] == 0} {
|
||||||
echo "** Programming Finished **"
|
echo "** Programming Finished **"
|
||||||
|
@ -60,6 +76,10 @@ proc program {filename args} {
|
||||||
program_error "** Verify Failed **" $exit
|
program_error "** Verify Failed **" $exit
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
program_error "** Programming Failed **" $exit
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if {[info exists reset]} {
|
if {[info exists reset]} {
|
||||||
# reset target if requested
|
# reset target if requested
|
||||||
|
@ -70,9 +90,7 @@ proc program {filename args} {
|
||||||
echo "** Resetting Target **"
|
echo "** Resetting Target **"
|
||||||
reset run
|
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.
|
||||||
|
|
Loading…
Reference in New Issue