mirror of https://github.com/ARMmbed/mbed-os.git
Merge pull request #12642 from OpenNuvoton/nuvoton_m263_custom_board
M263: Support custom boardpull/12682/head
commit
2c5660ae35
|
@ -19,6 +19,7 @@
|
||||||
#define MBED_PERIPHERALNAMES_H
|
#define MBED_PERIPHERALNAMES_H
|
||||||
|
|
||||||
#include "cmsis.h"
|
#include "cmsis.h"
|
||||||
|
#include "PinNames.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
@ -80,7 +81,16 @@ typedef enum {
|
||||||
UART_4 = (int) NU_MODNAME(UART4_BASE, 4, 0),
|
UART_4 = (int) NU_MODNAME(UART4_BASE, 4, 0),
|
||||||
UART_5 = (int) NU_MODNAME(UART5_BASE, 5, 0),
|
UART_5 = (int) NU_MODNAME(UART5_BASE, 5, 0),
|
||||||
// NOTE: board-specific
|
// NOTE: board-specific
|
||||||
STDIO_UART = UART_0
|
#if defined(MBED_CONF_TARGET_USB_UART)
|
||||||
|
USB_UART = MBED_CONF_TARGET_USB_UART,
|
||||||
|
#else
|
||||||
|
USB_UART = NC,
|
||||||
|
#endif
|
||||||
|
#if defined(MBED_CONF_TARGET_STDIO_UART)
|
||||||
|
STDIO_UART = MBED_CONF_TARGET_STDIO_UART
|
||||||
|
#else
|
||||||
|
STDIO_UART = USB_UART
|
||||||
|
#endif
|
||||||
|
|
||||||
} UARTName;
|
} UARTName;
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2019-2020 Nuvoton Technology Corporation
|
* Copyright (c) 2020, Nuvoton Technology Corporation
|
||||||
|
*
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
@ -14,8 +15,8 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
#ifndef MBED_PINNAMES_H
|
#ifndef __PIN_NAMES_COMMON_H__
|
||||||
#define MBED_PINNAMES_H
|
#define __PIN_NAMES_COMMON_H__
|
||||||
|
|
||||||
#include "cmsis.h"
|
#include "cmsis.h"
|
||||||
|
|
||||||
|
@ -71,77 +72,8 @@ typedef enum {
|
||||||
PullDefault = PullUp
|
PullDefault = PullUp
|
||||||
} PinMode;
|
} PinMode;
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
// Not connected
|
|
||||||
NC = (int)0xFFFFFFFF,
|
|
||||||
|
|
||||||
// Generic naming
|
|
||||||
PA_0 = NU_PORT_N_PIN_TO_PINNAME(0, 0), PA_1, PA_2, PA_3, PA_4, PA_5, PA_6, PA_7, PA_8, PA_9, PA_10, PA_11, PA_12, PA_13, PA_14, PA_15,
|
|
||||||
PB_0 = NU_PORT_N_PIN_TO_PINNAME(1, 0), PB_1, PB_2, PB_3, PB_4, PB_5, PB_6, PB_7, PB_8, PB_9, PB_10, PB_11, PB_12, PB_13, PB_14, PB_15,
|
|
||||||
PC_0 = NU_PORT_N_PIN_TO_PINNAME(2, 0), PC_1, PC_2, PC_3, PC_4, PC_5, PC_6, PC_7, PC_8, PC_9, PC_10, PC_11, PC_12, PC_13,
|
|
||||||
PD_0 = NU_PORT_N_PIN_TO_PINNAME(3, 0), PD_1, PD_2, PD_3, PD_4, PD_5, PD_6, PD_7, PD_8, PD_9, PD_10, PD_11, PD_12, PD_13, PD_14,
|
|
||||||
PE_0 = NU_PORT_N_PIN_TO_PINNAME(4, 0), PE_1, PE_2, PE_3, PE_4, PE_5, PE_6, PE_7, PE_8, PE_9, PE_10, PE_11, PE_12, PE_13, PE_14, PE_15,
|
|
||||||
PF_0 = NU_PORT_N_PIN_TO_PINNAME(5, 0), PF_1, PF_2, PF_3, PF_4, PF_5, PF_6, PF_7, PF_8, PF_9, PF_10, PF_11,
|
|
||||||
PG_0 = NU_PORT_N_PIN_TO_PINNAME(6, 0), PG_1, PG_2, PG_3, PG_4, PG_5, PG_6, PG_7, PG_8, PG_9, PG_10, PG_11, PG_12, PG_13, PG_14, PG_15,
|
|
||||||
PH_0 = NU_PORT_N_PIN_TO_PINNAME(7, 0), PH_1, PH_2, PH_3, PH_4, PH_5, PH_6, PH_7, PH_8, PH_9, PH_10, PH_11,
|
|
||||||
|
|
||||||
// Arduino UNO naming
|
|
||||||
A0 = PB_7,
|
|
||||||
A1 = PB_6,
|
|
||||||
A2 = PB_5,
|
|
||||||
A3 = PB_4,
|
|
||||||
A4 = PB_0,
|
|
||||||
A5 = PB_1,
|
|
||||||
|
|
||||||
D0 = PB_2,
|
|
||||||
D1 = PB_3,
|
|
||||||
D2 = PC_4,
|
|
||||||
D3 = PC_5,
|
|
||||||
D4 = PC_3,
|
|
||||||
D5 = PC_2,
|
|
||||||
D6 = PA_7,
|
|
||||||
D7 = PA_6,
|
|
||||||
D8 = PA_5,
|
|
||||||
D9 = PA_4,
|
|
||||||
D10 = PA_3,
|
|
||||||
D11 = PA_0,
|
|
||||||
D12 = PA_1,
|
|
||||||
D13 = PA_2,
|
|
||||||
D14 = PC_0,
|
|
||||||
D15 = PC_1,
|
|
||||||
|
|
||||||
// Other board-specific naming
|
|
||||||
|
|
||||||
// UART naming
|
|
||||||
USBTX = PB_13,
|
|
||||||
USBRX = PB_12,
|
|
||||||
STDIO_UART_TX = USBTX,
|
|
||||||
STDIO_UART_RX = USBRX,
|
|
||||||
|
|
||||||
// I2C naming
|
|
||||||
I2C_SCL = D15,
|
|
||||||
I2C_SDA = D14,
|
|
||||||
|
|
||||||
// LED naming
|
|
||||||
LED1 = PB_10,
|
|
||||||
LED2 = PB_10,
|
|
||||||
LED3 = PB_10, // No real LED. Just for passing ATS.
|
|
||||||
LED4 = PB_10, // No real LED. Just for passing ATS.
|
|
||||||
LED_RED = LED1,
|
|
||||||
|
|
||||||
// Button naming
|
|
||||||
SW2 = PB_11,
|
|
||||||
SW3 = PB_11,
|
|
||||||
BUTTON1 = SW2,
|
|
||||||
BUTTON2 = SW3,
|
|
||||||
|
|
||||||
// Force PinName to 32-bit required by NU_PINNAME_BIND(...)
|
|
||||||
FORCE_ENUM_PINNAME_32BIT = 0x7FFFFFFF,
|
|
||||||
|
|
||||||
} PinName;
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif // MBED_PINNAMES_H
|
#endif // __PIN_NAMES_COMMON_H__
|
|
@ -0,0 +1,118 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019-2020 Nuvoton Technology Corporation
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_PINNAMES_H
|
||||||
|
#define MBED_PINNAMES_H
|
||||||
|
|
||||||
|
#include "cmsis.h"
|
||||||
|
#include "PinNamesCommon.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
// Not connected
|
||||||
|
NC = (int)0xFFFFFFFF,
|
||||||
|
|
||||||
|
// Generic naming
|
||||||
|
PA_0 = NU_PORT_N_PIN_TO_PINNAME(0, 0), PA_1, PA_2, PA_3, PA_4, PA_5, PA_6, PA_7, PA_8, PA_9, PA_10, PA_11, PA_12, PA_13, PA_14, PA_15,
|
||||||
|
PB_0 = NU_PORT_N_PIN_TO_PINNAME(1, 0), PB_1, PB_2, PB_3, PB_4, PB_5, PB_6, PB_7, PB_8, PB_9, PB_10, PB_11, PB_12, PB_13, PB_14, PB_15,
|
||||||
|
PC_0 = NU_PORT_N_PIN_TO_PINNAME(2, 0), PC_1, PC_2, PC_3, PC_4, PC_5, PC_6, PC_7, PC_8, PC_9, PC_10, PC_11, PC_12, PC_13,
|
||||||
|
PD_0 = NU_PORT_N_PIN_TO_PINNAME(3, 0), PD_1, PD_2, PD_3, PD_4, PD_5, PD_6, PD_7, PD_8, PD_9, PD_10, PD_11, PD_12, PD_13, PD_14,
|
||||||
|
PE_0 = NU_PORT_N_PIN_TO_PINNAME(4, 0), PE_1, PE_2, PE_3, PE_4, PE_5, PE_6, PE_7, PE_8, PE_9, PE_10, PE_11, PE_12, PE_13, PE_14, PE_15,
|
||||||
|
PF_0 = NU_PORT_N_PIN_TO_PINNAME(5, 0), PF_1, PF_2, PF_3, PF_4, PF_5, PF_6, PF_7, PF_8, PF_9, PF_10, PF_11,
|
||||||
|
PG_0 = NU_PORT_N_PIN_TO_PINNAME(6, 0), PG_1, PG_2, PG_3, PG_4, PG_5, PG_6, PG_7, PG_8, PG_9, PG_10, PG_11, PG_12, PG_13, PG_14, PG_15,
|
||||||
|
PH_0 = NU_PORT_N_PIN_TO_PINNAME(7, 0), PH_1, PH_2, PH_3, PH_4, PH_5, PH_6, PH_7, PH_8, PH_9, PH_10, PH_11,
|
||||||
|
|
||||||
|
// Arduino UNO naming
|
||||||
|
A0 = PB_7,
|
||||||
|
A1 = PB_6,
|
||||||
|
A2 = PB_5,
|
||||||
|
A3 = PB_4,
|
||||||
|
A4 = PB_0,
|
||||||
|
A5 = PB_1,
|
||||||
|
|
||||||
|
D0 = PB_2,
|
||||||
|
D1 = PB_3,
|
||||||
|
D2 = PC_4,
|
||||||
|
D3 = PC_5,
|
||||||
|
D4 = PC_3,
|
||||||
|
D5 = PC_2,
|
||||||
|
D6 = PA_7,
|
||||||
|
D7 = PA_6,
|
||||||
|
D8 = PA_5,
|
||||||
|
D9 = PA_4,
|
||||||
|
D10 = PA_3,
|
||||||
|
D11 = PA_0,
|
||||||
|
D12 = PA_1,
|
||||||
|
D13 = PA_2,
|
||||||
|
D14 = PC_0,
|
||||||
|
D15 = PC_1,
|
||||||
|
|
||||||
|
// Other board-specific naming
|
||||||
|
|
||||||
|
// UART naming
|
||||||
|
#if defined(MBED_CONF_TARGET_USB_UART_TX)
|
||||||
|
USBTX = MBED_CONF_TARGET_USB_UART_TX,
|
||||||
|
#else
|
||||||
|
USBTX = NC,
|
||||||
|
#endif
|
||||||
|
#if defined(MBED_CONF_TARGET_USB_UART_RX)
|
||||||
|
USBRX = MBED_CONF_TARGET_USB_UART_RX,
|
||||||
|
#else
|
||||||
|
USBRX = NC,
|
||||||
|
#endif
|
||||||
|
#if defined(MBED_CONF_TARGET_STDIO_UART_TX)
|
||||||
|
STDIO_UART_TX = MBED_CONF_TARGET_STDIO_UART_TX,
|
||||||
|
#else
|
||||||
|
STDIO_UART_TX = USBTX,
|
||||||
|
#endif
|
||||||
|
#if defined(MBED_CONF_TARGET_STDIO_UART_RX)
|
||||||
|
STDIO_UART_RX = MBED_CONF_TARGET_STDIO_UART_RX,
|
||||||
|
#else
|
||||||
|
STDIO_UART_RX = USBRX,
|
||||||
|
#endif
|
||||||
|
SERIAL_TX = D1,
|
||||||
|
SERIAL_RX = D0,
|
||||||
|
|
||||||
|
// I2C naming
|
||||||
|
I2C_SCL = D15,
|
||||||
|
I2C_SDA = D14,
|
||||||
|
|
||||||
|
// LED naming
|
||||||
|
LED1 = PB_10,
|
||||||
|
LED2 = PB_10,
|
||||||
|
LED3 = PB_10, // No real LED. Just for passing ATS.
|
||||||
|
LED4 = PB_10, // No real LED. Just for passing ATS.
|
||||||
|
LED_RED = LED1,
|
||||||
|
|
||||||
|
// Button naming
|
||||||
|
SW2 = PB_11,
|
||||||
|
SW3 = PB_11,
|
||||||
|
BUTTON1 = SW2,
|
||||||
|
BUTTON2 = SW3,
|
||||||
|
|
||||||
|
// Force PinName to 32-bit required by NU_PINNAME_BIND(...)
|
||||||
|
FORCE_ENUM_PINNAME_32BIT = 0x7FFFFFFF,
|
||||||
|
|
||||||
|
} PinName;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // MBED_PINNAMES_H
|
|
@ -0,0 +1,133 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020, Nuvoton Technology Corporation
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __M261_MEM_H__
|
||||||
|
#define __M261_MEM_H__
|
||||||
|
|
||||||
|
/* About M261_mem.h/M261_mem.icf.h
|
||||||
|
*
|
||||||
|
* 1. M261_mem.h is created for centralizing memory configuration. It will be included by C/C++ files
|
||||||
|
* and linker files (except IAR linker file).
|
||||||
|
* 2. IAR linker doesn't support preprocessor, so M261_mem.icf.h, duplicate of M261_mem.h
|
||||||
|
* is created for IAR linker file.
|
||||||
|
* 3. To continue above, we name M261_mem.icf.h instead of M261_mem.icf because:
|
||||||
|
* (1) Mbed OS build tool may mis-regard M261_mem.icf as the main linker configuration file.
|
||||||
|
* (2) *.icf files may not be present in search directories for "include" directive. Per observation,
|
||||||
|
* the search directories are inconsistent among normal example build and test code build. To address
|
||||||
|
* it, we name M261_mem.icf.h instead because *.h files are always present in these builds
|
||||||
|
* (already there or via copy).
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Default memory specification
|
||||||
|
*
|
||||||
|
* Flash size: 512KiB
|
||||||
|
* SRAM size: 96KiB
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Resolve ROM start */
|
||||||
|
#ifndef MBED_ROM_START
|
||||||
|
#define MBED_ROM_START (0x0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Resolve ROM size */
|
||||||
|
#ifndef MBED_ROM_SIZE
|
||||||
|
#define MBED_ROM_SIZE (0x80000)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Resolve RAM start */
|
||||||
|
#ifndef MBED_RAM_START
|
||||||
|
#define MBED_RAM_START (0x20000000)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Resolve RAM size */
|
||||||
|
#ifndef MBED_RAM_SIZE
|
||||||
|
#define MBED_RAM_SIZE (0x18000)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Mbed build tool passes just APPLICATION_xxx macros to C/C++ files and just
|
||||||
|
* MBED_APP_xxx macros to linker files even though they mean the same thing.
|
||||||
|
* Because this file is to include by both C/C++ files and linker files, we add
|
||||||
|
* these macros according to the others for consistency when they are missing
|
||||||
|
* in compile or link stage. */
|
||||||
|
|
||||||
|
#ifndef APPLICATION_ADDR
|
||||||
|
#ifdef MBED_APP_START
|
||||||
|
#define APPLICATION_ADDR MBED_APP_START
|
||||||
|
#else
|
||||||
|
#define APPLICATION_ADDR MBED_ROM_START
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef APPLICATION_SIZE
|
||||||
|
#ifdef MBED_APP_SIZE
|
||||||
|
#define APPLICATION_SIZE MBED_APP_SIZE
|
||||||
|
#else
|
||||||
|
#define APPLICATION_SIZE MBED_ROM_SIZE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef APPLICATION_RAM_ADDR
|
||||||
|
#ifdef MBED_RAM_APP_START
|
||||||
|
#define APPLICATION_RAM_ADDR MBED_RAM_APP_START
|
||||||
|
#else
|
||||||
|
#define APPLICATION_RAM_ADDR MBED_RAM_START
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef APPLICATION_RAM_SIZE
|
||||||
|
#ifdef MBED_RAM_APP_SIZE
|
||||||
|
#define APPLICATION_RAM_SIZE MBED_RAM_APP_SIZE
|
||||||
|
#else
|
||||||
|
#define APPLICATION_RAM_SIZE MBED_RAM_SIZE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef MBED_APP_START
|
||||||
|
#define MBED_APP_START APPLICATION_ADDR
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef MBED_APP_SIZE
|
||||||
|
#define MBED_APP_SIZE APPLICATION_SIZE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef MBED_RAM_APP_START
|
||||||
|
#define MBED_RAM_APP_START APPLICATION_RAM_ADDR
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef MBED_RAM_APP_SIZE
|
||||||
|
#define MBED_RAM_APP_SIZE APPLICATION_RAM_SIZE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (APPLICATION_ADDR != MBED_APP_START)
|
||||||
|
#error("APPLICATION_ADDR and MBED_APP_START are not the same!!!")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (APPLICATION_SIZE != MBED_APP_SIZE)
|
||||||
|
#error("APPLICATION_SIZE and MBED_APP_SIZE are not the same!!!")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (APPLICATION_RAM_ADDR != MBED_RAM_APP_START)
|
||||||
|
#error("APPLICATION_RAM_ADDR and MBED_RAM_APP_START are not the same!!!")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (APPLICATION_RAM_SIZE != MBED_RAM_APP_SIZE)
|
||||||
|
#error("APPLICATION_RAM_SIZE and MBED_RAM_APP_SIZE are not the same!!!")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __M261_MEM_H__ */
|
|
@ -0,0 +1,115 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020, Nuvoton Technology Corporation
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* See M261_mem.h for documentation */
|
||||||
|
|
||||||
|
/* Default memory specification
|
||||||
|
*
|
||||||
|
* Flash size: 512KiB
|
||||||
|
* SRAM size: 96KiB
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Resolve ROM start */
|
||||||
|
if (!isdefinedsymbol(MBED_ROM_START)) {
|
||||||
|
define symbol MBED_ROM_START = 0x0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Resolve ROM size */
|
||||||
|
if (!isdefinedsymbol(MBED_ROM_SIZE)) {
|
||||||
|
define symbol MBED_ROM_SIZE = 0x80000;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Resolve RAM start */
|
||||||
|
if (!isdefinedsymbol(MBED_RAM_START)) {
|
||||||
|
define symbol MBED_RAM_START = 0x20000000;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Resolve RAM size */
|
||||||
|
if (!isdefinedsymbol(MBED_RAM_SIZE)) {
|
||||||
|
define symbol MBED_RAM_SIZE = 0x18000;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Mbed build tool passes just APPLICATION_xxx macros to C/C++ files and just
|
||||||
|
* MBED_APP_xxx macros to linker files even though they mean the same thing.
|
||||||
|
* Because this file is to include by both C/C++ files and linker files, we add
|
||||||
|
* these macros according to the others for consistency when they are missing
|
||||||
|
* in compile or link stage. */
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(APPLICATION_ADDR)) {
|
||||||
|
if (isdefinedsymbol(MBED_APP_START)) {
|
||||||
|
define symbol APPLICATION_ADDR = MBED_APP_START;
|
||||||
|
} else {
|
||||||
|
define symbol APPLICATION_ADDR = MBED_ROM_START;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(APPLICATION_SIZE)) {
|
||||||
|
if (isdefinedsymbol(MBED_APP_SIZE)) {
|
||||||
|
define symbol APPLICATION_SIZE = MBED_APP_SIZE;
|
||||||
|
} else {
|
||||||
|
define symbol APPLICATION_SIZE = MBED_ROM_SIZE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(APPLICATION_RAM_ADDR)) {
|
||||||
|
if (isdefinedsymbol(MBED_RAM_APP_START)) {
|
||||||
|
define symbol APPLICATION_RAM_ADDR = MBED_RAM_APP_START;
|
||||||
|
} else {
|
||||||
|
define symbol APPLICATION_RAM_ADDR = MBED_RAM_START;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(APPLICATION_RAM_SIZE)) {
|
||||||
|
if (isdefinedsymbol(MBED_RAM_APP_SIZE)) {
|
||||||
|
define symbol APPLICATION_RAM_SIZE = MBED_RAM_APP_SIZE;
|
||||||
|
} else {
|
||||||
|
define symbol APPLICATION_RAM_SIZE = MBED_RAM_SIZE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(MBED_APP_START)) {
|
||||||
|
define symbol MBED_APP_START = APPLICATION_ADDR;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(MBED_APP_SIZE)) {
|
||||||
|
define symbol MBED_APP_SIZE = APPLICATION_SIZE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(MBED_RAM_APP_START)) {
|
||||||
|
define symbol MBED_RAM_APP_START = APPLICATION_RAM_ADDR;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isdefinedsymbol(MBED_RAM_APP_SIZE)) {
|
||||||
|
define symbol MBED_RAM_APP_SIZE = APPLICATION_RAM_SIZE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (APPLICATION_ADDR != MBED_APP_START) {
|
||||||
|
error "APPLICATION_ADDR and MBED_APP_START are not the same!!!";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (APPLICATION_SIZE != MBED_APP_SIZE) {
|
||||||
|
error "APPLICATION_SIZE and MBED_APP_SIZE are not the same!!!";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (APPLICATION_RAM_ADDR != MBED_RAM_APP_START) {
|
||||||
|
error "APPLICATION_RAM_ADDR and MBED_RAM_APP_START are not the same!!!";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (APPLICATION_RAM_SIZE != MBED_RAM_APP_SIZE) {
|
||||||
|
error "APPLICATION_RAM_SIZE and MBED_RAM_APP_SIZE are not the same!!!";
|
||||||
|
}
|
|
@ -18,34 +18,29 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "../M261_mem.h"
|
||||||
#if !defined(MBED_APP_START)
|
|
||||||
#define MBED_APP_START 0x00000000
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(MBED_APP_SIZE)
|
|
||||||
#define MBED_APP_SIZE 0x00080000
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(MBED_BOOT_STACK_SIZE)
|
#if !defined(MBED_BOOT_STACK_SIZE)
|
||||||
#define MBED_BOOT_STACK_SIZE 0x400
|
#define MBED_BOOT_STACK_SIZE 0x400
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define VECTOR_SIZE (4*(16 + 102))
|
||||||
|
|
||||||
LR_IROM1 MBED_APP_START {
|
LR_IROM1 MBED_APP_START {
|
||||||
ER_IROM1 MBED_APP_START { ; load address = execution address
|
ER_IROM1 +0 { ; load address = execution address
|
||||||
*(RESET, +First)
|
*(RESET, +First)
|
||||||
*(InRoot$$Sections)
|
*(InRoot$$Sections)
|
||||||
.ANY (+RO)
|
.ANY (+RO)
|
||||||
}
|
}
|
||||||
|
|
||||||
ARM_LIB_STACK 0x20000000 EMPTY MBED_BOOT_STACK_SIZE {
|
ARM_LIB_STACK MBED_RAM_APP_START EMPTY MBED_BOOT_STACK_SIZE {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Reserve for vectors
|
/* Reserve for vectors
|
||||||
*
|
*
|
||||||
* Vector table base address is required to be 128-byte aligned at a minimum.
|
* Vector table base address is required to be 128-byte aligned at a minimum.
|
||||||
* A PE might impose further restrictions on it. */
|
* A PE might impose further restrictions on it. */
|
||||||
ER_IRAMVEC AlignExpr(+0, 128) EMPTY (4*(16 + 102)) { ; Reserve for vectors
|
ER_IRAMVEC AlignExpr(+0, 128) EMPTY VECTOR_SIZE { ; Reserve for vectors
|
||||||
}
|
}
|
||||||
|
|
||||||
RW_m_crash_data AlignExpr(+0, 0x100) EMPTY 0x100 { ; Reserve for crash data storage
|
RW_m_crash_data AlignExpr(+0, 0x100) EMPTY 0x100 { ; Reserve for crash data storage
|
||||||
|
@ -55,8 +50,8 @@ LR_IROM1 MBED_APP_START {
|
||||||
.ANY (+RW +ZI)
|
.ANY (+RW +ZI)
|
||||||
}
|
}
|
||||||
|
|
||||||
ARM_LIB_HEAP AlignExpr(+0, 16) EMPTY (0x20000000 + 0x18000 - AlignExpr(ImageLimit(RW_IRAM1), 16)) {
|
ARM_LIB_HEAP AlignExpr(+0, 16) EMPTY (MBED_RAM_APP_START + MBED_RAM_APP_SIZE - AlignExpr(ImageLimit(RW_IRAM1), 16)) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ScatterAssert(LoadLimit(LR_IROM1) <= (MBED_APP_START + MBED_APP_SIZE)) ; 512 KB APROM
|
ScatterAssert(LoadLimit(LR_IROM1) <= (MBED_APP_START + MBED_APP_SIZE))
|
||||||
ScatterAssert(ImageLimit(ARM_LIB_HEAP) <= 0x20018000) ; 96 KB SRAM
|
ScatterAssert(ImageLimit(ARM_LIB_HEAP) <= (MBED_RAM_APP_START + MBED_RAM_APP_SIZE))
|
||||||
|
|
|
@ -20,13 +20,7 @@
|
||||||
* Nuvoton M261 GCC linker script file
|
* Nuvoton M261 GCC linker script file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if !defined(MBED_APP_START)
|
#include "../M261_mem.h"
|
||||||
#define MBED_APP_START 0x00000000
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(MBED_APP_SIZE)
|
|
||||||
#define MBED_APP_SIZE 0x00080000
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(MBED_BOOT_STACK_SIZE)
|
#if !defined(MBED_BOOT_STACK_SIZE)
|
||||||
#define MBED_BOOT_STACK_SIZE 0x400
|
#define MBED_BOOT_STACK_SIZE 0x400
|
||||||
|
@ -39,7 +33,7 @@ MEMORY
|
||||||
{
|
{
|
||||||
VECTORS (rx) : ORIGIN = MBED_APP_START, LENGTH = 0x00000400
|
VECTORS (rx) : ORIGIN = MBED_APP_START, LENGTH = 0x00000400
|
||||||
FLASH (rx) : ORIGIN = MBED_APP_START + 0x400, LENGTH = MBED_APP_SIZE - 0x00000400
|
FLASH (rx) : ORIGIN = MBED_APP_START + 0x400, LENGTH = MBED_APP_SIZE - 0x00000400
|
||||||
RAM_INTERN (rwx) : ORIGIN = 0x20000000, LENGTH = 0x00018000 - 0x00000000
|
RAM_INTERN (rwx) : ORIGIN = MBED_RAM_APP_START, LENGTH = MBED_RAM_APP_SIZE
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -19,18 +19,19 @@
|
||||||
/*###ICF### Section handled by ICF editor, don't touch! ****/
|
/*###ICF### Section handled by ICF editor, don't touch! ****/
|
||||||
/*-Editor annotation file-*/
|
/*-Editor annotation file-*/
|
||||||
/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
|
/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
|
||||||
if (!isdefinedsymbol(MBED_APP_START)) { define symbol MBED_APP_START = 0x00000000; }
|
|
||||||
if (!isdefinedsymbol(MBED_APP_SIZE)) { define symbol MBED_APP_SIZE = 0x00080000; }
|
include "../M261_mem.icf.h";
|
||||||
|
|
||||||
if (!isdefinedsymbol(MBED_BOOT_STACK_SIZE)) { define symbol MBED_BOOT_STACK_SIZE = 0x400; }
|
if (!isdefinedsymbol(MBED_BOOT_STACK_SIZE)) { define symbol MBED_BOOT_STACK_SIZE = 0x400; }
|
||||||
/*-Specials-*/
|
/*-Specials-*/
|
||||||
define symbol __ICFEDIT_intvec_start__ = MBED_APP_START;
|
define symbol __ICFEDIT_intvec_start__ = MBED_APP_START;
|
||||||
/*-Memory Regions-*/
|
/*-Memory Regions-*/
|
||||||
define symbol __ICFEDIT_region_ROM_start__ = MBED_APP_START;
|
define symbol __ICFEDIT_region_ROM_start__ = MBED_APP_START;
|
||||||
define symbol __ICFEDIT_region_ROM_end__ = MBED_APP_START + MBED_APP_SIZE - 1;
|
define symbol __ICFEDIT_region_ROM_end__ = MBED_APP_START + MBED_APP_SIZE - 1;
|
||||||
define symbol __ICFEDIT_region_IRAM_start__ = 0x20000000;
|
define symbol __ICFEDIT_region_IRAM_start__ = MBED_RAM_APP_START;
|
||||||
define symbol __ICFEDIT_region_IRAM_end__ = 0x20017F00 - 1;
|
define symbol __ICFEDIT_region_IRAM_end__ = MBED_RAM_APP_START + MBED_RAM_APP_SIZE - 0x100 - 1;
|
||||||
define symbol __region_CRASH_DATA_RAM_start__ = 0x20017F00;
|
define symbol __region_CRASH_DATA_RAM_start__ = MBED_RAM_APP_START + MBED_RAM_APP_SIZE - 0x100;
|
||||||
define symbol __region_CRASH_DATA_RAM_end__ = 0x20018000 - 1;
|
define symbol __region_CRASH_DATA_RAM_end__ = MBED_RAM_APP_START + MBED_RAM_APP_SIZE - 1;
|
||||||
/*-Sizes-*/
|
/*-Sizes-*/
|
||||||
define symbol __ICFEDIT_size_cstack__ = MBED_BOOT_STACK_SIZE;
|
define symbol __ICFEDIT_size_cstack__ = MBED_BOOT_STACK_SIZE;
|
||||||
define symbol __ICFEDIT_size_intvec__ = (4 * (16 + 102));
|
define symbol __ICFEDIT_size_intvec__ = (4 * (16 + 102));
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "flash_data.h"
|
#include "flash_data.h"
|
||||||
#include "mbed_critical.h"
|
#include "mbed_critical.h"
|
||||||
|
#include "M261_mem.h"
|
||||||
|
|
||||||
// This is a flash algo binary blob. It is PIC (position independent code) that should be stored in RAM
|
// This is a flash algo binary blob. It is PIC (position independent code) that should be stored in RAM
|
||||||
// NOTE: On ARMv7-M/ARMv8-M, instruction fetches are always little-endian.
|
// NOTE: On ARMv7-M/ARMv8-M, instruction fetches are always little-endian.
|
||||||
|
@ -82,7 +83,7 @@ static const flash_algo_t flash_algo_config = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static const sector_info_t sectors_info[] = {
|
static const sector_info_t sectors_info[] = {
|
||||||
{0x0, 0x800}, // (start, sector size)
|
{MBED_ROM_START, 0x800}, // (start, sector size)
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Secure flash */
|
/* Secure flash */
|
||||||
|
@ -90,8 +91,8 @@ static const flash_target_config_t flash_target_config = {
|
||||||
.page_size = 4, // 4 bytes
|
.page_size = 4, // 4 bytes
|
||||||
// Here page_size is program unit, which is different
|
// Here page_size is program unit, which is different
|
||||||
// than FMC definition.
|
// than FMC definition.
|
||||||
.flash_start = 0x0,
|
.flash_start = MBED_ROM_START,
|
||||||
.flash_size = 0x80000, // 512 KB
|
.flash_size = MBED_ROM_SIZE,
|
||||||
.sectors = sectors_info,
|
.sectors = sectors_info,
|
||||||
.sector_info_count = sizeof(sectors_info) / sizeof(sector_info_t)
|
.sector_info_count = sizeof(sectors_info) / sizeof(sector_info_t)
|
||||||
};
|
};
|
||||||
|
|
|
@ -14712,13 +14712,13 @@
|
||||||
"5"
|
"5"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"NUMAKER_IOT_M263A": {
|
"MCU_M261": {
|
||||||
"core": "Cortex-M23",
|
"core": "Cortex-M23",
|
||||||
"default_toolchain": "ARMC6",
|
"default_toolchain": "ARMC6",
|
||||||
|
"public": false,
|
||||||
"extra_labels": [
|
"extra_labels": [
|
||||||
"NUVOTON",
|
"NUVOTON",
|
||||||
"M261",
|
"M261",
|
||||||
"M263KIAAE",
|
|
||||||
"FLASH_CMSIS_ALGO"
|
"FLASH_CMSIS_ALGO"
|
||||||
],
|
],
|
||||||
"macros": [
|
"macros": [
|
||||||
|
@ -14732,6 +14732,30 @@
|
||||||
"IAR"
|
"IAR"
|
||||||
],
|
],
|
||||||
"config": {
|
"config": {
|
||||||
|
"usb-uart": {
|
||||||
|
"help": "Configure USB_UART. USB_UART and USB_UART_TX/USB_UART_RX must be consistent.",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
"usb-uart-tx": {
|
||||||
|
"help": "Configure USBTX. USB_UART and USBTX/USBRX must be consistent.",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
"usb-uart-rx": {
|
||||||
|
"help": "Configure USBRX. USB_UART and USBTX/USBRX must be consistent.",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
"stdio-uart": {
|
||||||
|
"help": "Configure STDIO_UART. STDIO_UART and STDIO_UART_TX/STDIO_UART_RX must be consistent. STDIO_UART defaults to USB_UART.",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
"stdio-uart-tx": {
|
||||||
|
"help": "Configure STDIO_UART_TX. STDIO_UART and STDIO_UART_TX/STDIO_UART_RX must be consistent. STDIO_UART_TX defaults to USBTX.",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
"stdio-uart-rx": {
|
||||||
|
"help": "Configure STDIO_UART_RX. STDIO_UART and STDIO_UART_TX/STDIO_UART_RX must be consistent. STDIO_UART_RX defaults to USBRX.",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
"gpio-irq-debounce-enable": {
|
"gpio-irq-debounce-enable": {
|
||||||
"help": "Enable GPIO IRQ debounce",
|
"help": "Enable GPIO IRQ debounce",
|
||||||
"value": 0
|
"value": 0
|
||||||
|
@ -14782,13 +14806,9 @@
|
||||||
"components_add": [
|
"components_add": [
|
||||||
"FLASHIAP"
|
"FLASHIAP"
|
||||||
],
|
],
|
||||||
"detect_code": [
|
|
||||||
"1310"
|
|
||||||
],
|
|
||||||
"release_versions": [
|
"release_versions": [
|
||||||
"5"
|
"5"
|
||||||
],
|
],
|
||||||
"device_name": "M263KIAAE",
|
|
||||||
"bootloader_supported": true,
|
"bootloader_supported": true,
|
||||||
"overrides": {
|
"overrides": {
|
||||||
"deep-sleep-latency": 1,
|
"deep-sleep-latency": 1,
|
||||||
|
@ -14796,6 +14816,20 @@
|
||||||
},
|
},
|
||||||
"forced_reset_timeout": 3
|
"forced_reset_timeout": 3
|
||||||
},
|
},
|
||||||
|
"NUMAKER_IOT_M263A": {
|
||||||
|
"inherits": [
|
||||||
|
"MCU_M261"
|
||||||
|
],
|
||||||
|
"device_name": "M263KIAAE",
|
||||||
|
"detect_code": [
|
||||||
|
"1310"
|
||||||
|
],
|
||||||
|
"overrides": {
|
||||||
|
"usb-uart": "UART_0",
|
||||||
|
"usb-uart-tx": "PB_13",
|
||||||
|
"usb-uart-rx": "PB_12"
|
||||||
|
}
|
||||||
|
},
|
||||||
"NUCLEO_G071RB": {
|
"NUCLEO_G071RB": {
|
||||||
"inherits": [
|
"inherits": [
|
||||||
"FAMILY_STM32"
|
"FAMILY_STM32"
|
||||||
|
|
Loading…
Reference in New Issue