tests: nrf: Sync link_ram.x from upstream
Upstream has added bunch of improvements and fixes to linker script, so sync these while keeping the FLASH -> RAM changes.
This commit is contained in:
		
							parent
							
								
									9c2d2ff64d
								
							
						
					
					
						commit
						17346fdfc2
					
				| @ -1,5 +1,5 @@ | |||||||
| /* ##### EMBASSY NOTE | /* ##### EMBASSY NOTE | ||||||
|     Originally from https://github.com/rust-embedded/cortex-m-rt/blob/master/link.x.in |     Originally from https://github.com/rust-embedded/cortex-m/blob/master/cortex-m-rt/link.x.in | ||||||
|     Adjusted to put everything in RAM |     Adjusted to put everything in RAM | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| @ -65,22 +65,30 @@ PROVIDE(__pre_init = DefaultPreInit); | |||||||
| /* # Sections */ | /* # Sections */ | ||||||
| SECTIONS | SECTIONS | ||||||
| { | { | ||||||
|   PROVIDE(_stack_start = ORIGIN(RAM) + LENGTH(RAM)); |   PROVIDE(_ram_start = ORIGIN(RAM)); | ||||||
|  |   PROVIDE(_ram_end = ORIGIN(RAM) + LENGTH(RAM)); | ||||||
|  |   PROVIDE(_stack_start = _ram_end); | ||||||
| 
 | 
 | ||||||
|   /* ## Sections in RAM */ |   /* ## Sections in RAM */ | ||||||
|   /* ### Vector table */ |   /* ### Vector table */ | ||||||
|   .vector_table ORIGIN(RAM) : |   .vector_table ORIGIN(RAM) : | ||||||
|   { |   { | ||||||
|     /* Initial Stack Pointer (SP) value */ |     __vector_table = .; | ||||||
|     LONG(_stack_start); | 
 | ||||||
|  |     /* Initial Stack Pointer (SP) value. | ||||||
|  |      * We mask the bottom three bits to force 8-byte alignment. | ||||||
|  |      * Despite having an assert for this later, it's possible that a separate | ||||||
|  |      * linker script could override _stack_start after the assert is checked. | ||||||
|  |      */ | ||||||
|  |     LONG(_stack_start & 0xFFFFFFF8); | ||||||
| 
 | 
 | ||||||
|     /* Reset vector */ |     /* Reset vector */ | ||||||
|     KEEP(*(.vector_table.reset_vector)); /* this is the `__RESET_VECTOR` symbol */ |     KEEP(*(.vector_table.reset_vector)); /* this is the `__RESET_VECTOR` symbol */ | ||||||
|     __reset_vector = .; |  | ||||||
| 
 | 
 | ||||||
|     /* Exceptions */ |     /* Exceptions */ | ||||||
|  |     __exceptions = .; /* start of exceptions */ | ||||||
|     KEEP(*(.vector_table.exceptions)); /* this is the `__EXCEPTIONS` symbol */ |     KEEP(*(.vector_table.exceptions)); /* this is the `__EXCEPTIONS` symbol */ | ||||||
|     __eexceptions = .; |     __eexceptions = .; /* end of exceptions */ | ||||||
| 
 | 
 | ||||||
|     /* Device specific interrupts */ |     /* Device specific interrupts */ | ||||||
|     KEEP(*(.vector_table.interrupts)); /* this is the `__INTERRUPTS` symbol */ |     KEEP(*(.vector_table.interrupts)); /* this is the `__INTERRUPTS` symbol */ | ||||||
| @ -125,7 +133,6 @@ SECTIONS | |||||||
|   { |   { | ||||||
|     . = ALIGN(4); |     . = ALIGN(4); | ||||||
|     __sdata = .; |     __sdata = .; | ||||||
|     __edata = .; |  | ||||||
|     *(.data .data.*); |     *(.data .data.*); | ||||||
|     . = ALIGN(4); /* 4-byte align the end (VMA) of this section */ |     . = ALIGN(4); /* 4-byte align the end (VMA) of this section */ | ||||||
|   } > RAM |   } > RAM | ||||||
| @ -133,6 +140,7 @@ SECTIONS | |||||||
|    * use the .data loading mechanism by pushing __edata. Note: do not change |    * use the .data loading mechanism by pushing __edata. Note: do not change | ||||||
|    * output region or load region in those user sections! */ |    * output region or load region in those user sections! */ | ||||||
|   . = ALIGN(4); |   . = ALIGN(4); | ||||||
|  |   __edata = .; | ||||||
| 
 | 
 | ||||||
|   /* LMA of .data */ |   /* LMA of .data */ | ||||||
|   __sidata = LOADADDR(.data); |   __sidata = LOADADDR(.data); | ||||||
| @ -147,8 +155,12 @@ SECTIONS | |||||||
|     __veneer_base = .; |     __veneer_base = .; | ||||||
|     *(.gnu.sgstubs*) |     *(.gnu.sgstubs*) | ||||||
|     . = ALIGN(32); |     . = ALIGN(32); | ||||||
|     __veneer_limit = .; |  | ||||||
|   } > RAM |   } > RAM | ||||||
|  |   /* Place `__veneer_limit` outside the `.gnu.sgstubs` section because veneers are | ||||||
|  |    * always inserted last in the section, which would otherwise be _after_ the `__veneer_limit` symbol. | ||||||
|  |    */ | ||||||
|  |   . = ALIGN(32); | ||||||
|  |   __veneer_limit = .; | ||||||
| 
 | 
 | ||||||
|   /* ### .bss */ |   /* ### .bss */ | ||||||
|   .bss (NOLOAD) : ALIGN(4) |   .bss (NOLOAD) : ALIGN(4) | ||||||
| @ -213,10 +225,21 @@ BUG(cortex-m-rt): .bss is not 4-byte aligned"); | |||||||
| ASSERT(__sheap % 4 == 0, " | ASSERT(__sheap % 4 == 0, " | ||||||
| BUG(cortex-m-rt): start of .heap is not 4-byte aligned"); | BUG(cortex-m-rt): start of .heap is not 4-byte aligned"); | ||||||
| 
 | 
 | ||||||
|  | ASSERT(_stack_start % 8 == 0, " | ||||||
|  | ERROR(cortex-m-rt): stack start address is not 8-byte aligned. | ||||||
|  | If you have set _stack_start, check it's set to an address which is a multiple of 8 bytes. | ||||||
|  | If you haven't, stack starts at the end of RAM by default. Check that both RAM | ||||||
|  | origin and length are set to multiples of 8 in the `memory.x` file."); | ||||||
|  | 
 | ||||||
| /* # Position checks */ | /* # Position checks */ | ||||||
| 
 | 
 | ||||||
| /* ## .vector_table */ | /* ## .vector_table | ||||||
| ASSERT(__reset_vector == ADDR(.vector_table) + 0x8, " |  * | ||||||
|  |  * If the *start* of exception vectors is not 8 bytes past the start of the | ||||||
|  |  * vector table, then we somehow did not place the reset vector, which should | ||||||
|  |  * live 4 bytes past the start of the vector table. | ||||||
|  |  */ | ||||||
|  | ASSERT(__exceptions == ADDR(.vector_table) + 0x8, " | ||||||
| BUG(cortex-m-rt): the reset vector is missing"); | BUG(cortex-m-rt): the reset vector is missing"); | ||||||
| 
 | 
 | ||||||
| ASSERT(__eexceptions == ADDR(.vector_table) + 0x40, " | ASSERT(__eexceptions == ADDR(.vector_table) + 0x40, " | ||||||
| @ -248,7 +271,6 @@ the 'cc' crate then modify your build script to compile the C code _without_ | |||||||
| the -fPIC flag. See the documentation of the `cc::Build.pic` method for details."); | the -fPIC flag. See the documentation of the `cc::Build.pic` method for details."); | ||||||
| /* Do not exceed this mark in the error messages above                                    | */ | /* Do not exceed this mark in the error messages above                                    | */ | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| /* Provides weak aliases (cf. PROVIDED) for device specific interrupt handlers */ | /* Provides weak aliases (cf. PROVIDED) for device specific interrupt handlers */ | ||||||
| /* This will usually be provided by a device crate generated using svd2rust (see `device.x`) */ | /* This will usually be provided by a device crate generated using svd2rust (see `device.x`) */ | ||||||
| INCLUDE device.x | INCLUDE device.x | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user