The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
<>
Date:
Thu Nov 24 11:01:25 2016 +0000
Revision:
130:d75b3fe1f5cb
Parent:
123:b0220dba8be7
Child:
138:093f2bd7b9eb
Release 130 of the mbed library

Ports for Upcoming Targets


Fixes and Changes

3127: Fixed the issue about push/pop of VFP register. https://github.com/ARMmbed/mbed-os/pull/3127
3176: Modifying micro:bit pin names to mirror micro:bit edge connector https://github.com/ARMmbed/mbed-os/pull/3176
3160: Fix wrong index at LPC43xx tx end ring assignment https://github.com/ARMmbed/mbed-os/pull/3160
3217: Add I2C_ASYNCH capability for DISCO_F469NI https://github.com/ARMmbed/mbed-os/pull/3217
3211: [NUC472/M453] Support single UART shared by multiple serial objects and other updates https://github.com/ARMmbed/mbed-os/pull/3211
3198: NUCLEO_F410RB: Add I2C_ASYNCH capability https://github.com/ARMmbed/mbed-os/pull/3198
3194: Update K64 sdk drivers https://github.com/ARMmbed/mbed-os/pull/3194
3159: User trim values for NCS36510 https://github.com/ARMmbed/mbed-os/pull/3159
3243: Fix make exporters compilation https://github.com/ARMmbed/mbed-os/pull/3243
3231: STM32F3: DISCO_F303VC - Add missing UART and ADC pin muxing options https://github.com/ARMmbed/mbed-os/pull/3231
3233: K20xx Calculate PWM clock relative to bus clock https://github.com/ARMmbed/mbed-os/pull/3233
3237: Added back USART 6 pins https://github.com/ARMmbed/mbed-os/pull/3237
3253: Fix default polarity on LPC43XX PWM driver https://github.com/ARMmbed/mbed-os/pull/3253
3238: Dev i2c stm32f4hal https://github.com/ARMmbed/mbed-os/pull/3238
3251: Dev stm32l0 cube v1.7.0 https://github.com/ARMmbed/mbed-os/pull/3251
3252: [NORDIC - NRF51 - MBED 2] Fix non handled RTC IRQ https://github.com/ARMmbed/mbed-os/pull/3252

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Kojto 123:b0220dba8be7 1 /*
Kojto 123:b0220dba8be7 2 ** ###################################################################
<> 130:d75b3fe1f5cb 3 ** Processors: MK64FN1M0CAJ12
<> 130:d75b3fe1f5cb 4 ** MK64FN1M0VDC12
Kojto 123:b0220dba8be7 5 ** MK64FN1M0VLL12
Kojto 123:b0220dba8be7 6 ** MK64FN1M0VLQ12
Kojto 123:b0220dba8be7 7 ** MK64FN1M0VMD12
Kojto 123:b0220dba8be7 8 **
Kojto 123:b0220dba8be7 9 ** Compiler: IAR ANSI C/C++ Compiler for ARM
Kojto 123:b0220dba8be7 10 ** Reference manual: K64P144M120SF5RM, Rev.2, January 2014
<> 130:d75b3fe1f5cb 11 ** Version: rev. 2.9, 2016-03-21
<> 130:d75b3fe1f5cb 12 ** Build: b160406
Kojto 123:b0220dba8be7 13 **
Kojto 123:b0220dba8be7 14 ** Abstract:
Kojto 123:b0220dba8be7 15 ** Linker file for the IAR ANSI C/C++ Compiler for ARM
Kojto 123:b0220dba8be7 16 **
<> 130:d75b3fe1f5cb 17 ** Copyright (c) 2016 Freescale Semiconductor, Inc.
Kojto 123:b0220dba8be7 18 ** All rights reserved.
Kojto 123:b0220dba8be7 19 **
Kojto 123:b0220dba8be7 20 ** Redistribution and use in source and binary forms, with or without modification,
Kojto 123:b0220dba8be7 21 ** are permitted provided that the following conditions are met:
Kojto 123:b0220dba8be7 22 **
Kojto 123:b0220dba8be7 23 ** o Redistributions of source code must retain the above copyright notice, this list
Kojto 123:b0220dba8be7 24 ** of conditions and the following disclaimer.
Kojto 123:b0220dba8be7 25 **
Kojto 123:b0220dba8be7 26 ** o Redistributions in binary form must reproduce the above copyright notice, this
Kojto 123:b0220dba8be7 27 ** list of conditions and the following disclaimer in the documentation and/or
Kojto 123:b0220dba8be7 28 ** other materials provided with the distribution.
Kojto 123:b0220dba8be7 29 **
Kojto 123:b0220dba8be7 30 ** o Neither the name of Freescale Semiconductor, Inc. nor the names of its
Kojto 123:b0220dba8be7 31 ** contributors may be used to endorse or promote products derived from this
Kojto 123:b0220dba8be7 32 ** software without specific prior written permission.
Kojto 123:b0220dba8be7 33 **
Kojto 123:b0220dba8be7 34 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
Kojto 123:b0220dba8be7 35 ** ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
Kojto 123:b0220dba8be7 36 ** WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Kojto 123:b0220dba8be7 37 ** DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
Kojto 123:b0220dba8be7 38 ** ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
Kojto 123:b0220dba8be7 39 ** (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
Kojto 123:b0220dba8be7 40 ** LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
Kojto 123:b0220dba8be7 41 ** ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Kojto 123:b0220dba8be7 42 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
Kojto 123:b0220dba8be7 43 ** SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Kojto 123:b0220dba8be7 44 **
Kojto 123:b0220dba8be7 45 ** http: www.freescale.com
Kojto 123:b0220dba8be7 46 ** mail: support@freescale.com
Kojto 123:b0220dba8be7 47 **
Kojto 123:b0220dba8be7 48 ** ###################################################################
Kojto 123:b0220dba8be7 49 */
Kojto 123:b0220dba8be7 50 define symbol __ram_vector_table__ = 1;
Kojto 123:b0220dba8be7 51
Kojto 123:b0220dba8be7 52 /* Heap 1/4 of ram and stack 1/8 */
Kojto 123:b0220dba8be7 53 define symbol __stack_size__=0x8000;
Kojto 123:b0220dba8be7 54 define symbol __heap_size__=0x10000;
Kojto 123:b0220dba8be7 55
Kojto 123:b0220dba8be7 56 define symbol __ram_vector_table_size__ = isdefinedsymbol(__ram_vector_table__) ? 0x00000400 : 0;
Kojto 123:b0220dba8be7 57 define symbol __ram_vector_table_offset__ = isdefinedsymbol(__ram_vector_table__) ? 0x000003FF : 0;
Kojto 123:b0220dba8be7 58
Kojto 123:b0220dba8be7 59 define symbol m_interrupts_start = 0x00000000;
Kojto 123:b0220dba8be7 60 define symbol m_interrupts_end = 0x000003FF;
Kojto 123:b0220dba8be7 61
Kojto 123:b0220dba8be7 62 define symbol m_flash_config_start = 0x00000400;
Kojto 123:b0220dba8be7 63 define symbol m_flash_config_end = 0x0000040F;
Kojto 123:b0220dba8be7 64
Kojto 123:b0220dba8be7 65 define symbol m_text_start = 0x00000410;
Kojto 123:b0220dba8be7 66 define symbol m_text_end = 0x000FFFFF;
Kojto 123:b0220dba8be7 67
Kojto 123:b0220dba8be7 68 define symbol m_interrupts_ram_start = 0x1FFF0000;
Kojto 123:b0220dba8be7 69 define symbol m_interrupts_ram_end = 0x1FFF0000 + __ram_vector_table_offset__;
Kojto 123:b0220dba8be7 70
Kojto 123:b0220dba8be7 71 define symbol m_data_start = m_interrupts_ram_start + __ram_vector_table_size__;
Kojto 123:b0220dba8be7 72 define symbol m_data_end = 0x1FFFFFFF;
Kojto 123:b0220dba8be7 73
Kojto 123:b0220dba8be7 74 define symbol m_data_2_start = 0x20000000;
Kojto 123:b0220dba8be7 75 define symbol m_data_2_end = 0x2002FFFF;
Kojto 123:b0220dba8be7 76
Kojto 123:b0220dba8be7 77 /* Sizes */
Kojto 123:b0220dba8be7 78 if (isdefinedsymbol(__stack_size__)) {
Kojto 123:b0220dba8be7 79 define symbol __size_cstack__ = __stack_size__;
Kojto 123:b0220dba8be7 80 } else {
Kojto 123:b0220dba8be7 81 define symbol __size_cstack__ = 0x0400;
Kojto 123:b0220dba8be7 82 }
Kojto 123:b0220dba8be7 83
Kojto 123:b0220dba8be7 84 if (isdefinedsymbol(__heap_size__)) {
Kojto 123:b0220dba8be7 85 define symbol __size_heap__ = __heap_size__;
Kojto 123:b0220dba8be7 86 } else {
Kojto 123:b0220dba8be7 87 define symbol __size_heap__ = 0x0400;
Kojto 123:b0220dba8be7 88 }
Kojto 123:b0220dba8be7 89
Kojto 123:b0220dba8be7 90 define exported symbol __VECTOR_TABLE = m_interrupts_start;
Kojto 123:b0220dba8be7 91 define exported symbol __VECTOR_RAM = isdefinedsymbol(__ram_vector_table__) ? m_interrupts_ram_start : m_interrupts_start;
Kojto 123:b0220dba8be7 92 define exported symbol __RAM_VECTOR_TABLE_SIZE = __ram_vector_table_size__;
Kojto 123:b0220dba8be7 93
Kojto 123:b0220dba8be7 94 define memory mem with size = 4G;
Kojto 123:b0220dba8be7 95 define region m_flash_config_region = mem:[from m_flash_config_start to m_flash_config_end];
Kojto 123:b0220dba8be7 96 define region TEXT_region = mem:[from m_interrupts_start to m_interrupts_end]
Kojto 123:b0220dba8be7 97 | mem:[from m_text_start to m_text_end];
Kojto 123:b0220dba8be7 98 define region DATA_region = mem:[from m_data_start to m_data_end]
Kojto 123:b0220dba8be7 99 | mem:[from m_data_2_start to m_data_2_end-__size_cstack__];
Kojto 123:b0220dba8be7 100 define region CSTACK_region = mem:[from m_data_2_end-__size_cstack__+1 to m_data_2_end];
Kojto 123:b0220dba8be7 101 define region m_interrupts_ram_region = mem:[from m_interrupts_ram_start to m_interrupts_ram_end];
Kojto 123:b0220dba8be7 102
Kojto 123:b0220dba8be7 103 define block CSTACK with alignment = 8, size = __size_cstack__ { };
Kojto 123:b0220dba8be7 104 define block HEAP with alignment = 8, size = __size_heap__ { };
Kojto 123:b0220dba8be7 105 define block RW { readwrite };
Kojto 123:b0220dba8be7 106 define block ZI { zi };
Kojto 123:b0220dba8be7 107
Kojto 123:b0220dba8be7 108 initialize by copy { readwrite, section .textrw };
Kojto 123:b0220dba8be7 109 do not initialize { section .noinit };
Kojto 123:b0220dba8be7 110
Kojto 123:b0220dba8be7 111 place at address mem: m_interrupts_start { readonly section .intvec };
Kojto 123:b0220dba8be7 112 place in m_flash_config_region { section FlashConfig };
Kojto 123:b0220dba8be7 113 place in TEXT_region { readonly };
Kojto 123:b0220dba8be7 114 place in DATA_region { block RW };
Kojto 123:b0220dba8be7 115 place in DATA_region { block ZI };
Kojto 123:b0220dba8be7 116 place in DATA_region { last block HEAP };
Kojto 123:b0220dba8be7 117 place in CSTACK_region { block CSTACK };
Kojto 123:b0220dba8be7 118 place in m_interrupts_ram_region { section m_interrupts_ram };
Kojto 123:b0220dba8be7 119