]> git.friedersdorff.com Git - max/tmk_keyboard.git/blobdiff - keyboard/teensy_lc_onekey/ld/MKL26Z64.ld
ibmpc_usb: Update prebuilt firmware files
[max/tmk_keyboard.git] / keyboard / teensy_lc_onekey / ld / MKL26Z64.ld
index 9e9e92502ca6cb3bf8fed94a2a813e86f4dbce6c..fb141f888cef12c77e6080e37a5db877b87701e8 100644 (file)
@@ -1,47 +1,86 @@
 /*\r
-    ChibiOS - Copyright (C) 2006..2015 Giovanni Di Sirio.\r
-\r
-    This file is part of ChibiOS.\r
-\r
-    ChibiOS is free software; you can redistribute it and/or modify\r
-    it under the terms of the GNU General Public License as published by\r
-    the Free Software Foundation; either version 3 of the License, or\r
-    (at your option) any later version.\r
-\r
-    ChibiOS is distributed in the hope that it will be useful,\r
-    but WITHOUT ANY WARRANTY; without even the implied warranty of\r
-    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
-    GNU General Public License for more details.\r
-\r
-    You should have received a copy of the GNU General Public License\r
-    along with this program.  If not, see <http://www.gnu.org/licenses/>.\r
-*/\r
+ * Copyright (C) 2013-2016 Fabio Utzig, http://fabioutzig.com\r
+ *           (C) 2016 flabbergast <s3+flabbergast@sdfeu.org>\r
+ *\r
+ * Permission is hereby granted, free of charge, to any person obtaining\r
+ * a copy of this software and associated documentation files (the "Software"),\r
+ * to deal in the Software without restriction, including without limitation\r
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,\r
+ * and/or sell copies of the Software, and to permit persons to whom the\r
+ * Software is furnished to do so, subject to the following conditions:\r
+ *\r
+ * The above copyright notice and this permission notice shall be included in\r
+ * all copies or substantial portions of the Software.\r
+ *\r
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS\r
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\r
+ * SOFTWARE.\r
+ */\r
 \r
 /*\r
  * KL26Z64 memory setup.\r
  */\r
 MEMORY\r
 {\r
-  flash0   :  org = 0x00000000,  len = 0xc0\r
-  flashcfg :  org = 0x00000400,  len = 0x10\r
-  flash    :  org = 0x00000410,  len = 62k - 0x410\r
-  eeprom_emu : org = 0x0000F800, len = 2k\r
-  ram0     :  org = 0x1FFFF800,  len = 8k\r
-  ram1     :  org = 0x00000000,  len = 0\r
-  ram2     :  org = 0x00000000,  len = 0\r
-  ram3     :  org = 0x00000000,  len = 0\r
-  ram4     :  org = 0x00000000,  len = 0\r
-  ram5     :  org = 0x00000000,  len = 0\r
-  ram6     :  org = 0x00000000,  len = 0\r
-  ram7     :  org = 0x00000000,  len = 0\r
+  flash0   : org = 0x00000000, len = 0x100\r
+  flash1   : org = 0x00000400, len = 0x10\r
+  flash2   : org = 0x00000410, len = 62k - 0x410\r
+  flash3   : org = 0x0000F800, len = 2k\r
+  flash4   : org = 0x00000000, len = 0\r
+  flash5   : org = 0x00000000, len = 0\r
+  flash6   : org = 0x00000000, len = 0\r
+  flash7   : org = 0x00000000, len = 0\r
+  ram0     : org = 0x1FFFF800, len = 8k\r
+  ram1     : org = 0x00000000, len = 0\r
+  ram2     : org = 0x00000000, len = 0\r
+  ram3     : org = 0x00000000, len = 0\r
+  ram4     : org = 0x00000000, len = 0\r
+  ram5     : org = 0x00000000, len = 0\r
+  ram6     : org = 0x00000000, len = 0\r
+  ram7     : org = 0x00000000, len = 0\r
 }\r
 \r
-__eeprom_workarea_start__ = ORIGIN(eeprom_emu);\r
-__eeprom_workarea_size__  = LENGTH(eeprom_emu);\r
-__eeprom_workarea_end__   = __eeprom_workarea_start__ + __eeprom_workarea_size__;\r
+/* Flash region for the configuration bytes.*/\r
+SECTIONS\r
+{\r
+  .cfmprotect : ALIGN(4) SUBALIGN(4)\r
+  {\r
+    KEEP(*(.cfmconfig))\r
+  } > flash1\r
+}\r
+\r
+/* For each data/text section two region are defined, a virtual region\r
+   and a load region (_LMA suffix).*/\r
+\r
+/* Flash region to be used for exception vectors.*/\r
+REGION_ALIAS("VECTORS_FLASH", flash0);\r
+REGION_ALIAS("VECTORS_FLASH_LMA", flash0);\r
+\r
+/* Flash region to be used for constructors and destructors.*/\r
+REGION_ALIAS("XTORS_FLASH", flash2);\r
+REGION_ALIAS("XTORS_FLASH_LMA", flash2);\r
+\r
+/* Flash region to be used for code text.*/\r
+REGION_ALIAS("TEXT_FLASH", flash2);\r
+REGION_ALIAS("TEXT_FLASH_LMA", flash2);\r
+\r
+/* Flash region to be used for read only data.*/\r
+REGION_ALIAS("RODATA_FLASH", flash2);\r
+REGION_ALIAS("RODATA_FLASH_LMA", flash2);\r
+\r
+/* Flash region to be used for various.*/\r
+REGION_ALIAS("VARIOUS_FLASH", flash2);\r
+REGION_ALIAS("VARIOUS_FLASH_LMA", flash2);\r
+\r
+/* Flash region to be used for RAM(n) initialization data.*/\r
+REGION_ALIAS("RAM_INIT_FLASH_LMA", flash2);\r
 \r
 /* RAM region to be used for Main stack. This stack accommodates the processing\r
-   of all exceptions and interrupts*/\r
+   of all exceptions and interrupts.*/\r
 REGION_ALIAS("MAIN_STACK_RAM", ram0);\r
 \r
 /* RAM region to be used for the process stack. This is the stack used by\r
@@ -50,6 +89,7 @@ REGION_ALIAS("PROCESS_STACK_RAM", ram0);
 \r
 /* RAM region to be used for data segment.*/\r
 REGION_ALIAS("DATA_RAM", ram0);\r
+REGION_ALIAS("DATA_RAM_LMA", flash2);\r
 \r
 /* RAM region to be used for BSS segment.*/\r
 REGION_ALIAS("BSS_RAM", ram0);\r
@@ -57,4 +97,9 @@ REGION_ALIAS("BSS_RAM", ram0);
 /* RAM region to be used for the default heap.*/\r
 REGION_ALIAS("HEAP_RAM", ram0);\r
 \r
-INCLUDE ld/rules_kinetis.ld\r
+__eeprom_workarea_start__ = ORIGIN(flash3);\r
+__eeprom_workarea_size__  = LENGTH(flash3);\r
+__eeprom_workarea_end__   = __eeprom_workarea_start__ + __eeprom_workarea_size__;\r
+\r
+/* Generic rules inclusion.*/\r
+INCLUDE rules.ld\r