PIC32MX: update cfg script
authorSpencer Oliver <ntfreak@users.sourceforge.net>
Mon, 15 Mar 2010 09:36:46 +0000 (09:36 +0000)
committerSpencer Oliver <ntfreak@users.sourceforge.net>
Mon, 15 Mar 2010 09:38:46 +0000 (09:38 +0000)
The default config script will now dynamically setup the BMX registers
in the reset init script.
This will also work if the user overrides the default working area.

Signed-off-by: Spencer Oliver <ntfreak@users.sourceforge.net>
tcl/target/pic32mx.cfg

index 0f1fa66c0548ddcec33c4add04cebdd9b3aaf5e8..d77c3a8c9ae95bce54324e1355909a6a9ded5563 100644 (file)
@@ -18,14 +18,14 @@ if { [info exists CPUTAPID ] } {
    set _CPUTAPID 0x30938053
 }
 
    set _CPUTAPID 0x30938053
 }
 
-# working area is 16384 - 2048
-# loose first 2048 bytes due to BMXDKPBA reg
+# default working area is 16384
 if { [info exists WORKAREASIZE] } {
    set  _WORKAREASIZE $WORKAREASIZE
 } else {
 if { [info exists WORKAREASIZE] } {
    set  _WORKAREASIZE $WORKAREASIZE
 } else {
-   set  _WORKAREASIZE [expr (16384 - 2048)]
+   set  _WORKAREASIZE 0x4000
 }
 
 }
 
+
 jtag_nsrst_delay 100
 jtag_ntrst_delay 100
 
 jtag_nsrst_delay 100
 jtag_ntrst_delay 100
 
@@ -39,22 +39,35 @@ jtag newtap $_CHIPNAME cpu -irlen 5 -ircapture 0x1 -irmask 0x1f -expected-id $_C
 set _TARGETNAME $_CHIPNAME.cpu
 target create $_TARGETNAME mips_m4k -endian $_ENDIAN -chain-position $_TARGETNAME
 
 set _TARGETNAME $_CHIPNAME.cpu
 target create $_TARGETNAME mips_m4k -endian $_ENDIAN -chain-position $_TARGETNAME
 
-$_TARGETNAME configure -work-area-phys 0xa0000800 -work-area-size $_WORKAREASIZE -work-area-backup 0
+#
+# At reset the pic32mx does not allow code execution from RAM
+# we have to setup the BMX registers to allow this.
+# One limitation is that we loose the first 2k of RAM.
+#
+
+global _PIC32MX_DATASIZE
+global _PIC32MX_PROGSIZE
+set _PIC32MX_DATASIZE 0x800
+set _PIC32MX_PROGSIZE [expr ($_WORKAREASIZE - $_PIC32MX_DATASIZE)]
 
 
+$_TARGETNAME configure -work-area-phys 0xa0000800 -work-area-size $_PIC32MX_PROGSIZE -work-area-backup 0
 $_TARGETNAME configure -event reset-init {
        #
        # from reset the pic32 cannot execute code in ram - enable ram execution
        # minimum offset from start of ram is 2k
        #
 
 $_TARGETNAME configure -event reset-init {
        #
        # from reset the pic32 cannot execute code in ram - enable ram execution
        # minimum offset from start of ram is 2k
        #
 
+       global _PIC32MX_DATASIZE
+       global _PIC32MX_PROGSIZE
+
        # BMXCON
        mww 0xbf882000 0x001f0040
        # BMXCON
        mww 0xbf882000 0x001f0040
-       # BMXDKPBA: 0xa0000800
-       mww 0xbf882010 0x00000800
-       # BMXDUDBA
-       mww 0xbf882020 0x00004000
-       # BMXDUPBA
-       mww 0xbf882030 0x00004000
+       # BMXDKPBA: 2k kernel data @ 0xa0000800
+       mww 0xbf882010 $_PIC32MX_DATASIZE
+       # BMXDUDBA: 16k kernel program @ 0xa0000800
+       mww 0xbf882020 $_PIC32MX_PROGSIZE
+       # BMXDUPBA: 0k user program
+       mww 0xbf882030 $_PIC32MX_PROGSIZE
 }
 
 set _FLASHNAME $_CHIPNAME.flash
 }
 
 set _FLASHNAME $_CHIPNAME.flash

Linking to existing account procedure

If you already have an account and want to add another login method you MUST first sign in with your existing account and then change URL to read https://review.openocd.org/login/?link to get to this page again but this time it'll work for linking. Thank you.

SSH host keys fingerprints

1024 SHA256:YKx8b7u5ZWdcbp7/4AeXNaqElP49m6QrwfXaqQGJAOk gerrit-code-review@openocd.zylin.com (DSA)
384 SHA256:jHIbSQa4REvwCFG4cq5LBlBLxmxSqelQPem/EXIrxjk gerrit-code-review@openocd.org (ECDSA)
521 SHA256:UAOPYkU9Fjtcao0Ul/Rrlnj/OsQvt+pgdYSZ4jOYdgs gerrit-code-review@openocd.org (ECDSA)
256 SHA256:A13M5QlnozFOvTllybRZH6vm7iSt0XLxbA48yfc2yfY gerrit-code-review@openocd.org (ECDSA)
256 SHA256:spYMBqEYoAOtK7yZBrcwE8ZpYt6b68Cfh9yEVetvbXg gerrit-code-review@openocd.org (ED25519)
+--[ED25519 256]--+
|=..              |
|+o..   .         |
|*.o   . .        |
|+B . . .         |
|Bo. = o S        |
|Oo.+ + =         |
|oB=.* = . o      |
| =+=.+   + E     |
|. .=o   . o      |
+----[SHA256]-----+
2048 SHA256:0Onrb7/PHjpo6iVZ7xQX2riKN83FJ3KGU0TvI0TaFG4 gerrit-code-review@openocd.zylin.com (RSA)