Add bootloader support for the LPC55S69 board

bla
pull/10086/head
David Saada 2019-03-07 18:00:20 +02:00
parent d6088e5017
commit eb5cef84fd
11 changed files with 1933 additions and 14 deletions

View File

@ -0,0 +1,10 @@
{
"name": "bootloader_LPC55S69",
"target_overrides": {
"*": {
"target.app_offset": "0x8400",
"target.header_offset": "0x8000",
"target.bootloader_img": "mbed-bootloader-lpc55s69-v1_0_0.hex"
}
}
}

View File

@ -106,7 +106,7 @@ static void powerdown_nvic()
NVIC->ICER[i] = 0xFFFFFFFF; NVIC->ICER[i] = 0xFFFFFFFF;
NVIC->ICPR[i] = 0xFFFFFFFF; NVIC->ICPR[i] = 0xFFFFFFFF;
for (j = 0; j < 8; j++) { for (j = 0; j < 8; j++) {
#if defined(__CORTEX_M23) #if defined(__CORTEX_M23) || defined(__CORTEX_M33)
NVIC->IPR[i * 8 + j] = 0x00000000; NVIC->IPR[i * 8 + j] = 0x00000000;
#else #else
NVIC->IP[i * 8 + j] = 0x00000000; NVIC->IP[i * 8 + j] = 0x00000000;
@ -132,7 +132,7 @@ static void powerdown_scb(uint32_t vtor)
num_pri_reg = 12; num_pri_reg = 12;
#endif #endif
for (i = 0; i < num_pri_reg; i++) { for (i = 0; i < num_pri_reg; i++) {
#if defined(__CORTEX_M7) || defined(__CORTEX_M23) #if defined(__CORTEX_M7) || defined(__CORTEX_M23) || defined(__CORTEX_M33)
SCB->SHPR[i] = 0x00; SCB->SHPR[i] = 0x00;
#else #else
SCB->SHP[i] = 0x00; SCB->SHP[i] = 0x00;

View File

@ -21,7 +21,7 @@
#include<stdint.h> #include<stdint.h>
#if defined(__CORTEX_M0PLUS) || defined(__CORTEX_M3) || defined(__CORTEX_M4) || defined(__CORTEX_M7)\ #if defined(__CORTEX_M0PLUS) || defined(__CORTEX_M3) || defined(__CORTEX_M4) || defined(__CORTEX_M7)\
|| defined(__CORTEX_M23) || defined(__CORTEX_A9) || defined(__CORTEX_M23) || defined(__CORTEX_A9) || defined(__CORTEX_M33)
#define MBED_APPLICATION_SUPPORT 1 #define MBED_APPLICATION_SUPPORT 1
#else #else
#define MBED_APPLICATION_SUPPORT 0 #define MBED_APPLICATION_SUPPORT 0

View File

@ -57,10 +57,18 @@
#define MBED_ROM_START NS_CODE_START #define MBED_ROM_START NS_CODE_START
#endif #endif
#if !defined(MBED_APP_START)
#define MBED_APP_START MBED_ROM_START
#endif
#if !defined(MBED_ROM_SIZE) #if !defined(MBED_ROM_SIZE)
#define MBED_ROM_SIZE NS_CODE_SIZE #define MBED_ROM_SIZE NS_CODE_SIZE
#endif #endif
#if !defined(MBED_APP_SIZE)
#define MBED_APP_SIZE MBED_ROM_SIZE
#endif
#if !defined(MBED_RAM_START) #if !defined(MBED_RAM_START)
#define MBED_RAM_START NS_DATA_START #define MBED_RAM_START NS_DATA_START
#endif #endif
@ -70,11 +78,11 @@
#endif #endif
#define m_interrupts_start MBED_ROM_START #define m_interrupts_start MBED_APP_START
#define m_interrupts_size 0x140 #define m_interrupts_size 0x140
#define m_text_start MBED_ROM_START + 0x140 #define m_text_start MBED_APP_START + 0x140
#define m_text_size MBED_ROM_SIZE - 0x140 #define m_text_size MBED_APP_SIZE - 0x140
#define m_interrupts_ram_start MBED_RAM_START #define m_interrupts_ram_start MBED_RAM_START
#define m_interrupts_ram_size __ram_vector_table_size__ #define m_interrupts_ram_size __ram_vector_table_size__

View File

@ -33,10 +33,18 @@ __ram_vector_table__ = 1;
#define MBED_ROM_START NS_CODE_START #define MBED_ROM_START NS_CODE_START
#endif #endif
#if !defined(MBED_APP_START)
#define MBED_APP_START MBED_ROM_START
#endif
#if !defined(MBED_ROM_SIZE) #if !defined(MBED_ROM_SIZE)
#define MBED_ROM_SIZE NS_CODE_SIZE #define MBED_ROM_SIZE NS_CODE_SIZE
#endif #endif
#if !defined(MBED_APP_SIZE)
#define MBED_APP_SIZE MBED_ROM_SIZE
#endif
#if !defined(MBED_RAM_START) #if !defined(MBED_RAM_START)
#define MBED_RAM_START NS_DATA_START #define MBED_RAM_START NS_DATA_START
#endif #endif
@ -56,8 +64,8 @@ M_VECTOR_RAM_SIZE = DEFINED(__ram_vector_table__) ? 0x200 : 0x0;
MEMORY MEMORY
{ {
m_interrupts (RX) : ORIGIN = MBED_ROM_START, LENGTH = 0x140 m_interrupts (RX) : ORIGIN = MBED_APP_START, LENGTH = 0x140
m_text (RX) : ORIGIN = MBED_ROM_START + 0x140, LENGTH = MBED_ROM_SIZE - 0x140 m_text (RX) : ORIGIN = MBED_APP_START + 0x140, LENGTH = MBED_APP_SIZE - 0x140
m_data (RW) : ORIGIN = MBED_RAM_START, LENGTH = MBED_RAM_SIZE m_data (RW) : ORIGIN = MBED_RAM_START, LENGTH = MBED_RAM_SIZE
m_usb_sram (RW) : ORIGIN = 0x40100000, LENGTH = 0x00004000 m_usb_sram (RW) : ORIGIN = 0x40100000, LENGTH = 0x00004000
} }

View File

@ -34,10 +34,18 @@ if (!isdefinedsymbol(MBED_ROM_START)) {
define symbol MBED_ROM_START = NS_CODE_START; define symbol MBED_ROM_START = NS_CODE_START;
} }
if (!isdefinedsymbol(MBED_APP_START)) {
define symbol MBED_APP_START = MBED_ROM_START;
}
if (!isdefinedsymbol(MBED_ROM_SIZE)) { if (!isdefinedsymbol(MBED_ROM_SIZE)) {
define symbol MBED_ROM_SIZE = NS_CODE_SIZE; define symbol MBED_ROM_SIZE = NS_CODE_SIZE;
} }
if (!isdefinedsymbol(MBED_APP_SIZE)) {
define symbol MBED_APP_SIZE = MBED_ROM_SIZE;
}
if (!isdefinedsymbol(MBED_RAM_START)) { if (!isdefinedsymbol(MBED_RAM_START)) {
define symbol MBED_RAM_START = NS_DATA_START; define symbol MBED_RAM_START = NS_DATA_START;
} }
@ -72,11 +80,11 @@ if (isdefinedsymbol(__heap_size__)) {
define symbol __size_heap__ = 0x0400; define symbol __size_heap__ = 0x0400;
} }
define symbol m_interrupts_start = MBED_ROM_START; define symbol m_interrupts_start = MBED_APP_START;
define symbol m_interrupts_end = (MBED_ROM_START + 0x13F); define symbol m_interrupts_end = (MBED_APP_START + 0x13F);
define symbol m_text_start = (MBED_ROM_START + 0x140); define symbol m_text_start = (MBED_APP_START + 0x140);
define symbol m_text_end = (MBED_ROM_START + MBED_ROM_SIZE - 1); define symbol m_text_end = (MBED_APP_START + MBED_APP_SIZE - 1);
define symbol m_interrupts_ram_start = MBED_RAM_START; define symbol m_interrupts_ram_start = MBED_RAM_START;
define symbol m_interrupts_ram_end = (MBED_RAM_START + __ram_vector_table_size__ - 1); define symbol m_interrupts_ram_end = (MBED_RAM_START + __ram_vector_table_size__ - 1);

View File

@ -17,7 +17,9 @@
*/ */
#include "cmsis_nvic_virtual.h" #include "cmsis_nvic_virtual.h"
#include "psa/lifecycle.h" #include "mbed_toolchain.h"
MBED_NORETURN void mbed_psa_system_reset();
void __NVIC_TFMSystemReset(void) void __NVIC_TFMSystemReset(void)
{ {

View File

@ -2102,7 +2102,8 @@
"secure-ram-start": "0x30000000", "secure-ram-start": "0x30000000",
"secure-ram-size": "0x22000" "secure-ram-size": "0x22000"
}, },
"OUTPUT_EXT": "hex" "OUTPUT_EXT": "hex",
"bootloader_supported": true
}, },
"LPC55S69_S": { "LPC55S69_S": {
"inherits": ["SPE_Target", "LPC55S69"], "inherits": ["SPE_Target", "LPC55S69"],

View File

@ -21,6 +21,8 @@ from tools.resources import FileType
def find_secure_image(notify, resources, ns_image_path, configured_s_image_filename, image_type): def find_secure_image(notify, resources, ns_image_path, configured_s_image_filename, image_type):
""" Find secure image. """ """ Find secure image. """
if configured_s_image_filename is None:
return None
assert ns_image_path and configured_s_image_filename, 'ns_image_path and configured_s_image_path are mandatory' assert ns_image_path and configured_s_image_filename, 'ns_image_path and configured_s_image_path are mandatory'
assert image_type in [FileType.BIN, FileType.HEX], 'image_type must be of type BIN or HEX' assert image_type in [FileType.BIN, FileType.HEX], 'image_type must be of type BIN or HEX'

View File

@ -26,6 +26,9 @@ LPC55S69_BASE = path_join(MBED_OS_ROOT, 'targets', 'TARGET_NXP', 'TARGET_MCUXpre
def lpc55s69_complete(t_self, non_secure_bin, secure_bin): def lpc55s69_complete(t_self, non_secure_bin, secure_bin):
if secure_bin is None:
return None
assert os.path.isfile(secure_bin) assert os.path.isfile(secure_bin)
assert os.path.isfile(non_secure_bin) assert os.path.isfile(non_secure_bin)