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:
Anna Bridge
Date:
Fri Apr 20 11:08:29 2018 +0100
Revision:
166:5aab5a7997ee
Parent:
163:e59c8e839560
Child:
170:e95d10626187
Updating mbed 2 version number

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 163:e59c8e839560 1 #! armcc -E
AnnaBridge 163:e59c8e839560 2 /*
AnnaBridge 163:e59c8e839560 3 ** ###################################################################
AnnaBridge 163:e59c8e839560 4 ** Processor: LPC54628J512ET180
AnnaBridge 163:e59c8e839560 5 ** Compiler: Keil ARM C/C++ Compiler
AnnaBridge 163:e59c8e839560 6 ** Reference manual: LPC546xx User manual Rev.1.9 5 June 2017
AnnaBridge 163:e59c8e839560 7 ** Version: rev. 1.2, 2017-06-08
AnnaBridge 163:e59c8e839560 8 ** Build: b170821
AnnaBridge 163:e59c8e839560 9 **
AnnaBridge 163:e59c8e839560 10 ** Abstract:
AnnaBridge 163:e59c8e839560 11 ** Linker file for the Keil ARM C/C++ Compiler
AnnaBridge 163:e59c8e839560 12 **
AnnaBridge 163:e59c8e839560 13 ** Copyright 2016 Freescale Semiconductor, Inc.
AnnaBridge 163:e59c8e839560 14 ** Copyright 2016-2017 NXP
AnnaBridge 163:e59c8e839560 15 ** Redistribution and use in source and binary forms, with or without modification,
AnnaBridge 163:e59c8e839560 16 ** are permitted provided that the following conditions are met:
AnnaBridge 163:e59c8e839560 17 **
AnnaBridge 163:e59c8e839560 18 ** 1. Redistributions of source code must retain the above copyright notice, this list
AnnaBridge 163:e59c8e839560 19 ** of conditions and the following disclaimer.
AnnaBridge 163:e59c8e839560 20 **
AnnaBridge 163:e59c8e839560 21 ** 2. Redistributions in binary form must reproduce the above copyright notice, this
AnnaBridge 163:e59c8e839560 22 ** list of conditions and the following disclaimer in the documentation and/or
AnnaBridge 163:e59c8e839560 23 ** other materials provided with the distribution.
AnnaBridge 163:e59c8e839560 24 **
AnnaBridge 163:e59c8e839560 25 ** 3. Neither the name of the copyright holder nor the names of its
AnnaBridge 163:e59c8e839560 26 ** contributors may be used to endorse or promote products derived from this
AnnaBridge 163:e59c8e839560 27 ** software without specific prior written permission.
AnnaBridge 163:e59c8e839560 28 **
AnnaBridge 163:e59c8e839560 29 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
AnnaBridge 163:e59c8e839560 30 ** ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
AnnaBridge 163:e59c8e839560 31 ** WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
AnnaBridge 163:e59c8e839560 32 ** DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
AnnaBridge 163:e59c8e839560 33 ** ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
AnnaBridge 163:e59c8e839560 34 ** (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
AnnaBridge 163:e59c8e839560 35 ** LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
AnnaBridge 163:e59c8e839560 36 ** ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
AnnaBridge 163:e59c8e839560 37 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
AnnaBridge 163:e59c8e839560 38 ** SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
AnnaBridge 163:e59c8e839560 39 **
AnnaBridge 163:e59c8e839560 40 ** http: www.nxp.com
AnnaBridge 163:e59c8e839560 41 ** mail: support@nxp.com
AnnaBridge 163:e59c8e839560 42 **
AnnaBridge 163:e59c8e839560 43 ** ###################################################################
AnnaBridge 163:e59c8e839560 44 */
AnnaBridge 163:e59c8e839560 45 #define __ram_vector_table__ 1
AnnaBridge 163:e59c8e839560 46
AnnaBridge 163:e59c8e839560 47 #if (defined(__ram_vector_table__))
AnnaBridge 163:e59c8e839560 48 #define __ram_vector_table_size__ 0x00000400
AnnaBridge 163:e59c8e839560 49 #else
AnnaBridge 163:e59c8e839560 50 #define __ram_vector_table_size__ 0x00000000
AnnaBridge 163:e59c8e839560 51 #endif
AnnaBridge 163:e59c8e839560 52
AnnaBridge 163:e59c8e839560 53 #define m_interrupts_start 0x00000000
AnnaBridge 163:e59c8e839560 54 #define m_interrupts_size 0x00000400
AnnaBridge 163:e59c8e839560 55
AnnaBridge 163:e59c8e839560 56 #define m_text_start 0x00000400
AnnaBridge 163:e59c8e839560 57 #define m_text_size 0x0007FC00
AnnaBridge 163:e59c8e839560 58
AnnaBridge 163:e59c8e839560 59 #define m_interrupts_ram_start 0x20000000
AnnaBridge 163:e59c8e839560 60 #define m_interrupts_ram_size __ram_vector_table_size__
AnnaBridge 163:e59c8e839560 61
AnnaBridge 163:e59c8e839560 62 #define m_data_start (m_interrupts_ram_start + m_interrupts_ram_size)
AnnaBridge 163:e59c8e839560 63 #define m_data_size (0x00028000 - m_interrupts_ram_size)
AnnaBridge 163:e59c8e839560 64
AnnaBridge 163:e59c8e839560 65 #define m_usb_sram_start 0x40100000
AnnaBridge 163:e59c8e839560 66 #define m_usb_sram_size 0x00002000
AnnaBridge 163:e59c8e839560 67
AnnaBridge 163:e59c8e839560 68 /* USB BDT size */
AnnaBridge 163:e59c8e839560 69 #define usb_bdt_size 0x0
AnnaBridge 163:e59c8e839560 70 /* Sizes */
AnnaBridge 163:e59c8e839560 71 #if (defined(__stack_size__))
AnnaBridge 163:e59c8e839560 72 #define Stack_Size __stack_size__
AnnaBridge 163:e59c8e839560 73 #else
AnnaBridge 163:e59c8e839560 74 #define Stack_Size 0x0400
AnnaBridge 163:e59c8e839560 75 #endif
AnnaBridge 163:e59c8e839560 76
AnnaBridge 163:e59c8e839560 77 #if (defined(__heap_size__))
AnnaBridge 163:e59c8e839560 78 #define Heap_Size __heap_size__
AnnaBridge 163:e59c8e839560 79 #else
AnnaBridge 163:e59c8e839560 80 #define Heap_Size 0x0400
AnnaBridge 163:e59c8e839560 81 #endif
AnnaBridge 163:e59c8e839560 82
AnnaBridge 163:e59c8e839560 83 LR_m_text m_interrupts_start m_text_start+m_text_size-m_interrupts_start { ; load region size_region
AnnaBridge 163:e59c8e839560 84 VECTOR_ROM m_interrupts_start m_interrupts_size { ; load address = execution address
AnnaBridge 163:e59c8e839560 85 * (RESET,+FIRST)
AnnaBridge 163:e59c8e839560 86 }
AnnaBridge 163:e59c8e839560 87 ER_m_text m_text_start FIXED m_text_size { ; load address = execution address
AnnaBridge 163:e59c8e839560 88 * (InRoot$$Sections)
AnnaBridge 163:e59c8e839560 89 .ANY (+RO)
AnnaBridge 163:e59c8e839560 90 }
AnnaBridge 163:e59c8e839560 91
AnnaBridge 163:e59c8e839560 92 #if (defined(__ram_vector_table__))
AnnaBridge 163:e59c8e839560 93 VECTOR_RAM m_interrupts_ram_start EMPTY m_interrupts_ram_size {
AnnaBridge 163:e59c8e839560 94 }
AnnaBridge 163:e59c8e839560 95 #else
AnnaBridge 163:e59c8e839560 96 VECTOR_RAM m_interrupts_start EMPTY 0 {
AnnaBridge 163:e59c8e839560 97 }
AnnaBridge 163:e59c8e839560 98 #endif
AnnaBridge 163:e59c8e839560 99 RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size { ; RW data
AnnaBridge 163:e59c8e839560 100 .ANY (+RW +ZI)
AnnaBridge 163:e59c8e839560 101 }
AnnaBridge 163:e59c8e839560 102 RW_IRAM1 +0 EMPTY Heap_Size { ; Heap region growing up
AnnaBridge 163:e59c8e839560 103 }
AnnaBridge 163:e59c8e839560 104 ARM_LIB_STACK m_data_start+m_data_size EMPTY -Stack_Size { ; Stack region growing down
AnnaBridge 163:e59c8e839560 105 }
AnnaBridge 163:e59c8e839560 106 }
AnnaBridge 163:e59c8e839560 107
AnnaBridge 163:e59c8e839560 108 LR_m_usb_bdt m_usb_sram_start usb_bdt_size {
AnnaBridge 163:e59c8e839560 109 ER_m_usb_bdt m_usb_sram_start UNINIT usb_bdt_size {
AnnaBridge 163:e59c8e839560 110 * (m_usb_bdt)
AnnaBridge 163:e59c8e839560 111 }
AnnaBridge 163:e59c8e839560 112 }
AnnaBridge 163:e59c8e839560 113
AnnaBridge 163:e59c8e839560 114 LR_m_usb_ram (m_usb_sram_start + usb_bdt_size) (m_usb_sram_size - usb_bdt_size) {
AnnaBridge 163:e59c8e839560 115 ER_m_usb_ram (m_usb_sram_start + usb_bdt_size) UNINIT (m_usb_sram_size - usb_bdt_size) {
AnnaBridge 163:e59c8e839560 116 * (m_usb_global)
AnnaBridge 163:e59c8e839560 117 }
AnnaBridge 163:e59c8e839560 118 }
AnnaBridge 163:e59c8e839560 119