mirror of https://github.com/ARMmbed/mbed-os.git
parent
d6088e5017
commit
eb5cef84fd
File diff suppressed because it is too large
Load Diff
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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__
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
|
@ -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"],
|
||||||
|
|
|
@ -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'
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue