MacroRat / MouseCode

Dependencies:   ITG3200 QEI

Committer:
sahilmgandhi
Date:
Sun May 14 23:18:57 2017 +0000
Revision:
18:6a4db94011d3
Publishing again

Who changed what in which revision?

UserRevisionLine numberNew contents of line
sahilmgandhi 18:6a4db94011d3 1 /*
sahilmgandhi 18:6a4db94011d3 2 ** ###################################################################
sahilmgandhi 18:6a4db94011d3 3 ** Processors: MKL27Z64VDA4
sahilmgandhi 18:6a4db94011d3 4 ** MKL27Z64VFM4
sahilmgandhi 18:6a4db94011d3 5 ** MKL27Z64VFT4
sahilmgandhi 18:6a4db94011d3 6 ** MKL27Z64VLH4
sahilmgandhi 18:6a4db94011d3 7 ** MKL27Z64VMP4
sahilmgandhi 18:6a4db94011d3 8 **
sahilmgandhi 18:6a4db94011d3 9 ** Compiler: GNU C Compiler
sahilmgandhi 18:6a4db94011d3 10 ** Reference manual: KL27P64M48SF2RM, Rev. 1, Sep 2014
sahilmgandhi 18:6a4db94011d3 11 ** Version: rev. 1.4, 2014-09-22
sahilmgandhi 18:6a4db94011d3 12 ** Build: b151217
sahilmgandhi 18:6a4db94011d3 13 **
sahilmgandhi 18:6a4db94011d3 14 ** Abstract:
sahilmgandhi 18:6a4db94011d3 15 ** Linker file for the GNU C Compiler
sahilmgandhi 18:6a4db94011d3 16 **
sahilmgandhi 18:6a4db94011d3 17 ** Copyright (c) 2015 Freescale Semiconductor, Inc.
sahilmgandhi 18:6a4db94011d3 18 ** All rights reserved.
sahilmgandhi 18:6a4db94011d3 19 **
sahilmgandhi 18:6a4db94011d3 20 ** Redistribution and use in source and binary forms, with or without modification,
sahilmgandhi 18:6a4db94011d3 21 ** are permitted provided that the following conditions are met:
sahilmgandhi 18:6a4db94011d3 22 **
sahilmgandhi 18:6a4db94011d3 23 ** o Redistributions of source code must retain the above copyright notice, this list
sahilmgandhi 18:6a4db94011d3 24 ** of conditions and the following disclaimer.
sahilmgandhi 18:6a4db94011d3 25 **
sahilmgandhi 18:6a4db94011d3 26 ** o Redistributions in binary form must reproduce the above copyright notice, this
sahilmgandhi 18:6a4db94011d3 27 ** list of conditions and the following disclaimer in the documentation and/or
sahilmgandhi 18:6a4db94011d3 28 ** other materials provided with the distribution.
sahilmgandhi 18:6a4db94011d3 29 **
sahilmgandhi 18:6a4db94011d3 30 ** o Neither the name of Freescale Semiconductor, Inc. nor the names of its
sahilmgandhi 18:6a4db94011d3 31 ** contributors may be used to endorse or promote products derived from this
sahilmgandhi 18:6a4db94011d3 32 ** software without specific prior written permission.
sahilmgandhi 18:6a4db94011d3 33 **
sahilmgandhi 18:6a4db94011d3 34 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
sahilmgandhi 18:6a4db94011d3 35 ** ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
sahilmgandhi 18:6a4db94011d3 36 ** WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
sahilmgandhi 18:6a4db94011d3 37 ** DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
sahilmgandhi 18:6a4db94011d3 38 ** ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
sahilmgandhi 18:6a4db94011d3 39 ** (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
sahilmgandhi 18:6a4db94011d3 40 ** LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
sahilmgandhi 18:6a4db94011d3 41 ** ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
sahilmgandhi 18:6a4db94011d3 42 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
sahilmgandhi 18:6a4db94011d3 43 ** SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
sahilmgandhi 18:6a4db94011d3 44 **
sahilmgandhi 18:6a4db94011d3 45 ** http: www.freescale.com
sahilmgandhi 18:6a4db94011d3 46 ** mail: support@freescale.com
sahilmgandhi 18:6a4db94011d3 47 **
sahilmgandhi 18:6a4db94011d3 48 ** ###################################################################
sahilmgandhi 18:6a4db94011d3 49 */
sahilmgandhi 18:6a4db94011d3 50
sahilmgandhi 18:6a4db94011d3 51 /* Entry Point */
sahilmgandhi 18:6a4db94011d3 52 ENTRY(Reset_Handler)
sahilmgandhi 18:6a4db94011d3 53
sahilmgandhi 18:6a4db94011d3 54 __ram_vector_table__ = 1;
sahilmgandhi 18:6a4db94011d3 55
sahilmgandhi 18:6a4db94011d3 56 /* With the RTOS in use, this does not affect the main stack size. The size of
sahilmgandhi 18:6a4db94011d3 57 * the stack where main runs is determined via the RTOS. */
sahilmgandhi 18:6a4db94011d3 58 __stack_size__ = 0x400;
sahilmgandhi 18:6a4db94011d3 59 /* With the RTOS in use, this does not affect the main heap size. */
sahilmgandhi 18:6a4db94011d3 60 __heap_size__ = 0x0;
sahilmgandhi 18:6a4db94011d3 61
sahilmgandhi 18:6a4db94011d3 62 HEAP_SIZE = DEFINED(__heap_size__) ? __heap_size__ : 0x0400;
sahilmgandhi 18:6a4db94011d3 63 STACK_SIZE = DEFINED(__stack_size__) ? __stack_size__ : 0x0400;
sahilmgandhi 18:6a4db94011d3 64 M_VECTOR_RAM_SIZE = DEFINED(__ram_vector_table__) ? 0x0200 : 0x0;
sahilmgandhi 18:6a4db94011d3 65
sahilmgandhi 18:6a4db94011d3 66 /* Specify the memory areas */
sahilmgandhi 18:6a4db94011d3 67 MEMORY
sahilmgandhi 18:6a4db94011d3 68 {
sahilmgandhi 18:6a4db94011d3 69 m_interrupts (RX) : ORIGIN = 0x00000000, LENGTH = 0x00000200
sahilmgandhi 18:6a4db94011d3 70 m_flash_config (RX) : ORIGIN = 0x00000400, LENGTH = 0x00000010
sahilmgandhi 18:6a4db94011d3 71 m_text (RX) : ORIGIN = 0x00000410, LENGTH = 0x0000FBF0
sahilmgandhi 18:6a4db94011d3 72 m_data (RW) : ORIGIN = 0x1FFFF000, LENGTH = 0x00004000
sahilmgandhi 18:6a4db94011d3 73 }
sahilmgandhi 18:6a4db94011d3 74
sahilmgandhi 18:6a4db94011d3 75 /* Define output sections */
sahilmgandhi 18:6a4db94011d3 76 SECTIONS
sahilmgandhi 18:6a4db94011d3 77 {
sahilmgandhi 18:6a4db94011d3 78 /* The startup code goes first into internal flash */
sahilmgandhi 18:6a4db94011d3 79 .interrupts :
sahilmgandhi 18:6a4db94011d3 80 {
sahilmgandhi 18:6a4db94011d3 81 __VECTOR_TABLE = .;
sahilmgandhi 18:6a4db94011d3 82 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 83 KEEP(*(.isr_vector)) /* Startup code */
sahilmgandhi 18:6a4db94011d3 84 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 85 } > m_interrupts
sahilmgandhi 18:6a4db94011d3 86
sahilmgandhi 18:6a4db94011d3 87 .flash_config :
sahilmgandhi 18:6a4db94011d3 88 {
sahilmgandhi 18:6a4db94011d3 89 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 90 KEEP(*(.FlashConfig)) /* Flash Configuration Field (FCF) */
sahilmgandhi 18:6a4db94011d3 91 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 92 } > m_flash_config
sahilmgandhi 18:6a4db94011d3 93
sahilmgandhi 18:6a4db94011d3 94 /* The program code and other data goes into internal flash */
sahilmgandhi 18:6a4db94011d3 95 .text :
sahilmgandhi 18:6a4db94011d3 96 {
sahilmgandhi 18:6a4db94011d3 97 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 98 *(.text) /* .text sections (code) */
sahilmgandhi 18:6a4db94011d3 99 *(.text*) /* .text* sections (code) */
sahilmgandhi 18:6a4db94011d3 100 *(.rodata) /* .rodata sections (constants, strings, etc.) */
sahilmgandhi 18:6a4db94011d3 101 *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
sahilmgandhi 18:6a4db94011d3 102 *(.glue_7) /* glue arm to thumb code */
sahilmgandhi 18:6a4db94011d3 103 *(.glue_7t) /* glue thumb to arm code */
sahilmgandhi 18:6a4db94011d3 104 *(.eh_frame)
sahilmgandhi 18:6a4db94011d3 105 KEEP (*(.init))
sahilmgandhi 18:6a4db94011d3 106 KEEP (*(.fini))
sahilmgandhi 18:6a4db94011d3 107 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 108 } > m_text
sahilmgandhi 18:6a4db94011d3 109
sahilmgandhi 18:6a4db94011d3 110 .ARM.extab :
sahilmgandhi 18:6a4db94011d3 111 {
sahilmgandhi 18:6a4db94011d3 112 *(.ARM.extab* .gnu.linkonce.armextab.*)
sahilmgandhi 18:6a4db94011d3 113 } > m_text
sahilmgandhi 18:6a4db94011d3 114
sahilmgandhi 18:6a4db94011d3 115 .ARM :
sahilmgandhi 18:6a4db94011d3 116 {
sahilmgandhi 18:6a4db94011d3 117 __exidx_start = .;
sahilmgandhi 18:6a4db94011d3 118 *(.ARM.exidx*)
sahilmgandhi 18:6a4db94011d3 119 __exidx_end = .;
sahilmgandhi 18:6a4db94011d3 120 } > m_text
sahilmgandhi 18:6a4db94011d3 121
sahilmgandhi 18:6a4db94011d3 122 .ctors :
sahilmgandhi 18:6a4db94011d3 123 {
sahilmgandhi 18:6a4db94011d3 124 __CTOR_LIST__ = .;
sahilmgandhi 18:6a4db94011d3 125 /* gcc uses crtbegin.o to find the start of
sahilmgandhi 18:6a4db94011d3 126 the constructors, so we make sure it is
sahilmgandhi 18:6a4db94011d3 127 first. Because this is a wildcard, it
sahilmgandhi 18:6a4db94011d3 128 doesn't matter if the user does not
sahilmgandhi 18:6a4db94011d3 129 actually link against crtbegin.o; the
sahilmgandhi 18:6a4db94011d3 130 linker won't look for a file to match a
sahilmgandhi 18:6a4db94011d3 131 wildcard. The wildcard also means that it
sahilmgandhi 18:6a4db94011d3 132 doesn't matter which directory crtbegin.o
sahilmgandhi 18:6a4db94011d3 133 is in. */
sahilmgandhi 18:6a4db94011d3 134 KEEP (*crtbegin.o(.ctors))
sahilmgandhi 18:6a4db94011d3 135 KEEP (*crtbegin?.o(.ctors))
sahilmgandhi 18:6a4db94011d3 136 /* We don't want to include the .ctor section from
sahilmgandhi 18:6a4db94011d3 137 from the crtend.o file until after the sorted ctors.
sahilmgandhi 18:6a4db94011d3 138 The .ctor section from the crtend file contains the
sahilmgandhi 18:6a4db94011d3 139 end of ctors marker and it must be last */
sahilmgandhi 18:6a4db94011d3 140 KEEP (*(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors))
sahilmgandhi 18:6a4db94011d3 141 KEEP (*(SORT(.ctors.*)))
sahilmgandhi 18:6a4db94011d3 142 KEEP (*(.ctors))
sahilmgandhi 18:6a4db94011d3 143 __CTOR_END__ = .;
sahilmgandhi 18:6a4db94011d3 144 } > m_text
sahilmgandhi 18:6a4db94011d3 145
sahilmgandhi 18:6a4db94011d3 146 .dtors :
sahilmgandhi 18:6a4db94011d3 147 {
sahilmgandhi 18:6a4db94011d3 148 __DTOR_LIST__ = .;
sahilmgandhi 18:6a4db94011d3 149 KEEP (*crtbegin.o(.dtors))
sahilmgandhi 18:6a4db94011d3 150 KEEP (*crtbegin?.o(.dtors))
sahilmgandhi 18:6a4db94011d3 151 KEEP (*(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors))
sahilmgandhi 18:6a4db94011d3 152 KEEP (*(SORT(.dtors.*)))
sahilmgandhi 18:6a4db94011d3 153 KEEP (*(.dtors))
sahilmgandhi 18:6a4db94011d3 154 __DTOR_END__ = .;
sahilmgandhi 18:6a4db94011d3 155 } > m_text
sahilmgandhi 18:6a4db94011d3 156
sahilmgandhi 18:6a4db94011d3 157 .preinit_array :
sahilmgandhi 18:6a4db94011d3 158 {
sahilmgandhi 18:6a4db94011d3 159 PROVIDE_HIDDEN (__preinit_array_start = .);
sahilmgandhi 18:6a4db94011d3 160 KEEP (*(.preinit_array*))
sahilmgandhi 18:6a4db94011d3 161 PROVIDE_HIDDEN (__preinit_array_end = .);
sahilmgandhi 18:6a4db94011d3 162 } > m_text
sahilmgandhi 18:6a4db94011d3 163
sahilmgandhi 18:6a4db94011d3 164 .init_array :
sahilmgandhi 18:6a4db94011d3 165 {
sahilmgandhi 18:6a4db94011d3 166 PROVIDE_HIDDEN (__init_array_start = .);
sahilmgandhi 18:6a4db94011d3 167 KEEP (*(SORT(.init_array.*)))
sahilmgandhi 18:6a4db94011d3 168 KEEP (*(.init_array*))
sahilmgandhi 18:6a4db94011d3 169 PROVIDE_HIDDEN (__init_array_end = .);
sahilmgandhi 18:6a4db94011d3 170 } > m_text
sahilmgandhi 18:6a4db94011d3 171
sahilmgandhi 18:6a4db94011d3 172 .fini_array :
sahilmgandhi 18:6a4db94011d3 173 {
sahilmgandhi 18:6a4db94011d3 174 PROVIDE_HIDDEN (__fini_array_start = .);
sahilmgandhi 18:6a4db94011d3 175 KEEP (*(SORT(.fini_array.*)))
sahilmgandhi 18:6a4db94011d3 176 KEEP (*(.fini_array*))
sahilmgandhi 18:6a4db94011d3 177 PROVIDE_HIDDEN (__fini_array_end = .);
sahilmgandhi 18:6a4db94011d3 178 } > m_text
sahilmgandhi 18:6a4db94011d3 179
sahilmgandhi 18:6a4db94011d3 180 __etext = .; /* define a global symbol at end of code */
sahilmgandhi 18:6a4db94011d3 181 __DATA_ROM = .; /* Symbol is used by startup for data initialization */
sahilmgandhi 18:6a4db94011d3 182
sahilmgandhi 18:6a4db94011d3 183 /* reserve MTB memory at the beginning of m_data */
sahilmgandhi 18:6a4db94011d3 184 .mtb : /* MTB buffer address as defined by the hardware */
sahilmgandhi 18:6a4db94011d3 185 {
sahilmgandhi 18:6a4db94011d3 186 . = ALIGN(8);
sahilmgandhi 18:6a4db94011d3 187 _mtb_start = .;
sahilmgandhi 18:6a4db94011d3 188 KEEP(*(.mtb_buf)) /* need to KEEP Micro Trace Buffer as not referenced by application */
sahilmgandhi 18:6a4db94011d3 189 . = ALIGN(8);
sahilmgandhi 18:6a4db94011d3 190 _mtb_end = .;
sahilmgandhi 18:6a4db94011d3 191 } > m_data
sahilmgandhi 18:6a4db94011d3 192
sahilmgandhi 18:6a4db94011d3 193 .interrupts_ram :
sahilmgandhi 18:6a4db94011d3 194 {
sahilmgandhi 18:6a4db94011d3 195 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 196 __VECTOR_RAM__ = .;
sahilmgandhi 18:6a4db94011d3 197 __interrupts_ram_start__ = .; /* Create a global symbol at data start */
sahilmgandhi 18:6a4db94011d3 198 *(.m_interrupts_ram) /* This is a user defined section */
sahilmgandhi 18:6a4db94011d3 199 . += M_VECTOR_RAM_SIZE;
sahilmgandhi 18:6a4db94011d3 200 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 201 __interrupts_ram_end__ = .; /* Define a global symbol at data end */
sahilmgandhi 18:6a4db94011d3 202 } > m_data
sahilmgandhi 18:6a4db94011d3 203
sahilmgandhi 18:6a4db94011d3 204 __VECTOR_RAM = DEFINED(__ram_vector_table__) ? __VECTOR_RAM__ : ORIGIN(m_interrupts);
sahilmgandhi 18:6a4db94011d3 205 __RAM_VECTOR_TABLE_SIZE_BYTES = DEFINED(__ram_vector_table__) ? (__interrupts_ram_end__ - __interrupts_ram_start__) : 0x0;
sahilmgandhi 18:6a4db94011d3 206
sahilmgandhi 18:6a4db94011d3 207 .data : AT(__DATA_ROM)
sahilmgandhi 18:6a4db94011d3 208 {
sahilmgandhi 18:6a4db94011d3 209 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 210 __DATA_RAM = .;
sahilmgandhi 18:6a4db94011d3 211 __data_start__ = .; /* create a global symbol at data start */
sahilmgandhi 18:6a4db94011d3 212 *(.data) /* .data sections */
sahilmgandhi 18:6a4db94011d3 213 *(.data*) /* .data* sections */
sahilmgandhi 18:6a4db94011d3 214 KEEP(*(.jcr*))
sahilmgandhi 18:6a4db94011d3 215 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 216 __data_end__ = .; /* define a global symbol at data end */
sahilmgandhi 18:6a4db94011d3 217 } > m_data
sahilmgandhi 18:6a4db94011d3 218
sahilmgandhi 18:6a4db94011d3 219 __DATA_END = __DATA_ROM + (__data_end__ - __data_start__);
sahilmgandhi 18:6a4db94011d3 220 text_end = ORIGIN(m_text) + LENGTH(m_text);
sahilmgandhi 18:6a4db94011d3 221 ASSERT(__DATA_END <= text_end, "region m_text overflowed with text and data")
sahilmgandhi 18:6a4db94011d3 222
sahilmgandhi 18:6a4db94011d3 223 USB_RAM_GAP = DEFINED(__usb_ram_size__) ? __usb_ram_size__ : 0x800;
sahilmgandhi 18:6a4db94011d3 224 /* Uninitialized data section */
sahilmgandhi 18:6a4db94011d3 225 .bss :
sahilmgandhi 18:6a4db94011d3 226 {
sahilmgandhi 18:6a4db94011d3 227 /* This is used by the startup in order to initialize the .bss section */
sahilmgandhi 18:6a4db94011d3 228 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 229 __START_BSS = .;
sahilmgandhi 18:6a4db94011d3 230 __bss_start__ = .;
sahilmgandhi 18:6a4db94011d3 231 *(.bss)
sahilmgandhi 18:6a4db94011d3 232 *(.bss*)
sahilmgandhi 18:6a4db94011d3 233 . = ALIGN(512);
sahilmgandhi 18:6a4db94011d3 234 USB_RAM_START = .;
sahilmgandhi 18:6a4db94011d3 235 . += USB_RAM_GAP;
sahilmgandhi 18:6a4db94011d3 236 *(COMMON)
sahilmgandhi 18:6a4db94011d3 237 . = ALIGN(4);
sahilmgandhi 18:6a4db94011d3 238 __bss_end__ = .;
sahilmgandhi 18:6a4db94011d3 239 __END_BSS = .;
sahilmgandhi 18:6a4db94011d3 240 } > m_data
sahilmgandhi 18:6a4db94011d3 241
sahilmgandhi 18:6a4db94011d3 242 .heap :
sahilmgandhi 18:6a4db94011d3 243 {
sahilmgandhi 18:6a4db94011d3 244 . = ALIGN(8);
sahilmgandhi 18:6a4db94011d3 245 __end__ = .;
sahilmgandhi 18:6a4db94011d3 246 PROVIDE(end = .);
sahilmgandhi 18:6a4db94011d3 247 __HeapBase = .;
sahilmgandhi 18:6a4db94011d3 248 . += HEAP_SIZE;
sahilmgandhi 18:6a4db94011d3 249 __HeapLimit = .;
sahilmgandhi 18:6a4db94011d3 250 __heap_limit = .; /* Add for _sbrk */
sahilmgandhi 18:6a4db94011d3 251 } > m_data
sahilmgandhi 18:6a4db94011d3 252
sahilmgandhi 18:6a4db94011d3 253 .stack :
sahilmgandhi 18:6a4db94011d3 254 {
sahilmgandhi 18:6a4db94011d3 255 . = ALIGN(8);
sahilmgandhi 18:6a4db94011d3 256 . += STACK_SIZE;
sahilmgandhi 18:6a4db94011d3 257 } > m_data
sahilmgandhi 18:6a4db94011d3 258
sahilmgandhi 18:6a4db94011d3 259 m_usb_bdt USB_RAM_START (NOLOAD) :
sahilmgandhi 18:6a4db94011d3 260 {
sahilmgandhi 18:6a4db94011d3 261 *(m_usb_bdt)
sahilmgandhi 18:6a4db94011d3 262 USB_RAM_BDT_END = .;
sahilmgandhi 18:6a4db94011d3 263 }
sahilmgandhi 18:6a4db94011d3 264
sahilmgandhi 18:6a4db94011d3 265 m_usb_global USB_RAM_BDT_END (NOLOAD) :
sahilmgandhi 18:6a4db94011d3 266 {
sahilmgandhi 18:6a4db94011d3 267 *(m_usb_global)
sahilmgandhi 18:6a4db94011d3 268 }
sahilmgandhi 18:6a4db94011d3 269
sahilmgandhi 18:6a4db94011d3 270 /* Initializes stack on the end of block */
sahilmgandhi 18:6a4db94011d3 271 __StackTop = ORIGIN(m_data) + LENGTH(m_data);
sahilmgandhi 18:6a4db94011d3 272 __StackLimit = __StackTop - STACK_SIZE;
sahilmgandhi 18:6a4db94011d3 273 PROVIDE(__stack = __StackTop);
sahilmgandhi 18:6a4db94011d3 274
sahilmgandhi 18:6a4db94011d3 275 .ARM.attributes 0 : { *(.ARM.attributes) }
sahilmgandhi 18:6a4db94011d3 276
sahilmgandhi 18:6a4db94011d3 277 ASSERT(__StackLimit >= __HeapLimit, "region m_data overflowed with stack and heap")
sahilmgandhi 18:6a4db94011d3 278 }
sahilmgandhi 18:6a4db94011d3 279