mirror of
				https://xff.cz/git/u-boot/
				synced 2025-10-26 16:13:55 +01:00 
			
		
		
		
	Allow PSCI layer to handle any SiP service functions added by platform vendors. PSCI layer will look for SiP service function in the SiP function table located in '._secure_svc_tbl_entries' section if the SMC function identifier is not found in the PSCI standard functions table. Use DECLARE_SECURE_SVC macro to declare and add platform specific SiP service function. This new section '._secure_svc_tbl_entries' is located next to '._secure.text' section. Refer to arch/arm/cpu/armv8/u-boot.lds. Signed-off-by: Chee Hong Ang <chee.hong.ang@intel.com>
		
			
				
	
	
		
			176 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			176 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * (C) Copyright 2013
 | |
|  * David Feng <fenghua@phytium.com.cn>
 | |
|  *
 | |
|  * (C) Copyright 2002
 | |
|  * Gary Jennejohn, DENX Software Engineering, <garyj@denx.de>
 | |
|  */
 | |
| 
 | |
| #include <config.h>
 | |
| #include <asm/psci.h>
 | |
| 
 | |
| OUTPUT_FORMAT("elf64-littleaarch64", "elf64-littleaarch64", "elf64-littleaarch64")
 | |
| OUTPUT_ARCH(aarch64)
 | |
| ENTRY(_start)
 | |
| SECTIONS
 | |
| {
 | |
| #ifdef CONFIG_ARMV8_SECURE_BASE
 | |
| 	/DISCARD/ : { *(.rela._secure*) }
 | |
| #endif
 | |
| 	. = 0x00000000;
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 	.text :
 | |
| 	{
 | |
| 		*(.__image_copy_start)
 | |
| 		CPUDIR/start.o (.text*)
 | |
| 	}
 | |
| 
 | |
| 	/* This needs to come before *(.text*) */
 | |
| 	.efi_runtime : {
 | |
|                 __efi_runtime_start = .;
 | |
| 		*(.text.efi_runtime*)
 | |
| 		*(.rodata.efi_runtime*)
 | |
| 		*(.data.efi_runtime*)
 | |
|                 __efi_runtime_stop = .;
 | |
| 	}
 | |
| 
 | |
| 	.text_rest :
 | |
| 	{
 | |
| 		*(.text*)
 | |
| 	}
 | |
| 
 | |
| #ifdef CONFIG_ARMV8_PSCI
 | |
| 	.__secure_start :
 | |
| #ifndef CONFIG_ARMV8_SECURE_BASE
 | |
| 		ALIGN(CONSTANT(COMMONPAGESIZE))
 | |
| #endif
 | |
| 	{
 | |
| 		KEEP(*(.__secure_start))
 | |
| 	}
 | |
| 
 | |
| #ifndef CONFIG_ARMV8_SECURE_BASE
 | |
| #define CONFIG_ARMV8_SECURE_BASE
 | |
| #define __ARMV8_PSCI_STACK_IN_RAM
 | |
| #endif
 | |
| 	.secure_text CONFIG_ARMV8_SECURE_BASE :
 | |
| 		AT(ADDR(.__secure_start) + SIZEOF(.__secure_start))
 | |
| 	{
 | |
| 		*(._secure.text)
 | |
| 		. = ALIGN(8);
 | |
| 		__secure_svc_tbl_start = .;
 | |
| 		KEEP(*(._secure_svc_tbl_entries))
 | |
| 		__secure_svc_tbl_end = .;
 | |
| 	}
 | |
| 
 | |
| 	.secure_data : AT(LOADADDR(.secure_text) + SIZEOF(.secure_text))
 | |
| 	{
 | |
| 		*(._secure.data)
 | |
| 	}
 | |
| 
 | |
| 	.secure_stack ALIGN(ADDR(.secure_data) + SIZEOF(.secure_data),
 | |
| 			    CONSTANT(COMMONPAGESIZE)) (NOLOAD) :
 | |
| #ifdef __ARMV8_PSCI_STACK_IN_RAM
 | |
| 		AT(ADDR(.secure_stack))
 | |
| #else
 | |
| 		AT(LOADADDR(.secure_data) + SIZEOF(.secure_data))
 | |
| #endif
 | |
| 	{
 | |
| 		KEEP(*(.__secure_stack_start))
 | |
| 
 | |
| 		. = . + CONFIG_ARMV8_PSCI_NR_CPUS * ARM_PSCI_STACK_SIZE;
 | |
| 
 | |
| 		. = ALIGN(CONSTANT(COMMONPAGESIZE));
 | |
| 
 | |
| 		KEEP(*(.__secure_stack_end))
 | |
| 	}
 | |
| 
 | |
| #ifndef __ARMV8_PSCI_STACK_IN_RAM
 | |
| 	. = LOADADDR(.secure_stack);
 | |
| #endif
 | |
| 
 | |
| 	.__secure_end : AT(ADDR(.__secure_end)) {
 | |
| 		KEEP(*(.__secure_end))
 | |
| 		LONG(0x1d1071c);	/* Must output something to reset LMA */
 | |
| 	}
 | |
| #endif
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 	.rodata : { *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) }
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 	.data : {
 | |
| 		*(.data*)
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 
 | |
| 	. = .;
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 	.u_boot_list : {
 | |
| 		KEEP(*(SORT(.u_boot_list*)));
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 
 | |
| 	.efi_runtime_rel : {
 | |
|                 __efi_runtime_rel_start = .;
 | |
| 		*(.rel*.efi_runtime)
 | |
| 		*(.rel*.efi_runtime.*)
 | |
|                 __efi_runtime_rel_stop = .;
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 
 | |
| 	.image_copy_end :
 | |
| 	{
 | |
| 		*(.__image_copy_end)
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 
 | |
| 	.rel_dyn_start :
 | |
| 	{
 | |
| 		*(.__rel_dyn_start)
 | |
| 	}
 | |
| 
 | |
| 	.rela.dyn : {
 | |
| 		*(.rela*)
 | |
| 	}
 | |
| 
 | |
| 	.rel_dyn_end :
 | |
| 	{
 | |
| 		*(.__rel_dyn_end)
 | |
| 	}
 | |
| 
 | |
| 	_end = .;
 | |
| 
 | |
| 	. = ALIGN(8);
 | |
| 
 | |
| 	.bss_start : {
 | |
| 		KEEP(*(.__bss_start));
 | |
| 	}
 | |
| 
 | |
| 	.bss : {
 | |
| 		*(.bss*)
 | |
| 		 . = ALIGN(8);
 | |
| 	}
 | |
| 
 | |
| 	.bss_end : {
 | |
| 		KEEP(*(.__bss_end));
 | |
| 	}
 | |
| 
 | |
| 	/DISCARD/ : { *(.dynsym) }
 | |
| 	/DISCARD/ : { *(.dynstr*) }
 | |
| 	/DISCARD/ : { *(.dynamic*) }
 | |
| 	/DISCARD/ : { *(.plt*) }
 | |
| 	/DISCARD/ : { *(.interp*) }
 | |
| 	/DISCARD/ : { *(.gnu*) }
 | |
| 
 | |
| #ifdef CONFIG_LINUX_KERNEL_IMAGE_HEADER
 | |
| #include "linux-kernel-image-header-vars.h"
 | |
| #endif
 | |
| }
 |