SECTIONS { .text : { . = ALIGN(4); KEEP(*(.init)) . = ALIGN(4); *(.text.handleInterruptASM) *(.text) *(.text.*) *(.rodata) *(.rodata.*) . = ALIGN(4); } >FLASH_TEXT /* Put the stack at the bottom of RAM, so that the application will * crash on stack overflow instead of silently corrupting memory. * See: http://blog.japaric.io/stack-overflow-protection/ */ .stack (NOLOAD) : { . = ALIGN(8); . += _stack_size; _stack_top = .; } >RAM /* Start address (in flash) of .data, used by startup code. */ _sidata = LOADADDR(.data); /* Globals with initial value */ .data : { . = ALIGN(8); /* see https://gnu-mcu-eclipse.github.io/arch/riscv/programmer/#the-gp-global-pointer-register */ PROVIDE( __global_pointer$ = . + (4K / 2) ); _sdata = .; /* used by startup code */ *(.sdata) *(.data .data.*) . = ALIGN(8); _edata = .; /* used by startup code */ } >RAM AT>FLASH_TEXT /* Zero-initialized globals */ .bss : { . = ALIGN(8); _sbss = .; /* used by startup code */ *(.sbss) *(.bss .bss.*) *(COMMON) . = ALIGN(8); _ebss = .; /* used by startup code */ } >RAM /DISCARD/ : { *(.eh_frame) /* causes 'no memory region specified' error in lld */ } } /* For the memory allocator. */ _heap_start = _ebss; _heap_end = ORIGIN(RAM) + LENGTH(RAM); _globals_start = _sdata; _globals_end = _ebss;