TEST

Dependencies:   max32630fthr Adafruit_FeatherOLED USBDevice

Revision:
1:f60eafbf009a
diff -r 07d28b5db986 -r f60eafbf009a patches/0001-porting-MAX32625PICO-to-mbed-os-5.patch
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/patches/0001-porting-MAX32625PICO-to-mbed-os-5.patch	Wed Apr 10 14:56:25 2019 +0300
@@ -0,0 +1,611 @@
+From 0420b36056436f6f7b387b614de8ab9e0aa0f373 Mon Sep 17 00:00:00 2001
+From: Mahir Ozturk <Mahir.Ozturk@maximintegrated.com>
+Date: Wed, 29 Mar 2017 14:16:50 +0300
+Subject: [PATCH] porting MAX32625PICO to mbed-os 5
+
+---
+ .../TARGET_MAX32625PICO/PeripheralNames.h          |  88 +++++++++++
+ .../TARGET_MAX32625/TARGET_MAX32625PICO/PinNames.h | 140 ++++++++++++++++
+ .../TARGET_MAX32625PICO/low_level_init.c           |  56 +++++++
+ .../TARGET_MAX32625PICO/MAX32625.sct               |  16 ++
+ .../TARGET_MAX32625PICO/max32625.ld                | 176 +++++++++++++++++++++
+ .../TOOLCHAIN_IAR/TARGET_MAX32625PICO/MAX32625.icf |  29 ++++
+ .../TARGET_MAX32625/device/system_max32625.c       |   7 +
+ targets/targets.json                               |   9 ++
+ 8 files changed, 521 insertions(+)
+ create mode 100644 targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PeripheralNames.h
+ create mode 100644 targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PinNames.h
+ create mode 100644 targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/low_level_init.c
+ create mode 100644 targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_ARM_STD/TARGET_MAX32625PICO/MAX32625.sct
+ create mode 100644 targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_GCC_ARM/TARGET_MAX32625PICO/max32625.ld
+ create mode 100644 targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_IAR/TARGET_MAX32625PICO/MAX32625.icf
+
+diff --git a/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PeripheralNames.h b/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PeripheralNames.h
+new file mode 100644
+index 000000000..4686ef9c9
+--- /dev/null
++++ b/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PeripheralNames.h
+@@ -0,0 +1,88 @@
++/*******************************************************************************
++ * Copyright (C) 2016 Maxim Integrated Products, Inc., All Rights Reserved.
++ *
++ * Permission is hereby granted, free of charge, to any person obtaining a
++ * copy of this software and associated documentation files (the "Software"),
++ * to deal in the Software without restriction, including without limitation
++ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
++ * and/or sell copies of the Software, and to permit persons to whom the
++ * Software is furnished to do so, subject to the following conditions:
++ *
++ * The above copyright notice and this permission notice shall be included
++ * in all copies or substantial portions of the Software.
++ *
++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
++ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
++ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
++ * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
++ * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
++ * OTHER DEALINGS IN THE SOFTWARE.
++ *
++ * Except as contained in this notice, the name of Maxim Integrated
++ * Products, Inc. shall not be used except as stated in the Maxim Integrated
++ * Products, Inc. Branding Policy.
++ *
++ * The mere transfer of this software does not imply any licenses
++ * of trade secrets, proprietary technology, copyrights, patents,
++ * trademarks, maskwork rights, or any other form of intellectual
++ * property whatsoever. Maxim Integrated Products, Inc. retains all
++ * ownership rights.
++ *******************************************************************************
++ */
++
++#ifndef MBED_PERIPHERALNAMES_H
++#define MBED_PERIPHERALNAMES_H
++
++#include "cmsis.h"
++
++#ifdef __cplusplus
++extern "C" {
++#endif
++
++typedef enum {
++    UART_0 = MXC_BASE_UART0,
++    UART_1 = MXC_BASE_UART1,
++    UART_2 = MXC_BASE_UART2,
++    STDIO_UART = UART_1
++} UARTName;
++
++typedef enum {
++    I2C_0 = MXC_BASE_I2CM0,
++    I2C_1 = MXC_BASE_I2CM1
++} I2CName;
++
++typedef enum {
++    SPI_0 = MXC_BASE_SPIM0,
++    SPI_1 = MXC_BASE_SPIM1,
++    SPI_2 = MXC_BASE_SPIM2
++} SPIName;
++
++typedef enum {
++    PWM_0 = MXC_BASE_PT0,
++    PWM_1 = MXC_BASE_PT1,
++    PWM_2 = MXC_BASE_PT2,
++    PWM_3 = MXC_BASE_PT3,
++    PWM_4 = MXC_BASE_PT4,
++    PWM_5 = MXC_BASE_PT5,
++    PWM_6 = MXC_BASE_PT6,
++    PWM_7 = MXC_BASE_PT7,
++    PWM_8 = MXC_BASE_PT8,
++    PWM_9 = MXC_BASE_PT9,
++    PWM_10 = MXC_BASE_PT10,
++    PWM_11 = MXC_BASE_PT11,
++    PWM_12 = MXC_BASE_PT12,
++    PWM_13 = MXC_BASE_PT13,
++    PWM_14 = MXC_BASE_PT14,
++    PWM_15 = MXC_BASE_PT15
++} PWMName;
++
++typedef enum {
++    ADC = MXC_BASE_ADC
++} ADCName;
++
++#ifdef __cplusplus
++}
++#endif
++
++#endif
+diff --git a/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PinNames.h b/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PinNames.h
+new file mode 100644
+index 000000000..1cbd97e37
+--- /dev/null
++++ b/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/PinNames.h
+@@ -0,0 +1,140 @@
++/*******************************************************************************
++ * Copyright (C) 2016 Maxim Integrated Products, Inc., All Rights Reserved.
++ *
++ * Permission is hereby granted, free of charge, to any person obtaining a
++ * copy of this software and associated documentation files (the "Software"),
++ * to deal in the Software without restriction, including without limitation
++ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
++ * and/or sell copies of the Software, and to permit persons to whom the
++ * Software is furnished to do so, subject to the following conditions:
++ *
++ * The above copyright notice and this permission notice shall be included
++ * in all copies or substantial portions of the Software.
++ *
++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
++ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
++ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
++ * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
++ * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
++ * OTHER DEALINGS IN THE SOFTWARE.
++ *
++ * Except as contained in this notice, the name of Maxim Integrated
++ * Products, Inc. shall not be used except as stated in the Maxim Integrated
++ * Products, Inc. Branding Policy.
++ *
++ * The mere transfer of this software does not imply any licenses
++ * of trade secrets, proprietary technology, copyrights, patents,
++ * trademarks, maskwork rights, or any other form of intellectual
++ * property whatsoever. Maxim Integrated Products, Inc. retains all
++ * ownership rights.
++ *******************************************************************************
++ */
++
++#ifndef MBED_PINNAMES_H
++#define MBED_PINNAMES_H
++
++#include "cmsis.h"
++#include "gpio_regs.h"
++
++#ifdef __cplusplus
++extern "C" {
++#endif
++
++typedef enum {
++    PIN_INPUT  = 0, /* MXC_V_GPIO_OUT_MODE_HIGH_Z,*/
++    PIN_OUTPUT = 1  /* MXC_V_GPIO_OUT_MODE_NORMAL_DRIVE */
++} PinDirection;
++
++#define PORT_SHIFT  12
++#define PINNAME_TO_PORT(name)   ((unsigned int)(name) >> PORT_SHIFT)
++#define PINNAME_TO_PIN(name)    ((unsigned int)(name) & ~(0xFFFFFFFF << PORT_SHIFT))
++
++#define NOT_CONNECTED (int)0xFFFFFFFF
++
++typedef enum {
++    P0_0 = (0 << PORT_SHIFT), P0_1, P0_2, P0_3, P0_4, P0_5, P0_6, P0_7,
++    P1_0 = (1 << PORT_SHIFT), P1_1, P1_2, P1_3, P1_4, P1_5, P1_6, P1_7,
++    P2_0 = (2 << PORT_SHIFT), P2_1, P2_2, P2_3, P2_4, P2_5, P2_6, P2_7,
++    P3_0 = (3 << PORT_SHIFT), P3_1, P3_2, P3_3, P3_4, P3_5, P3_6, P3_7,
++    P4_0 = (4 << PORT_SHIFT), P4_1, P4_2, P4_3, P4_4, P4_5, P4_6, P4_7,
++
++    // Analog input pins
++    AIN_0 = (0xA << PORT_SHIFT), AIN_1, AIN_2, AIN_3, AIN_4, AIN_5, AIN_6, AIN_7, AIN_8, AIN_9,
++
++    // LEDs
++    LED1 = P2_4,
++    LED2 = P2_5,
++    LED3 = P2_6,
++    LED_RED = LED1,
++    LED_GREEN = LED2,
++    LED_BLUE = LED3,
++
++    // Push button
++    SW1 = P2_7,
++
++    // USB bridge connected UART pins
++    USBTX = P2_1,
++    USBRX = P2_0,
++    STDIO_UART_TX = USBTX,
++    STDIO_UART_RX = USBRX,
++
++    // I2C pins
++    I2C0_SCL = P1_7,
++    I2C0_SDA = P1_6,
++
++    I2C1_SCL = P3_5,
++    I2C1_SDA = P3_4,
++
++    // UART pins
++    UART0_RX  = P0_0,
++    UART0_TX  = P0_1,
++    UART0_CTS = P0_2,
++    UART0_RTS = P0_3,
++
++    UART1_RX  = P2_0,
++    UART1_TX  = P2_1,
++
++    UART2_RX  = P3_0,
++    UART2_TX  = P3_1,
++    UART2_CTS = P3_2,
++    UART2_RTS = P3_3,
++
++    // SPI pins
++    SPI0_SCK  = P0_4,
++    SPI0_MOSI = P0_5,
++    SPI0_MISO = P0_6,
++    SPI0_SS   = P0_7,
++
++    SPI1_SCK  = P1_0,
++    SPI1_MOSI = P1_1,
++    SPI1_MISO = P1_2,
++    SPI1_SS   = P1_3,
++
++    SPI2_SCK  = P2_4,
++    SPI2_MOSI = P2_5,
++    SPI2_MISO = P2_6,
++    SPI2_SS   = P2_7,
++
++    // Not connected
++    NC = NOT_CONNECTED
++} PinName;
++
++typedef enum {
++    PullUp,
++    PullDown,
++    OpenDrain,
++    PullNone,
++    PullDefault = PullUp
++} PinMode;
++
++typedef enum {
++    LED_ON = 0,
++    LED_OFF = 1
++} LedStates;
++
++#ifdef __cplusplus
++}
++#endif
++
++#endif
+diff --git a/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/low_level_init.c b/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/low_level_init.c
+new file mode 100644
+index 000000000..1c56f9891
+--- /dev/null
++++ b/targets/TARGET_Maxim/TARGET_MAX32625/TARGET_MAX32625PICO/low_level_init.c
+@@ -0,0 +1,56 @@
++/*******************************************************************************
++ * Copyright (C) 2017 Maxim Integrated Products, Inc., All Rights Reserved.
++ *
++ * Permission is hereby granted, free of charge, to any person obtaining a
++ * copy of this software and associated documentation files (the "Software"),
++ * to deal in the Software without restriction, including without limitation
++ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
++ * and/or sell copies of the Software, and to permit persons to whom the
++ * Software is furnished to do so, subject to the following conditions:
++ *
++ * The above copyright notice and this permission notice shall be included
++ * in all copies or substantial portions of the Software.
++ *
++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
++ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
++ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
++ * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
++ * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
++ * OTHER DEALINGS IN THE SOFTWARE.
++ *
++ * Except as contained in this notice, the name of Maxim Integrated
++ * Products, Inc. shall not be used except as stated in the Maxim Integrated
++ * Products, Inc. Branding Policy.
++ *
++ * The mere transfer of this software does not imply any licenses
++ * of trade secrets, proprietary technology, copyrights, patents,
++ * trademarks, maskwork rights, or any other form of intellectual
++ * property whatsoever. Maxim Integrated Products, Inc. retains all
++ * ownership rights.
++ *******************************************************************************
++ */
++ 
++#include "cmsis.h"
++#include "ioman_regs.h"
++#include "gpio_regs.h"
++ 
++//******************************************************************************
++// This function will get called early in system initialization
++void low_level_init(void)
++{
++    /* The MAX32625PICO board utilizes a bootloader that can leave some 
++     * peripherals in a partially configured state.  This function resets
++     * those to allow proper initialization.
++     */
++    MXC_IOMAN->uart0_req = 0x0;         // Clear any requests
++    MXC_IOMAN->uart1_req = 0x0;         // Clear any requests
++
++    MXC_GPIO->inten[2] = 0x0;           // Clear interrupt enable
++    MXC_GPIO->int_mode[2] = 0x0;        // Clear interrupt mode
++    MXC_GPIO->in_mode[2] = 0x22222222;  // Clear input mode
++    MXC_GPIO->out_val[2] = 0x0;  // Clear output value
++    MXC_GPIO->out_mode[2] = 0xFFFFFFFF;  // Clear output mode
++    
++
++}
+diff --git a/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_ARM_STD/TARGET_MAX32625PICO/MAX32625.sct b/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_ARM_STD/TARGET_MAX32625PICO/MAX32625.sct
+new file mode 100644
+index 000000000..6ea0cb73b
+--- /dev/null
++++ b/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_ARM_STD/TARGET_MAX32625PICO/MAX32625.sct
+@@ -0,0 +1,16 @@
++; MAX32625
++; 512KB FLASH (0x70000) @ 0x000010000
++; 160KB RAM (0x24F00) @ 0x20003100
++
++LR_IROM1 0x000010000 0x70000  {    ; load region size_region
++    ER_IROM1 0x000010000 0x70000  {  ; load address = execution address 
++        *.o (RESET, +First)
++        *(InRoot$$Sections)
++        .ANY (+RO)
++    }
++
++    ; [RAM] Vector table dynamic copy: 68 vectors * 4 bytes = 272 (0x110)
++    RW_IRAM1 (0x20003100+0x110) (0x24F00-0x110)  {  ; RW data
++        .ANY (+RW +ZI)
++    }
++}
+diff --git a/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_GCC_ARM/TARGET_MAX32625PICO/max32625.ld b/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_GCC_ARM/TARGET_MAX32625PICO/max32625.ld
+new file mode 100644
+index 000000000..f51f007f1
+--- /dev/null
++++ b/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_GCC_ARM/TARGET_MAX32625PICO/max32625.ld
+@@ -0,0 +1,176 @@
++/*******************************************************************************
++ * Copyright (C) 2016 Maxim Integrated Products, Inc., All Rights Reserved.
++ *
++ * Permission is hereby granted, free of charge, to any person obtaining a
++ * copy of this software and associated documentation files (the "Software"),
++ * to deal in the Software without restriction, including without limitation
++ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
++ * and/or sell copies of the Software, and to permit persons to whom the
++ * Software is furnished to do so, subject to the following conditions:
++ *
++ * The above copyright notice and this permission notice shall be included
++ * in all copies or substantial portions of the Software.
++ *
++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
++ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
++ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
++ * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
++ * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
++ * OTHER DEALINGS IN THE SOFTWARE.
++ *
++ * Except as contained in this notice, the name of Maxim Integrated
++ * Products, Inc. shall not be used except as stated in the Maxim Integrated
++ * Products, Inc. Branding Policy.
++ *
++ * The mere transfer of this software does not imply any licenses
++ * of trade secrets, proprietary technology, copyrights, patents,
++ * trademarks, maskwork rights, or any other form of intellectual
++ * property whatsoever. Maxim Integrated Products, Inc. retains all
++ * ownership rights.
++ *******************************************************************************
++ */
++
++MEMORY
++{
++    FLASH (rx) : ORIGIN = 0x00010000, LENGTH = 0x00070000
++    RAM  (rwx) : ORIGIN = 0x20003100, LENGTH = 0x00024F00
++}
++
++/* Linker script to place sections and symbol values. Should be used together
++ * with other linker script that defines memory regions FLASH and RAM.
++ * It references following symbols, which must be defined in code:
++ *   Reset_Handler : Entry of reset handler
++ * 
++ * It defines following symbols, which code can use without definition:
++ *   __exidx_start
++ *   __exidx_end
++ *   __etext
++ *   __data_start__
++ *   __preinit_array_start
++ *   __preinit_array_end
++ *   __init_array_start
++ *   __init_array_end
++ *   __fini_array_start
++ *   __fini_array_end
++ *   __data_end__
++ *   __bss_start__
++ *   __bss_end__
++ *   __end__
++ *   end
++ *   __HeapLimit
++ *   __StackLimit
++ *   __StackTop
++ *   __stack
++ */
++ENTRY(Reset_Handler)
++
++SECTIONS
++{
++    .text :
++    {
++        KEEP(*(.isr_vector))
++        *(.text*)
++
++        KEEP(*(.init))
++        KEEP(*(.fini))
++
++        /* .ctors */
++        *crtbegin.o(.ctors)
++        *crtbegin?.o(.ctors)
++        *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
++        *(SORT(.ctors.*))
++        *(.ctors)
++
++        /* .dtors */
++        *crtbegin.o(.dtors)
++        *crtbegin?.o(.dtors)
++        *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
++        *(SORT(.dtors.*))
++        *(.dtors)
++
++        *(.rodata*)
++
++        KEEP(*(.eh_frame*))
++    } > FLASH
++
++    .ARM.extab :
++    {
++        *(.ARM.extab* .gnu.linkonce.armextab.*)
++    } > FLASH
++
++    __exidx_start = .;
++    .ARM.exidx :
++    {
++        *(.ARM.exidx* .gnu.linkonce.armexidx.*)
++    } > FLASH
++    __exidx_end = .;
++
++    __etext = .;
++
++    .data : AT (__etext)
++    {
++        __data_start__ = .;
++        *(vtable)
++        *(.data*)
++
++        . = ALIGN(4);
++        /* preinit data */
++        PROVIDE_HIDDEN (__preinit_array_start = .);
++        KEEP(*(.preinit_array))
++        PROVIDE_HIDDEN (__preinit_array_end = .);
++
++        . = ALIGN(4);
++        /* init data */
++        PROVIDE_HIDDEN (__init_array_start = .);
++        KEEP(*(SORT(.init_array.*)))
++        KEEP(*(.init_array))
++        PROVIDE_HIDDEN (__init_array_end = .);
++
++
++        . = ALIGN(4);
++        /* finit data */
++        PROVIDE_HIDDEN (__fini_array_start = .);
++        KEEP(*(SORT(.fini_array.*)))
++        KEEP(*(.fini_array))
++        PROVIDE_HIDDEN (__fini_array_end = .);
++
++        . = ALIGN(4);
++        /* All data end */
++        __data_end__ = .;
++
++    } > RAM
++
++    .bss :
++    {
++        __bss_start__ = .;
++        *(.bss*)
++        *(COMMON)
++        __bss_end__ = .;
++    } > RAM
++
++    .heap :
++    {
++        __end__ = .;
++        end = __end__;
++        *(.heap*)
++        __HeapLimit = .;
++    } > RAM
++
++    /* .stack_dummy section doesn't contains any symbols. It is only
++     * used for linker to calculate size of stack sections, and assign
++     * values to stack symbols later */
++    .stack_dummy :
++    {
++        *(.stack)
++    } > RAM
++
++    /* Set stack top to end of RAM, and stack limit move down by
++     * size of stack_dummy section */
++    __StackTop = ORIGIN(RAM) + LENGTH(RAM);
++    __StackLimit = __StackTop - SIZEOF(.stack_dummy);
++    PROVIDE(__stack = __StackTop);
++
++    /* Check if data + heap + stack exceeds RAM limit */
++    ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack")
++}
+diff --git a/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_IAR/TARGET_MAX32625PICO/MAX32625.icf b/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_IAR/TARGET_MAX32625PICO/MAX32625.icf
+new file mode 100644
+index 000000000..bba1c8067
+--- /dev/null
++++ b/targets/TARGET_Maxim/TARGET_MAX32625/device/TOOLCHAIN_IAR/TARGET_MAX32625PICO/MAX32625.icf
+@@ -0,0 +1,29 @@
++/* [ROM] */
++define symbol __intvec_start__        = 0x00010000;
++define symbol __region_ROM_start__    = 0x00010000;
++define symbol __region_ROM_end__      = 0x0007FFFF;
++
++/* [RAM] Vector table dynamic copy: 68 vectors * 4 bytes = 272 (0x110) bytes */
++define symbol __NVIC_start__          = 0x00010000;
++define symbol __NVIC_end__            = 0x00010110; /* to be aligned on 8 bytes */
++define symbol __region_RAM_start__    = 0x20003100;
++define symbol __region_RAM_end__      = 0x20027FFF;
++
++/* Memory regions */
++define memory mem with size = 4G;
++define region ROM_region      = mem:[from __region_ROM_start__   to __region_ROM_end__];
++define region RAM_region      = mem:[from __region_RAM_start__   to __region_RAM_end__];
++
++/* Stack and Heap */
++define symbol __size_cstack__ = 0x5000;
++define symbol __size_heap__   = 0xA000;
++define block CSTACK    with alignment = 8, size = __size_cstack__   { };
++define block HEAP      with alignment = 8, size = __size_heap__     { };
++
++initialize by copy { readwrite };
++do not initialize  { section .noinit };
++
++place at address mem:__intvec_start__ { readonly section .intvec };
++place in ROM_region   { readonly };
++place in RAM_region   { readwrite,
++                        block CSTACK, block HEAP };
+diff --git a/targets/TARGET_Maxim/TARGET_MAX32625/device/system_max32625.c b/targets/TARGET_Maxim/TARGET_MAX32625/device/system_max32625.c
+index 4f77b2116..bba36bb5c 100644
+--- a/targets/TARGET_Maxim/TARGET_MAX32625/device/system_max32625.c
++++ b/targets/TARGET_Maxim/TARGET_MAX32625/device/system_max32625.c
+@@ -171,6 +171,10 @@ __weak int PreInit(void)
+     return 0;
+ }
+ 
++/* Override this function for early platform initialization
++*/
++__weak void low_level_init(void) {}
++
+ /* This function is called just before control is transferred to main().
+  */
+ void SystemInit(void)
+@@ -258,6 +262,9 @@ void SystemInit(void)
+     __ISB();
+ #endif
+ 
++    /* Early platform initialization */
++    low_level_init();
++
+     /* Perform an initial trim of the internal ring oscillator */
+     CLKMAN_TrimRO();
+ }
+diff --git a/targets/targets.json b/targets/targets.json
+index ee38b950b..12d5cf61b 100644
+--- a/targets/targets.json
++++ b/targets/targets.json
+@@ -1904,6 +1904,15 @@
+         "device_has": ["ANALOGIN", "ERROR_RED", "I2C", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_FC", "SLEEP", "SPI", "STDIO_MESSAGES"],
+         "release_versions": ["2", "5"]
+     },
++	"MAX32625PICO": {
++        "inherits": ["Target"],
++        "core": "Cortex-M4F",
++        "macros": ["__SYSTEM_HFX=96000000","TARGET=MAX32625","TARGET_REV=0x4132"],
++        "extra_labels": ["Maxim", "MAX32625"],
++        "supported_toolchains": ["GCC_ARM", "IAR", "ARM"],
++        "device_has": ["ANALOGIN", "ERROR_RED", "I2C", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_FC", "SLEEP", "SPI", "STDIO_MESSAGES"],
++        "release_versions": ["2", "5"]
++    },
+     "MAX32630FTHR": {
+         "inherits": ["Target"],
+         "core": "Cortex-M4F",
+-- 
+2.11.1.windows.1
+