X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/57fcd2d7d14c7c41242aaae49653f3669971f4d6..2e656c39ebfd7e2471296ec96bcb1eee7b6b39f6:/armsrc/ldscript?ds=inline diff --git a/armsrc/ldscript b/armsrc/ldscript index 8e3231c0..d0be3b6a 100644 --- a/armsrc/ldscript +++ b/armsrc/ldscript @@ -1,30 +1,70 @@ -INCLUDE ../common/ldscript.common - -ENTRY(Vector) -SECTIONS -{ - .fpgaimage : { - *(fpga_bit.data) - } >fpgaimage - .start : { *(.startos) } >osimage - .text : { - *(.text) - *(.text.*) - *(.eh_frame) - *(.glue_7) - *(.glue_7t) - *(.version_information) - } >osimage - .rodata : { - *(.rodata) - *(.rodata*) - } >osimage - .data : { *(.data) } >ram - __bss_start__ = .; - .bss : { *(.bss) } >ram - __bss_end__ = .; - - .commonarea (NOLOAD) : { - *(.commonarea) - } >commonarea -} +/* +----------------------------------------------------------------------------- + This code is licensed to you under the terms of the GNU GPL, version 2 or, + at your option, any later version. See the LICENSE.txt file for the text of + the license. +----------------------------------------------------------------------------- + Linker script for the ARM binary +----------------------------------------------------------------------------- +*/ +INCLUDE ../common/ldscript.common + +PHDRS +{ + fpgaimage PT_LOAD FLAGS(4); + text PT_LOAD; + data PT_LOAD; + bss PT_LOAD; +} + +ENTRY(Vector) +SECTIONS +{ + .fpgaimage : { + *(fpga_lf_bit.data) + *(fpga_hf_bit.data) + } >fpgaimage :fpgaimage + + .start : { + *(.startos) + } >osimage :text + + .text : { + *(.text) + *(.text.*) + *(.eh_frame) + *(.glue_7) + *(.glue_7t) + } >osimage :text + + .rodata : { + *(.rodata) + *(.rodata.*) + KEEP(*(.version_information)) + } >osimage :text + + . = ALIGN(4); + + .data : { + *(.data) + *(.data.*) + *(.ramfunc) + . = ALIGN(4); + } >ram AT>osimage :data + + __data_src_start__ = LOADADDR(.data); + __data_start__ = ADDR(.data); + __data_end__ = __data_start__ + SIZEOF(.data); + + .bss : { + __bss_start__ = .; + *(.bss) + *(.bss.*) + . = ALIGN(4); + __bss_end__ = .; + } >ram AT>ram :bss + + .commonarea (NOLOAD) : { + *(.commonarea) + } >commonarea :NONE +}