X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/2bfed17db25367442c6ad57a76a3c998ec84889c..45dcfac2cc8df0e60c05d4596f74c785347dce36:/bootrom/ldscript-flash?ds=sidebyside diff --git a/bootrom/ldscript-flash b/bootrom/ldscript-flash index 50218d68..ccc0db2f 100644 --- a/bootrom/ldscript-flash +++ b/bootrom/ldscript-flash @@ -5,15 +5,32 @@ SECTIONS { . = 0; - bootphase1 : { + .bootphase1 : { *(.startup) *(.bootphase1) + + /* It seems to be impossible to flush align a section at the + end of a memory segment. Instead, we'll put the version_information + wherever the linker wants it, and then put a pointer to the start + of the version information at the end of the section. + -- Henryk Plötz 2009-08-28 */ + + _version_information_start = ABSOLUTE(.); + *(.version_information); + + /* Why doesn't this work even though _bootphase1_version_pointer = 0x1001fc? + . = _bootphase1_version_pointer - ORIGIN(bootphase1); */ + /* This works, apparently it fools the linker into accepting an absolute address */ + . = _bootphase1_version_pointer - ORIGIN(bootphase1) + ORIGIN(bootphase1); + LONG(_version_information_start) } >bootphase1 - bootphase2 : { + __bootphase2_src_start__ = ORIGIN(bootphase2); + .bootphase2 : { __bootphase2_start__ = .; *(.startphase2) *(.text) + *(.eh_frame) *(.glue_7) *(.glue_7t) *(.rodata) @@ -29,4 +46,8 @@ SECTIONS . = ALIGN( 32 / 8 ); __bss_end__ = .; + + .commonarea (NOLOAD) : { + *(.commonarea) + } >commonarea }