/*\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
\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
/* 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