]> git.donarmstrong.com Git - kiibohd-controller.git/blob - Lib/mk20dx256vlh7.bootloader.ld
Basic code for mk20dx256vlh7 flashing
[kiibohd-controller.git] / Lib / mk20dx256vlh7.bootloader.ld
1 /* Teensyduino Core Library
2  * http://www.pjrc.com/teensy/
3  * Copyright (c) 2013 PJRC.COM, LLC.
4  * Modifications by Jacob Alexander 2014-2015 for use with McHCK and Kiibohd-dfu
5  *
6  * Permission is hereby granted, free of charge, to any person obtaining
7  * a copy of this software and associated documentation files (the
8  * "Software"), to deal in the Software without restriction, including
9  * without limitation the rights to use, copy, modify, merge, publish,
10  * distribute, sublicense, and/or sell copies of the Software, and to
11  * permit persons to whom the Software is furnished to do so, subject to
12  * the following conditions:
13  *
14  * 1. The above copyright notice and this permission notice shall be
15  * included in all copies or substantial portions of the Software.
16  *
17  * 2. If the Software is incorporated into a build system that allows
18  * selection among a list of target devices, then similar target
19  * devices manufactured by PJRC.COM must be included in the list of
20  * target devices and selectable in the same manner.
21  *
22  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
23  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
25  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
26  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
27  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
28  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
29  * SOFTWARE.
30  */
31
32 MEMORY
33 {
34         FLASH (rx)     : ORIGIN = 0x0, LENGTH = 256K
35         FLASH_APP (rx) : ORIGIN = 8K, LENGTH = 256K-8K
36         RAM  (rwx)     : ORIGIN = 0x20000000 - 64K / 2, LENGTH = 64K
37 }
38
39 /* Starting Address of the application ROM */
40 _bootloader = ORIGIN( FLASH );
41 _app_rom = ORIGIN( FLASH_APP );
42
43 FlexRAM = 0x14000000;
44 FTFL = 0x40020000;
45 SCB = 0xe000ed00;
46 USB0 = 0x40072000;
47 SIM = 0x40047000;
48
49 /* Section Definitions */
50 SECTIONS
51 {
52         .text :
53         {
54                 . = 0; KEEP(* (.vectors)) /* MUST BE AT 0 */
55                 *(.startup*)
56                 . = 0x400; KEEP(* (.flashconfig)) /* MUST BE AT 0x400 */
57                 *(.rodata*)
58                 *(.text*)
59                 . = ALIGN(4);
60                 KEEP(*(.init))
61         } > FLASH
62
63         .ARM.exidx :
64         {
65                 __exidx_start = .;
66                 *(.ARM.exidx* .gnu.linkonce.armexidx.*)
67                 __exidx_end = .;
68         } > FLASH
69         _etext = .;
70
71         .usbdescriptortable (NOLOAD) : {
72                 . = ALIGN(512);
73                 *(.usbdescriptortable*)
74         } > RAM
75
76         .dmabuffers (NOLOAD) : {
77                 . = ALIGN(4);
78                 *(.dmabuffers*)
79         } > RAM
80
81         .usbbuffers (NOLOAD) : {
82                 . = ALIGN(4);
83                 *(.usbbuffers*)
84         } > RAM
85
86         .data : AT (_etext) {
87                 . = ALIGN(4);
88                 _sdata = .;
89                 *(SORT_BY_ALIGNMENT(.ramtext.*) SORT_BY_ALIGNMENT(.data*))
90                 *(.data*)
91                 . = ALIGN(4);
92                 _edata = .;
93         } > RAM
94
95         .noinit (NOLOAD) : {
96                 *(.noinit*)
97         } > RAM
98
99         .bss : {
100                 . = ALIGN(4);
101                 _sbss = .;
102                 *(.bss*)
103                 *(COMMON)
104                 . = ALIGN(4);
105                 _ebss = .;
106                 __bss_end = .;
107         } > RAM
108
109         _estack = ORIGIN(RAM) + LENGTH(RAM);
110 }
111