aboutsummaryrefslogtreecommitdiff
path: root/src/target/startup.tcl
diff options
context:
space:
mode:
authorPaul Fertser <fercerpav@gmail.com>2014-03-22 16:47:37 +0400
committerPaul Fertser <fercerpav@gmail.com>2014-03-29 08:40:03 +0000
commit207237b92005d604b75ff5280042a6c286a685f8 (patch)
treedbe5dbb408ac7470a8b6f1c06f57defef8d79a5a /src/target/startup.tcl
parentde9ebc5ce6432830d473aba769c34ae38794c947 (diff)
downloadriscv-openocd-207237b92005d604b75ff5280042a6c286a685f8.zip
riscv-openocd-207237b92005d604b75ff5280042a6c286a685f8.tar.gz
riscv-openocd-207237b92005d604b75ff5280042a6c286a685f8.tar.bz2
tcl: introduce init_target_events and use it for gdb flashing events
This introduces a new global Tcl procedure that is run just after init_targets and before init_boards. Its default behaviour is to assign gdb-flash-erase-start and gdb-flash-write-end to reasonable defaults. The rationale for doing "reset init" before gdb erases and flashes memory is that all flash drivers are written in assumption that they can safely be used only after chip reset (plus chip-specific configuration in the init handler if any). The need to use "reset halt" after flashing is because a user expects running firmware after loading to be the same as running it from power-on-reset. Change-Id: I9ddc4047611904ca4ca779b73376d2739611948a Signed-off-by: Paul Fertser <fercerpav@gmail.com> Reviewed-on: http://openocd.zylin.com/2062 Tested-by: jenkins Reviewed-by: Spencer Oliver <spen@spen-soft.co.uk>
Diffstat (limited to 'src/target/startup.tcl')
-rw-r--r--src/target/startup.tcl15
1 files changed, 15 insertions, 0 deletions
diff --git a/src/target/startup.tcl b/src/target/startup.tcl
index 56fcbaa..033e9c9 100644
--- a/src/target/startup.tcl
+++ b/src/target/startup.tcl
@@ -164,6 +164,21 @@ proc armv4_5 params {
proc init_targets {} {
}
+proc set_default_target_event {t e s} {
+ if {[$t cget -event $e] == ""} {
+ $t configure -event $e $s
+ }
+}
+
+proc init_target_events {} {
+ set targets [target names]
+
+ foreach t $targets {
+ set_default_target_event $t gdb-flash-erase-start "reset init"
+ set_default_target_event $t gdb-flash-write-end "reset halt"
+ }
+}
+
# Additionally board config scripts can define a procedure init_board that will be executed after init and init_targets
proc init_board {} {
}