mirror of
git://git.code.sf.net/p/openocd/code
synced 2025-07-19 05:55:41 +10:00
The semantics of "-work-area-virt 0" (or phys) changed with the patch to require specifying physical or virtrual work area addresses. Specifying zero was previously a NOP. Now it means that address zero is valid. This patch addresses three related issues: - MMU-less processors should never specify work-area-virt; remove those specifications. Such processors include ARM7TDMI, Cortex-M3, and ARM966. - MMU-equipped processors *can* specify work-area-virt... but zero won't be appropriate, except in mischievous contexts (which hide null pointer exceptions). Remove those specs from those processors too. If any of those mappings is valid, someone will need to submit a patch adding it ... along with a comment saying what OS provides the mapping, and in which context. Example, say "works with Linux 2.6.30+, in kernel mode". (Note that ARM Linux doesn't map kernel memory to zero ...) - Clarify docs on that "-virt" and other work area stuff. Seems to me work-area-virt is quite problematic; not every operating system provides such static mappings; if they do, they're not in every MMU context... Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
56 lines
1.5 KiB
INI
56 lines
1.5 KiB
INI
#use combined on interfaces or targets that can't set TRST/SRST separately
|
|
reset_config srst_only srst_pulls_trst
|
|
|
|
if { [info exists CHIPNAME] } {
|
|
set _CHIPNAME $CHIPNAME
|
|
} else {
|
|
set _CHIPNAME at91sam7s
|
|
}
|
|
|
|
if { [info exists ENDIAN] } {
|
|
set _ENDIAN $ENDIAN
|
|
} else {
|
|
set _ENDIAN little
|
|
}
|
|
|
|
if { [info exists CPUTAPID ] } {
|
|
set _CPUTAPID $CPUTAPID
|
|
} else {
|
|
set _CPUTAPID 0x3f0f0f0f
|
|
}
|
|
|
|
jtag newtap $_CHIPNAME cpu -irlen 4 -ircapture 0x1 -irmask 0xf -expected-id $_CPUTAPID
|
|
|
|
set _TARGETNAME $_CHIPNAME.cpu
|
|
|
|
target create $_TARGETNAME arm7tdmi -endian $_ENDIAN -chain-position $_TARGETNAME -variant arm7tdmi
|
|
$_TARGETNAME configure -event reset-init {
|
|
soft_reset_halt
|
|
# RSTC_CR : Reset peripherals
|
|
mww 0xfffffd00 0xa5000004
|
|
# disable watchdog
|
|
mww 0xfffffd44 0x00008000
|
|
# enable user reset
|
|
mww 0xfffffd08 0xa5000001
|
|
# CKGR_MOR : enable the main oscillator
|
|
mww 0xfffffc20 0x00000601
|
|
sleep 10
|
|
# CKGR_PLLR: 96.1097 MHz
|
|
mww 0xfffffc2c 0x00481c0e
|
|
sleep 10
|
|
# PMC_MCKR : MCK = PLL / 2 ~= 48 MHz
|
|
mww 0xfffffc30 0x00000007
|
|
sleep 10
|
|
# MC_FMR: flash mode (FWS=1,FMCN=73)
|
|
mww 0xffffff60 0x00490100
|
|
sleep 100
|
|
}
|
|
|
|
$_TARGETNAME configure -work-area-phys 0x00200000 -work-area-size 0x4000 -work-area-backup 0
|
|
|
|
#flash bank <driver> <base_addr> <size> <chip_width> <bus_width> <target_number> [<target_name> <banks> <sectors_per_bank> <pages_per_sector> <page_size> <num_nvmbits> <ext_freq_khz>]
|
|
flash bank at91sam7 0 0 0 0 0 0 0 0 0 0 0 0 18432
|
|
|
|
# For more information about the configuration files, take a look at:
|
|
# openocd.texi
|