diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /arch/x86/boot | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'arch/x86/boot')
| -rw-r--r-- | arch/x86/boot/compressed/Makefile | 6 | ||||
| -rw-r--r-- | arch/x86/boot/compressed/eboot.c | 22 | ||||
| -rw-r--r-- | arch/x86/boot/compressed/head_64.S | 2 | ||||
| -rw-r--r-- | arch/x86/boot/compressed/misc.c | 4 | ||||
| -rw-r--r-- | arch/x86/boot/tools/build.c | 1 | 
5 files changed, 28 insertions, 7 deletions
| diff --git a/arch/x86/boot/compressed/Makefile b/arch/x86/boot/compressed/Makefile index 5ef205c5f37..dcd90df10ab 100644 --- a/arch/x86/boot/compressed/Makefile +++ b/arch/x86/boot/compressed/Makefile @@ -4,7 +4,8 @@  # create a compressed vmlinux image from the original vmlinux  # -targets := vmlinux vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 vmlinux.bin.lzma vmlinux.bin.xz vmlinux.bin.lzo +targets := vmlinux vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 vmlinux.bin.lzma \ +	vmlinux.bin.xz vmlinux.bin.lzo vmlinux.bin.lz4  KBUILD_CFLAGS := -m$(BITS) -D__KERNEL__ $(LINUX_INCLUDE) -O2  KBUILD_CFLAGS += -fno-strict-aliasing -fPIC @@ -63,12 +64,15 @@ $(obj)/vmlinux.bin.xz: $(vmlinux.bin.all-y) FORCE  	$(call if_changed,xzkern)  $(obj)/vmlinux.bin.lzo: $(vmlinux.bin.all-y) FORCE  	$(call if_changed,lzo) +$(obj)/vmlinux.bin.lz4: $(vmlinux.bin.all-y) FORCE +	$(call if_changed,lz4)  suffix-$(CONFIG_KERNEL_GZIP)	:= gz  suffix-$(CONFIG_KERNEL_BZIP2)	:= bz2  suffix-$(CONFIG_KERNEL_LZMA)	:= lzma  suffix-$(CONFIG_KERNEL_XZ)	:= xz  suffix-$(CONFIG_KERNEL_LZO) 	:= lzo +suffix-$(CONFIG_KERNEL_LZ4) 	:= lz4  quiet_cmd_mkpiggy = MKPIGGY $@        cmd_mkpiggy = $(obj)/mkpiggy $< > $@ || ( rm -f $@ ; false ) diff --git a/arch/x86/boot/compressed/eboot.c b/arch/x86/boot/compressed/eboot.c index c205035a6b9..b7388a425f0 100644 --- a/arch/x86/boot/compressed/eboot.c +++ b/arch/x86/boot/compressed/eboot.c @@ -225,7 +225,7 @@ static void low_free(unsigned long size, unsigned long addr)  	unsigned long nr_pages;  	nr_pages = round_up(size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE; -	efi_call_phys2(sys_table->boottime->free_pages, addr, size); +	efi_call_phys2(sys_table->boottime->free_pages, addr, nr_pages);  }  static void find_bits(unsigned long mask, u8 *pos, u8 *size) @@ -992,18 +992,20 @@ static efi_status_t exit_boot(struct boot_params *boot_params,  	efi_memory_desc_t *mem_map;  	efi_status_t status;  	__u32 desc_version; +	bool called_exit = false;  	u8 nr_entries;  	int i;  	size = sizeof(*mem_map) * 32;  again: -	size += sizeof(*mem_map); +	size += sizeof(*mem_map) * 2;  	_size = size;  	status = low_alloc(size, 1, (unsigned long *)&mem_map);  	if (status != EFI_SUCCESS)  		return status; +get_map:  	status = efi_call_phys5(sys_table->boottime->get_memory_map, &size,  				mem_map, &key, &desc_size, &desc_version);  	if (status == EFI_BUFFER_TOO_SMALL) { @@ -1029,8 +1031,20 @@ again:  	/* Might as well exit boot services now */  	status = efi_call_phys2(sys_table->boottime->exit_boot_services,  				handle, key); -	if (status != EFI_SUCCESS) -		goto free_mem_map; +	if (status != EFI_SUCCESS) { +		/* +		 * ExitBootServices() will fail if any of the event +		 * handlers change the memory map. In which case, we +		 * must be prepared to retry, but only once so that +		 * we're guaranteed to exit on repeated failures instead +		 * of spinning forever. +		 */ +		if (called_exit) +			goto free_mem_map; + +		called_exit = true; +		goto get_map; +	}  	/* Historic? */  	boot_params->alt_mem_k = 32 * 1024; diff --git a/arch/x86/boot/compressed/head_64.S b/arch/x86/boot/compressed/head_64.S index 16f24e6dad7..06e71c2c16b 100644 --- a/arch/x86/boot/compressed/head_64.S +++ b/arch/x86/boot/compressed/head_64.S @@ -27,8 +27,6 @@  #include <linux/init.h>  #include <linux/linkage.h>  #include <asm/segment.h> -#include <asm/pgtable_types.h> -#include <asm/page_types.h>  #include <asm/boot.h>  #include <asm/msr.h>  #include <asm/processor-flags.h> diff --git a/arch/x86/boot/compressed/misc.c b/arch/x86/boot/compressed/misc.c index 7cb56c6ca35..0319c88290a 100644 --- a/arch/x86/boot/compressed/misc.c +++ b/arch/x86/boot/compressed/misc.c @@ -145,6 +145,10 @@ static int lines, cols;  #include "../../../../lib/decompress_unlzo.c"  #endif +#ifdef CONFIG_KERNEL_LZ4 +#include "../../../../lib/decompress_unlz4.c" +#endif +  static void scroll(void)  {  	int i; diff --git a/arch/x86/boot/tools/build.c b/arch/x86/boot/tools/build.c index 94c54465002..c941d6a8887 100644 --- a/arch/x86/boot/tools/build.c +++ b/arch/x86/boot/tools/build.c @@ -243,6 +243,7 @@ static void parse_zoffset(char *fname)  	c = fread(buf, 1, sizeof(buf) - 1, file);  	if (ferror(file))  		die("read-error on `zoffset.h'"); +	fclose(file);  	buf[c] = 0;  	p = (char *)buf; | 
