openocd/tcl/target
Karl Kurbjun 70143a96c5 ICEPick-C: Add support for warm reset through JTAG controller and provide finer detail functions.
This sets up simple functions that can later be used to provide additional
ICEPick Operations.

Change-Id: I313b8679267696fad87d23f3692963e513f2fe21
Signed-off-by: Spencer Oliver <spen@spen-soft.co.uk>
Reviewed-on: http://openocd.zylin.com/22
Tested-by: Øyvind Harboe <oyvindharboe@gmail.com>
Reviewed-by: Øyvind Harboe <oyvindharboe@gmail.com>
2011-10-17 19:35:37 +00:00
..
aduc702x.cfg TCL scripts: replace "puts" with "echo" 2010-11-09 08:12:51 +01:00
amdm37x.cfg AM/DM37x: add ES1.2 silicon type into account 2011-09-30 09:37:04 +02:00
ar71xx.cfg TCL: fix non TCL comments 2010-12-18 21:04:22 +01:00
at32ap7000.cfg at32ap7000 config file 2010-08-15 21:54:01 +02:00
at91r40008.cfg AT91R40008/Ethernut 3 configuration 2010-02-02 11:09:53 -08:00
at91rm9200.cfg at91rm9200 : reset_config should go to the board config file 2010-05-18 11:48:47 +02:00
at91sam3XXX.cfg at91sam3s* support 2010-06-25 21:37:53 +02:00
at91sam3sXX.cfg at91sam3s* support 2010-06-25 21:37:53 +02:00
at91sam3u1c.cfg update 'flash bank' usage in scripts 2009-11-19 13:39:41 -08:00
at91sam3u1e.cfg update 'flash bank' usage in scripts 2009-11-19 13:39:41 -08:00
at91sam3u2c.cfg update 'flash bank' usage in scripts 2009-11-19 13:39:41 -08:00
at91sam3u2e.cfg update 'flash bank' usage in scripts 2009-11-19 13:39:41 -08:00
at91sam3u4c.cfg scripts: update flash bank names 2010-05-13 20:44:08 +01:00
at91sam3u4e.cfg scripts: update flash bank names 2010-05-13 20:44:08 +01:00
at91sam3uXX.cfg at91sam3s* support 2010-06-25 21:37:53 +02:00
at91sam7se512.cfg rename some target scripts to be consistent with the rest 2010-12-02 18:53:03 +01:00
at91sam7sx.cfg config scripts: remove useless reference to OpenOCD docs 2010-08-11 10:53:54 +02:00
at91sam7x256.cfg rename some target scripts to be consistent with the rest 2010-12-02 18:53:03 +01:00
at91sam9.cfg at91sam9: factorise cpu support 2011-03-03 22:49:46 +01:00
at91sam9g10.cfg at91: add at91sam9g10 support 2011-03-03 22:49:47 +01:00
at91sam9g20.cfg at91sam9: factorise cpu support 2011-03-03 22:49:46 +01:00
at91sam9g45.cfg at91: add at91sam9g45 support 2011-03-03 22:49:47 +01:00
at91sam9rl.cfg at91sam9: factorise cpu support 2011-03-03 22:49:46 +01:00
at91sam9260.cfg at91sam9260: update sram information 2011-03-03 22:49:47 +01:00
at91sam9260_ext_RAM_ext_flash.cfg at91sam9: factorise cpu support 2011-03-03 22:49:46 +01:00
at91sam9261.cfg at91: add at91sam9261 support 2011-03-03 22:49:46 +01:00
at91sam9263.cfg at91: add at91sam9263 support 2011-03-03 22:49:47 +01:00
atmega128.cfg rename some target scripts to be consistent with the rest 2010-12-02 18:53:03 +01:00
avr32.cfg avr32: basic target script 2010-08-15 21:56:41 +02:00
c100.cfg rename jtag_khz as adapter_khz 2010-03-15 08:37:43 -07:00
c100config.tcl TCL scripts: replace "puts" with "echo" 2010-11-09 08:12:51 +01:00
c100helper.tcl TCL scripts: replace "puts" with "echo" 2010-11-09 08:12:51 +01:00
c100regs.tcl TCL scripts: replace "puts" with "echo" 2010-11-09 08:12:51 +01:00
cs351x.cfg target.cfg: remove "-work-area-virt 0" 2009-11-08 08:52:40 -08:00
davinci.cfg TCL scripts: collect duplicated procedures 2010-09-21 12:25:59 +02:00
dragonite.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
dsp56321.cfg rename jtag_khz as adapter_khz 2010-03-15 08:37:43 -07:00
dsp568013.cfg dsp568013 disable polling by default 2011-08-30 15:08:54 -07:00
dsp568037.cfg flash support (only full erase/write) for 568013 and 568037 2011-05-18 18:47:55 +02:00
epc9301.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
faux.cfg target.cfg: update to use new flash configuration syntax 2009-12-17 11:39:09 +00:00
feroceon.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
fm3.cfg cfg: add Fujitsu FM3 config 2011-07-27 10:56:25 +01:00
hilscher_netx10.cfg Add support for Hilscher netX controllers 2010-12-18 21:11:57 +01:00
hilscher_netx50.cfg Add support for Hilscher netX controllers 2010-12-18 21:11:57 +01:00
hilscher_netx500.cfg Add support for Hilscher netX controllers 2010-12-18 21:11:57 +01:00
icepick.cfg ICEPick-C: Add support for warm reset through JTAG controller and provide finer detail functions. 2011-10-17 19:35:37 +00:00
imx.cfg Tcl and doc: update to match new 'arm mcr ...' etc 2009-12-01 01:10:19 -08:00
imx21.cfg Remove annoying end-of-line whitespace from tcl/* files 2009-09-21 18:48:22 +00:00
imx25.cfg iMX2* + ETB targets: hook up ETM and ETB 2009-11-13 16:56:11 -08:00
imx27.cfg iMX2* + ETB targets: hook up ETM and ETB 2009-11-13 16:56:11 -08:00
imx31.cfg TCL scripts: replace "puts" with "echo" 2010-11-09 08:12:51 +01:00
imx35.cfg TCL scripts: replace "puts" with "echo" 2010-11-09 08:12:51 +01:00
imx51.cfg CortexA8: Introduce Freescale i.MX51 variant 2010-11-05 11:25:57 +01:00
imx53.cfg Add preliminary support for Freescale iMX53 2011-04-13 21:32:00 +02:00
is5114.cfg testing/examples/.../*cfg: rm jtag_device calls 2009-12-15 14:45:26 -08:00
ixp42x.cfg update IXP42x target / XBA board config 2010-12-19 22:16:31 +01:00
lpc2xxx.cfg Make the lpc2xxx generic driver support romless parts 2011-05-03 22:06:57 +02:00
lpc1768.cfg Remove srst_pulls_trst from LPC1768 target 2010-10-25 08:04:58 +02:00
lpc2103.cfg Add another level of procedures to LPC2xxx initialization - procedures for specific targets (setup_lpc<number>) take core clock and adapter clock as parameters. This way "constant" parameters (flash size and type, CPUTAPID, etc.) do not need to be copied if one wishes to change the "variable" parameters - like the core clock or adapter clock - in a board config file or somewhere else. 2011-01-09 21:34:02 +01:00
lpc2124.cfg Add another level of procedures to LPC2xxx initialization - procedures for specific targets (setup_lpc<number>) take core clock and adapter clock as parameters. This way "constant" parameters (flash size and type, CPUTAPID, etc.) do not need to be copied if one wishes to change the "variable" parameters - like the core clock or adapter clock - in a board config file or somewhere else. 2011-01-09 21:34:02 +01:00
lpc2129.cfg Add another level of procedures to LPC2xxx initialization - procedures for specific targets (setup_lpc<number>) take core clock and adapter clock as parameters. This way "constant" parameters (flash size and type, CPUTAPID, etc.) do not need to be copied if one wishes to change the "variable" parameters - like the core clock or adapter clock - in a board config file or somewhere else. 2011-01-09 21:34:02 +01:00
lpc2148.cfg Add another level of procedures to LPC2xxx initialization - procedures for specific targets (setup_lpc<number>) take core clock and adapter clock as parameters. This way "constant" parameters (flash size and type, CPUTAPID, etc.) do not need to be copied if one wishes to change the "variable" parameters - like the core clock or adapter clock - in a board config file or somewhere else. 2011-01-09 21:34:02 +01:00
lpc2294.cfg Add another level of procedures to LPC2xxx initialization - procedures for specific targets (setup_lpc<number>) take core clock and adapter clock as parameters. This way "constant" parameters (flash size and type, CPUTAPID, etc.) do not need to be copied if one wishes to change the "variable" parameters - like the core clock or adapter clock - in a board config file or somewhere else. 2011-01-09 21:34:02 +01:00
lpc2378.cfg Add another level of procedures to LPC2xxx initialization - procedures for specific targets (setup_lpc<number>) take core clock and adapter clock as parameters. This way "constant" parameters (flash size and type, CPUTAPID, etc.) do not need to be copied if one wishes to change the "variable" parameters - like the core clock or adapter clock - in a board config file or somewhere else. 2011-01-09 21:34:02 +01:00
lpc2460.cfg Add support for the lpc2460 target 2011-05-03 22:07:01 +02:00
lpc2478.cfg Add another level of procedures to LPC2xxx initialization - procedures for specific targets (setup_lpc<number>) take core clock and adapter clock as parameters. This way "constant" parameters (flash size and type, CPUTAPID, etc.) do not need to be copied if one wishes to change the "variable" parameters - like the core clock or adapter clock - in a board config file or somewhere else. 2011-01-09 21:34:02 +01:00
lpc2900.cfg target.cfg: update to use new flash configuration syntax 2009-12-17 11:39:09 +00:00
lpc3131.cfg TCL: fix non TCL comments 2010-12-18 21:04:22 +01:00
lpc3250.cfg Add the REV A tap id to the LPC3250 configuration 2011-04-13 21:28:44 +02:00
mc13224v.cfg rename jtag_khz as adapter_khz 2010-03-15 08:37:43 -07:00
nuc910.cfg cfg: add Avalue RSC-W910 config 2010-07-13 14:17:00 +01:00
omap2420.cfg OMAP2420: define reset-assert event 2009-12-07 14:57:43 -08:00
omap3530.cfg Fix omap3_dbginit to write to physical memory. 2010-09-26 17:45:58 -07:00
omap4430.cfg pandaboard: use new -dbgbase option to workaround broken ROM table 2011-04-02 09:00:01 +02:00
omap5912.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
omapl138.cfg cfg: add omapl138 support and da850evm preliminary support 2010-08-10 09:43:30 +02:00
pic32mx.cfg config scripts: remove useless reference to OpenOCD docs 2010-08-11 10:53:54 +02:00
pxa3xx.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
pxa255.cfg rename jtag_khz as adapter_khz 2010-03-15 08:37:43 -07:00
pxa270.cfg board scripts: Marvell PXA270M processor has a new TAPID: 0x89265013 2010-09-14 11:15:35 +02:00
readme.txt rename jtag_khz as adapter_khz 2010-03-15 08:37:43 -07:00
samsung_s3c2410.cfg target.cfg: remove "-work-area-virt 0" 2009-11-08 08:52:40 -08:00
samsung_s3c2440.cfg target.cfg: remove "-work-area-virt 0" 2009-11-08 08:52:40 -08:00
samsung_s3c2450.cfg rename jtag_khz as adapter_khz 2010-03-15 08:37:43 -07:00
samsung_s3c4510.cfg Remove annoying end-of-line whitespace from tcl/* files 2009-09-21 18:48:22 +00:00
samsung_s3c6410.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
sharp_lh79532.cfg Remove annoying end-of-line whitespace from tcl/* files 2009-09-21 18:48:22 +00:00
smp8634.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
spear3xx.cfg TCL scripts: add support for ST SPEAr310 2010-11-06 15:40:52 +01:00
stellaris.cfg cfg: allow stellaris device class override 2011-08-02 13:10:03 +01:00
stm32.cfg cfg: support calling legacy stm32 scripts 2011-07-29 17:01:31 +01:00
stm32f1x.cfg Add Valuline HD to config file 2011-08-25 20:13:16 +02:00
stm32f2x.cfg cfg: update scripts to use new stm32 driver names 2011-07-28 11:45:09 +01:00
stm32f2xxx.cfg cfg: support calling legacy stm32 scripts 2011-07-29 17:01:31 +01:00
stm32l.cfg STM32L: Added flash driver and target 2011-10-03 18:42:39 +02:00
stm32xl.cfg cfg: update scripts to use new stm32 driver names 2011-07-28 11:45:09 +01:00
str710.cfg config scripts: remove useless reference to OpenOCD docs 2010-08-11 10:53:54 +02:00
str730.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
str750.cfg FLASH/NOR: rename from spearsmi to stmsmi 2010-11-23 08:37:34 +01:00
str912.cfg config scripts: remove useless reference to OpenOCD docs 2010-08-11 10:53:54 +02:00
swj-dp.tcl swj-dp.tcl (SWD infrastructure #1) 2010-10-10 14:41:11 -07:00
test_reset_syntax_error.cfg Remove annoying end-of-line whitespace from tcl/* files 2009-09-21 18:48:22 +00:00
test_syntax_error.cfg Remove annoying end-of-line whitespace from tcl/* files 2009-09-21 18:48:22 +00:00
ti_dm355.cfg Add a new JTAG "setup" event; use for better DaVinci ICEpick support. 2009-10-05 08:20:28 +00:00
ti_dm365.cfg Add a new JTAG "setup" event; use for better DaVinci ICEpick support. 2009-10-05 08:20:28 +00:00
ti_dm6446.cfg Add a new JTAG "setup" event; use for better DaVinci ICEpick support. 2009-10-05 08:20:28 +00:00
tmpa900.cfg CPU name in TMPA900 config file should obviously be TMPA900 (not TMPA910). 2011-07-18 14:24:05 +01:00
tmpa910.cfg rename jtag_nsrst_delay as adapter_nsrst_delay 2010-03-15 08:41:30 -07:00
u8500.cfg u8500 : config for L2 cache 2011-09-30 09:45:29 +02:00

readme.txt

Prerequisites:
The users of OpenOCD as well as computer programs interacting with OpenOCD are expecting that certain commands
do the same thing across all the targets.

Rules to follow when writing scripts:

1. The configuration script should be defined such as , for example, the following sequences are working:
	reset
	flash info <bank>
and
	reset
	flash erase_address <start> <len>
and
	reset init
	load

In most cases this can be accomplished by specifying the default startup mode as reset_init (target command
in the configuration file).

2. If the target is correctly configured, flash must be writable without any other helper commands. It is
assumed that all write-protect mechanisms should be disabled.

3. The configuration scripts should be defined such as the binary that was written to flash verifies
(turn off remapping, checksums, etc...)

flash write_image [file] <parameters>
verify_image [file] <parameters>

4. adapter_khz sets the maximum speed (or alternatively RCLK). If invoked
multiple times only the last setting is used.

interface/xxx.cfg files are always executed *before* target/xxx.cfg
files, so any adapter_khz in interface/xxx.cfg will be overridden by
target/xxx.cfg. adapter_khz in interface/xxx.cfg would then, effectively,
set the default JTAG speed.

Note that a target/xxx.cfg file can invoke another target/yyy.cfg file,
so one can create target subtype configurations where e.g. only
amount of DRAM, oscillator speeds differ and having a single
config file for the default/common settings.