tcl/stm32l5x|u5x: support HLA adapters in non-secure mode only 46/6546/9
authorTarek BOCHKATI <tarek.bouchkati@gmail.com>
Fri, 24 Sep 2021 12:47:14 +0000 (13:47 +0100)
committerAntonio Borneo <borneo.antonio@gmail.com>
Fri, 21 Oct 2022 18:19:41 +0000 (18:19 +0000)
instrument "target/stm32x5x_common.cfg" used by both STM32L5x/U5x
to support HLA adapters like "interface/stlink.cfg" in non-secure mode

if the device switches to secure mode, the debug session will be
stopped immediately (with an explanatory message).

Change-Id: I645fdd55e3448ef82d0ddcc396f42fd7b2f39ac3
Signed-off-by: Tarek BOCHKATI <tarek.bouchkati@gmail.com>
Reported-by: Patrik Bachan <diggit@users.sourceforge.net>
Fixes: https://sourceforge.net/p/openocd/tickets/317/
Reviewed-on: https://review.openocd.org/c/openocd/+/6546
Reviewed-by: Tomas Vanek <vanekt@fbl.cz>
Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com>
Tested-by: jenkins
tcl/target/stm32x5x_common.cfg

index 321abff80a96b81e5ca9cc732663d306792830af..fb3aeb18c158d4b96417a1b97fffdc7bf1788422 100644 (file)
@@ -58,7 +58,9 @@ if {[using_jtag]} {
 
 reset_config srst_nogate
 
-if {![using_hla]} {
+if {[using_hla]} {
+       echo "Warn : The selected adapter does not support debugging this device in secure mode"
+} else {
        # if srst is not fitted use SYSRESETREQ to
        # perform a soft reset
        cortex_m reset_config sysresetreq
@@ -71,13 +73,18 @@ proc stm32x5x_is_secure {} {
 }
 
 proc stm32x5x_ahb_ap_non_secure_access {} {
-       # SPROT=1=Non Secure access, Priv=1
-       [[target current] cget -dap] apcsw 0x4B000000 0x4F000000
+       # in HLA mode, non-secure debugging is possible without changing the AP CSW
+       if {![using_hla]} {
+               # SPROT=1=Non Secure access, Priv=1
+               [[target current] cget -dap] apcsw 0x4B000000 0x4F000000
+       }
 }
 
 proc stm32x5x_ahb_ap_secure_access {} {
-       # SPROT=0=Secure access, Priv=1
-       [[target current] cget -dap] apcsw 0x0B000000 0x4F000000
+       if {![using_hla]} {
+               # SPROT=0=Secure access, Priv=1
+               [[target current] cget -dap] apcsw 0x0B000000 0x4F000000
+       }
 }
 
 $_TARGETNAME configure -event reset-start {

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)