diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-02-11 18:03:54 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-02-11 18:03:54 -0800 | 
| commit | 6b00f7efb5303418c231994c91fb8239f5ada260 (patch) | |
| tree | 1daba87ccda34e632ea39dedc5055391c7e94bdc /drivers/firmware/efi/libstub/efi-stub-helper.c | |
| parent | b3d6524ff7956c5a898d51a18eaecb62a60a2b84 (diff) | |
| parent | d476d94f180af3f0fca77394651d4a98f4df1c54 (diff) | |
Merge tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux
Pull arm64 updates from Catalin Marinas:
 "arm64 updates for 3.20:
   - reimplementation of the virtual remapping of UEFI Runtime Services
     in a way that is stable across kexec
   - emulation of the "setend" instruction for 32-bit tasks (user
     endianness switching trapped in the kernel, SCTLR_EL1.E0E bit set
     accordingly)
   - compat_sys_call_table implemented in C (from asm) and made it a
     constant array together with sys_call_table
   - export CPU cache information via /sys (like other architectures)
   - DMA API implementation clean-up in preparation for IOMMU support
   - macros clean-up for KVM
   - dropped some unnecessary cache+tlb maintenance
   - CONFIG_ARM64_CPU_SUSPEND clean-up
   - defconfig update (CPU_IDLE)
  The EFI changes going via the arm64 tree have been acked by Matt
  Fleming.  There is also a patch adding sys_*stat64 prototypes to
  include/linux/syscalls.h, acked by Andrew Morton"
* tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: (47 commits)
  arm64: compat: Remove incorrect comment in compat_siginfo
  arm64: Fix section mismatch on alloc_init_p[mu]d()
  arm64: Avoid breakage caused by .altmacro in fpsimd save/restore macros
  arm64: mm: use *_sect to check for section maps
  arm64: drop unnecessary cache+tlb maintenance
  arm64:mm: free the useless initial page table
  arm64: Enable CPU_IDLE in defconfig
  arm64: kernel: remove ARM64_CPU_SUSPEND config option
  arm64: make sys_call_table const
  arm64: Remove asm/syscalls.h
  arm64: Implement the compat_sys_call_table in C
  syscalls: Declare sys_*stat64 prototypes if __ARCH_WANT_(COMPAT_)STAT64
  compat: Declare compat_sys_sigpending and compat_sys_sigprocmask prototypes
  arm64: uapi: expose our struct ucontext to the uapi headers
  smp, ARM64: Kill SMP single function call interrupt
  arm64: Emulate SETEND for AArch32 tasks
  arm64: Consolidate hotplug notifier for instruction emulation
  arm64: Track system support for mixed endian EL0
  arm64: implement generic IOMMU configuration
  arm64: Combine coherent and non-coherent swiotlb dma_ops
  ...
Diffstat (limited to 'drivers/firmware/efi/libstub/efi-stub-helper.c')
| -rw-r--r-- | drivers/firmware/efi/libstub/efi-stub-helper.c | 25 | 
1 files changed, 17 insertions, 8 deletions
| diff --git a/drivers/firmware/efi/libstub/efi-stub-helper.c b/drivers/firmware/efi/libstub/efi-stub-helper.c index d073e3946383..af5d63c7cc53 100644 --- a/drivers/firmware/efi/libstub/efi-stub-helper.c +++ b/drivers/firmware/efi/libstub/efi-stub-helper.c @@ -32,6 +32,15 @@  static unsigned long __chunk_size = EFI_READ_CHUNK_SIZE; +/* + * Allow the platform to override the allocation granularity: this allows + * systems that have the capability to run with a larger page size to deal + * with the allocations for initrd and fdt more efficiently. + */ +#ifndef EFI_ALLOC_ALIGN +#define EFI_ALLOC_ALIGN		EFI_PAGE_SIZE +#endif +  struct file_info {  	efi_file_handle_t *handle;  	u64 size; @@ -154,10 +163,10 @@ efi_status_t efi_high_alloc(efi_system_table_t *sys_table_arg,  	 * a specific address.  We are doing page-based allocations,  	 * so we must be aligned to a page.  	 */ -	if (align < EFI_PAGE_SIZE) -		align = EFI_PAGE_SIZE; +	if (align < EFI_ALLOC_ALIGN) +		align = EFI_ALLOC_ALIGN; -	nr_pages = round_up(size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE; +	nr_pages = round_up(size, EFI_ALLOC_ALIGN) / EFI_PAGE_SIZE;  again:  	for (i = 0; i < map_size / desc_size; i++) {  		efi_memory_desc_t *desc; @@ -239,10 +248,10 @@ efi_status_t efi_low_alloc(efi_system_table_t *sys_table_arg,  	 * a specific address.  We are doing page-based allocations,  	 * so we must be aligned to a page.  	 */ -	if (align < EFI_PAGE_SIZE) -		align = EFI_PAGE_SIZE; +	if (align < EFI_ALLOC_ALIGN) +		align = EFI_ALLOC_ALIGN; -	nr_pages = round_up(size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE; +	nr_pages = round_up(size, EFI_ALLOC_ALIGN) / EFI_PAGE_SIZE;  	for (i = 0; i < map_size / desc_size; i++) {  		efi_memory_desc_t *desc;  		unsigned long m = (unsigned long)map; @@ -296,7 +305,7 @@ void efi_free(efi_system_table_t *sys_table_arg, unsigned long size,  	if (!size)  		return; -	nr_pages = round_up(size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE; +	nr_pages = round_up(size, EFI_ALLOC_ALIGN) / EFI_PAGE_SIZE;  	efi_call_early(free_pages, addr, nr_pages);  } @@ -565,7 +574,7 @@ efi_status_t efi_relocate_kernel(efi_system_table_t *sys_table_arg,  	 * to the preferred address.  If that fails, allocate as low  	 * as possible while respecting the required alignment.  	 */ -	nr_pages = round_up(alloc_size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE; +	nr_pages = round_up(alloc_size, EFI_ALLOC_ALIGN) / EFI_PAGE_SIZE;  	status = efi_call_early(allocate_pages,  				EFI_ALLOCATE_ADDRESS, EFI_LOADER_DATA,  				nr_pages, &efi_addr); | 
