riscv-openocd/tcl/target
Olivier Schonken d1cd97777b topic: Added support for the SAM4S variants
Atmel introduced 6 new Cortex-M4 processors on 2011-10-26
SAM4S16C - 1024KB flash LQFP100/BGA100
SAM4S16B - 1024KB flash LQFP64/QFN64
SAM4S16A - 1024KB flash LQFP48/QFN48
SAM4S8C - 512KB flash LQFP100/BGA100
SAM4S8B - 512KB flash LQFP64/QFN64
SAM4S8A - 512KB flash LQFP48/QFN48

The SAM4S processors still suffer from the "6 waitstates needed
to program device" errata.

Other relevant changes are:
1. Address of flash memory starts at 0x400000.
2. EWP (Erase page and write page) only works for the first two 8KB "sectors"
3. Because of the EWP not working for all the sectors, normal page writes have
to be used.  The default_flash_blank_check is used to check if lockregions
should be erased.
4. The EA (Erase All) command takes 7.3s to complete. (Previous timeout was
500 ms)
5. There are 128 lockable regions of 8KB each.

Implemented default blank checking, and page erase for load_image scenarios.
This is to compensate for the EWP flash commands only working on the
first 2 8KB sectors.

Change-Id: I7c5a52b177f7849a107611fd0f635fc416cfb724
Signed-off-by: Olivier Schonken <olivier.schonken@gmail.com>
Reviewed-on: http://openocd.zylin.com/528
Tested-by: jenkins
Reviewed-by: Spencer Oliver <spen@spen-soft.co.uk>
2012-04-26 10:58:14 +00:00
..
aduc702x.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
am335x.cfg cfg: Beaglebone/AM335x refactor 2012-02-27 10:01:44 +00:00
amdm37x.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00: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 target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
at91rm9200.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
at91sam3XXX.cfg Added tcl config scripts for SAM3A/X targets and devboard 2012-03-30 15:56:19 +00:00
at91sam3ax_4x.cfg Added tcl config scripts for SAM3A/X targets and devboard 2012-03-30 15:56:19 +00:00
at91sam3ax_8x.cfg Added tcl config scripts for SAM3A/X targets and devboard 2012-03-30 15:56:19 +00:00
at91sam3ax_xx.cfg Added tcl config scripts for SAM3A/X targets and devboard 2012-03-30 15:56:19 +00:00
at91sam3nXX.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00: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 Fix remaining incorrect reference to target/at91sam3uXX.cfg 2011-12-02 06:37:29 +00:00
at91sam3uxx.cfg make sure file name case of at91sam3uxx matches what other files include 2011-12-01 22:28:33 +00:00
at91sam4XXX.cfg topic: Added support for the SAM4S variants 2012-04-26 10:58:14 +00:00
at91sam4sXX.cfg topic: Added support for the SAM4S variants 2012-04-26 10:58:14 +00:00
at91sam7se512.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
at91sam7sx.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
at91sam7x256.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
at91sam7x512.cfg at91sam7: add a new target config file for at91sam7x512 2011-11-08 08:07:22 +00:00
at91sam9.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00: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 target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
at91sam9260.cfg at91sam9260: update sram information 2011-03-03 22:49:47 +01:00
at91sam9260_ext_RAM_ext_flash.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00: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 target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
avr32.cfg scripts: use adapter_nsrst_delay not deprecated jtag_nsrst_delay 2012-03-30 16:01:51 +00:00
c100.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00: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 config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
davinci.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
dragonite.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
dsp56321.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
dsp568013.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
dsp568037.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
epc9301.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
faux.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
feroceon.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
fm3.cfg scripts: use adapter_nsrst_delay not deprecated jtag_nsrst_delay 2012-03-30 16:01:51 +00:00
hilscher_netx10.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
hilscher_netx50.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
hilscher_netx500.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
icepick.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx21.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx25.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx27.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx28.cfg topic: Add support for i.MX28EVK 2012-02-13 12:03:26 +00:00
imx31.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx35.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx51.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
imx53.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
is5114.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
ixp42x.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
k40.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
k60.cfg configuration for Freescale TWRK60N512 board 2011-11-17 17:33:28 +00:00
lpc2xxx.cfg Export _TARGETNAME from generic LPC2xxx script 2012-02-07 06:32:33 +00:00
lpc1768.cfg scripts: use adapter_khz not deprecated jtag_khz 2011-11-18 22:14:55 +00: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 config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
lpc3131.cfg scripts: use adapter_nsrst_delay not deprecated jtag_nsrst_delay 2012-03-30 16:01:51 +00:00
lpc3250.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
lpc4350.cfg Add new configuration files for the Diolan LPC-4350-DB1 development 2012-03-06 13:31:59 +00:00
mc13224v.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
nuc910.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
omap2420.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
omap3530.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
omap4430.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
omap4460.cfg omap4460: add initial TCL support for the omap4460 es1.0 2012-04-18 20:00:27 +00:00
omap5912.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
omapl138.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
pic32mx.cfg cfg: correct pic32mx config typo's 2012-03-14 20:30:45 +00:00
pxa3xx.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
pxa255.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
pxa270.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
readme.txt rename jtag_khz as adapter_khz 2010-03-15 08:37:43 -07:00
samsung_s3c2410.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
samsung_s3c2440.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
samsung_s3c2450.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
samsung_s3c4510.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
samsung_s3c6410.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
sharp_lh79532.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
smp8634.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
spear3xx.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
stellaris.cfg cfg: change default stellaris working area 2012-02-16 08:57:22 +00:00
stm32.cfg cfg: support calling legacy stm32 scripts 2011-07-29 17:01:31 +01:00
stm32_stlink.cfg cfg: add ST-LINK TRANSPORT config override 2012-02-10 14:23:09 +00:00
stm32f0x_stlink.cfg Fix Typo in cfg file 2012-02-17 14:02:50 +00:00
stm32f1x.cfg cfg: use consistent chipname 2012-01-09 09:48:34 +00:00
stm32f1x_stlink.cfg cfg: add stlink pseudo stm32 targets 2012-01-09 09:49:01 +00:00
stm32f2x.cfg scripts: use adapter_nsrst_delay not deprecated jtag_nsrst_delay 2012-03-30 16:01:51 +00:00
stm32f2x_stlink.cfg cfg: add stlink pseudo stm32 targets 2012-01-09 09:49:01 +00:00
stm32f2xxx.cfg cfg: support calling legacy stm32 scripts 2011-07-29 17:01:31 +01:00
stm32f4x.cfg cfg: add STM32F4x and STM3241G-EVAL config files 2012-03-30 16:02:14 +00:00
stm32f4x_stlink.cfg cfg: add stlink pseudo stm32 targets 2012-01-09 09:49:01 +00:00
stm32l.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
stm32lx_stlink.cfg cfg: fix incorrect STM32L SW-DP id 2012-02-10 14:24:00 +00:00
stm32xl.cfg cfg: update scripts to use new stm32 driver names 2011-07-28 11:45:09 +01:00
str710.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
str730.cfg cfg: fix typo in str730.cfg 2012-01-13 10:25:36 +00:00
str750.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
str912.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00: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 target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
ti_dm365.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
ti_dm6446.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
tmpa900.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
tmpa910.cfg target config files: Fix whitespace issues. 2011-11-07 16:16:33 +00:00
u8500.cfg u8500: linux rtos config 2012-01-15 22:17:42 +00: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.