diff options
Diffstat (limited to 'arch/arm/boot/compressed')
| -rw-r--r-- | arch/arm/boot/compressed/.gitignore | 1 | ||||
| -rw-r--r-- | arch/arm/boot/compressed/Makefile | 5 | ||||
| -rw-r--r-- | arch/arm/boot/compressed/atags_to_fdt.c | 44 | ||||
| -rw-r--r-- | arch/arm/boot/compressed/decompress.c | 4 | ||||
| -rw-r--r-- | arch/arm/boot/compressed/head-shmobile.S | 21 | ||||
| -rw-r--r-- | arch/arm/boot/compressed/head.S | 40 | ||||
| -rw-r--r-- | arch/arm/boot/compressed/piggy.lz4.S | 6 | 
7 files changed, 84 insertions, 37 deletions
| diff --git a/arch/arm/boot/compressed/.gitignore b/arch/arm/boot/compressed/.gitignore index f79a08efe00..47279aa96a6 100644 --- a/arch/arm/boot/compressed/.gitignore +++ b/arch/arm/boot/compressed/.gitignore @@ -6,6 +6,7 @@ piggy.gzip  piggy.lzo  piggy.lzma  piggy.xzkern +piggy.lz4  vmlinux  vmlinux.lds diff --git a/arch/arm/boot/compressed/Makefile b/arch/arm/boot/compressed/Makefile index 120b83bfde2..7ac1610252b 100644 --- a/arch/arm/boot/compressed/Makefile +++ b/arch/arm/boot/compressed/Makefile @@ -27,7 +27,7 @@ OBJS	+= misc.o decompress.o  ifeq ($(CONFIG_DEBUG_UNCOMPRESS),y)  OBJS	+= debug.o  endif -FONTC	= $(srctree)/drivers/video/console/font_acorn_8x8.c +FONTC	= $(srctree)/lib/fonts/font_acorn_8x8.c  # string library code (-Os is enforced to keep it much smaller)  OBJS		+= string.o @@ -91,6 +91,7 @@ suffix_$(CONFIG_KERNEL_GZIP) = gzip  suffix_$(CONFIG_KERNEL_LZO)  = lzo  suffix_$(CONFIG_KERNEL_LZMA) = lzma  suffix_$(CONFIG_KERNEL_XZ)   = xzkern +suffix_$(CONFIG_KERNEL_LZ4)  = lz4  # Borrowed libfdt files for the ATAG compatibility mode @@ -115,7 +116,7 @@ targets       := vmlinux vmlinux.lds \  		 font.o font.c head.o misc.o $(OBJS)  # Make sure files are removed during clean -extra-y       += piggy.gzip piggy.lzo piggy.lzma piggy.xzkern \ +extra-y       += piggy.gzip piggy.lzo piggy.lzma piggy.xzkern piggy.lz4 \  		 lib1funcs.S ashldi3.S $(libfdt) $(libfdt_hdrs) \  		 hyp-stub.S diff --git a/arch/arm/boot/compressed/atags_to_fdt.c b/arch/arm/boot/compressed/atags_to_fdt.c index aabc02a6848..d1153c8a765 100644 --- a/arch/arm/boot/compressed/atags_to_fdt.c +++ b/arch/arm/boot/compressed/atags_to_fdt.c @@ -53,6 +53,17 @@ static const void *getprop(const void *fdt, const char *node_path,  	return fdt_getprop(fdt, offset, property, len);  } +static uint32_t get_cell_size(const void *fdt) +{ +	int len; +	uint32_t cell_size = 1; +	const uint32_t *size_len =  getprop(fdt, "/", "#size-cells", &len); + +	if (size_len) +		cell_size = fdt32_to_cpu(*size_len); +	return cell_size; +} +  static void merge_fdt_bootargs(void *fdt, const char *fdt_cmdline)  {  	char cmdline[COMMAND_LINE_SIZE]; @@ -95,9 +106,11 @@ static void merge_fdt_bootargs(void *fdt, const char *fdt_cmdline)  int atags_to_fdt(void *atag_list, void *fdt, int total_space)  {  	struct tag *atag = atag_list; -	uint32_t mem_reg_property[2 * NR_BANKS]; +	/* In the case of 64 bits memory size, need to reserve 2 cells for +	 * address and size for each bank */ +	uint32_t mem_reg_property[2 * 2 * NR_BANKS];  	int memcount = 0; -	int ret; +	int ret, memsize;  	/* make sure we've got an aligned pointer */  	if ((u32)atag_list & 0x3) @@ -137,8 +150,25 @@ int atags_to_fdt(void *atag_list, void *fdt, int total_space)  				continue;  			if (!atag->u.mem.size)  				continue; -			mem_reg_property[memcount++] = cpu_to_fdt32(atag->u.mem.start); -			mem_reg_property[memcount++] = cpu_to_fdt32(atag->u.mem.size); +			memsize = get_cell_size(fdt); + +			if (memsize == 2) { +				/* if memsize is 2, that means that +				 * each data needs 2 cells of 32 bits, +				 * so the data are 64 bits */ +				uint64_t *mem_reg_prop64 = +					(uint64_t *)mem_reg_property; +				mem_reg_prop64[memcount++] = +					cpu_to_fdt64(atag->u.mem.start); +				mem_reg_prop64[memcount++] = +					cpu_to_fdt64(atag->u.mem.size); +			} else { +				mem_reg_property[memcount++] = +					cpu_to_fdt32(atag->u.mem.start); +				mem_reg_property[memcount++] = +					cpu_to_fdt32(atag->u.mem.size); +			} +  		} else if (atag->hdr.tag == ATAG_INITRD2) {  			uint32_t initrd_start, initrd_size;  			initrd_start = atag->u.initrd.start; @@ -150,8 +180,10 @@ int atags_to_fdt(void *atag_list, void *fdt, int total_space)  		}  	} -	if (memcount) -		setprop(fdt, "/memory", "reg", mem_reg_property, 4*memcount); +	if (memcount) { +		setprop(fdt, "/memory", "reg", mem_reg_property, +			4 * memcount * memsize); +	}  	return fdt_pack(fdt);  } diff --git a/arch/arm/boot/compressed/decompress.c b/arch/arm/boot/compressed/decompress.c index 24b0475cb8b..bd245d34952 100644 --- a/arch/arm/boot/compressed/decompress.c +++ b/arch/arm/boot/compressed/decompress.c @@ -51,6 +51,10 @@ extern char * strstr(const char * s1, const char *s2);  #include "../../../../lib/decompress_unxz.c"  #endif +#ifdef CONFIG_KERNEL_LZ4 +#include "../../../../lib/decompress_unlz4.c" +#endif +  int do_decompress(u8 *input, int len, u8 *output, void (*error)(char *x))  {  	return decompress(input, len, NULL, NULL, output, NULL, error); diff --git a/arch/arm/boot/compressed/head-shmobile.S b/arch/arm/boot/compressed/head-shmobile.S index fe3719b516f..e2d636336b7 100644 --- a/arch/arm/boot/compressed/head-shmobile.S +++ b/arch/arm/boot/compressed/head-shmobile.S @@ -46,7 +46,7 @@ __image_start:  __image_end:  	.long	_got_end  __load_base: -	.long	CONFIG_MEMORY_START + 0x02000000 @ Load at 32Mb into SDRAM +	.long	MEMORY_START + 0x02000000 @ Load at 32Mb into SDRAM  __loaded:  	.long	__continue  	.align @@ -55,26 +55,9 @@ __tmp_stack:  __continue:  #endif /* CONFIG_ZBOOT_ROM_MMC || CONFIG_ZBOOT_ROM_SH_MOBILE_SDHI */ -	b	1f -__atags:@ tag #1 -	.long	12			@ tag->hdr.size = tag_size(tag_core); -	.long	0x54410001		@ tag->hdr.tag = ATAG_CORE; -	.long   0			@ tag->u.core.flags = 0; -	.long	0			@ tag->u.core.pagesize = 0; -	.long	0			@ tag->u.core.rootdev = 0; -	@ tag #2 -	.long	8			@ tag->hdr.size = tag_size(tag_mem32); -	.long	0x54410002		@ tag->hdr.tag = ATAG_MEM; -	.long	CONFIG_MEMORY_SIZE	@ tag->u.mem.size = CONFIG_MEMORY_SIZE; -	.long	CONFIG_MEMORY_START	@ @ tag->u.mem.start = CONFIG_MEMORY_START; -	@ tag #3 -	.long	0			@ tag->hdr.size = 0 -	.long	0			@ tag->hdr.tag = ATAG_NONE; -1: -  	/* Set board ID necessary for boot */  	ldr	r7, 1f				@ Set machine type register -	adr	r8, __atags			@ Set atag register +	mov	r8, #0				@ pass null pointer as atag  	b	2f  1 :	.long MACH_TYPE diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S index 032a8d98714..75189f13cf5 100644 --- a/arch/arm/boot/compressed/head.S +++ b/arch/arm/boot/compressed/head.S @@ -142,7 +142,6 @@ start:  		mov	r7, r1			@ save architecture ID  		mov	r8, r2			@ save atags pointer -#ifndef __ARM_ARCH_2__  		/*  		 * Booting from Angel - need to enter SVC mode and disable  		 * FIQs/IRQs (numeric definitions from angel arm.h source). @@ -158,10 +157,6 @@ not_angel:  		safe_svcmode_maskall r0  		msr	spsr_cxsf, r9		@ Save the CPU boot mode in  						@ SPSR -#else -		teqp	pc, #0x0c000003		@ turn off interrupts -#endif -  		/*  		 * Note that some cache flushing and other stuff may  		 * be needed here - is there an Angel SWI call for this? @@ -183,7 +178,19 @@ not_angel:  		ldr	r4, =zreladdr  #endif -		bl	cache_on +		/* +		 * Set up a page table only if it won't overwrite ourself. +		 * That means r4 < pc && r4 - 16k page directory > &_end. +		 * Given that r4 > &_end is most unfrequent, we add a rough +		 * additional 1MB of room for a possible appended DTB. +		 */ +		mov	r0, pc +		cmp	r0, r4 +		ldrcc	r0, LC0+32 +		addcc	r0, r0, pc +		cmpcc	r4, r0 +		orrcc	r4, r4, #1		@ remember we skipped cache_on +		blcs	cache_on  restart:	adr	r0, LC0  		ldmia	r0, {r1, r2, r3, r6, r10, r11, r12} @@ -229,7 +236,7 @@ restart:	adr	r0, LC0   *   r0  = delta   *   r2  = BSS start   *   r3  = BSS end - *   r4  = final kernel address + *   r4  = final kernel address (possibly with LSB set)   *   r5  = appended dtb size (still unknown)   *   r6  = _edata   *   r7  = architecture ID @@ -277,6 +284,7 @@ restart:	adr	r0, LC0  		 */  		cmp	r0, #1  		sub	r0, r4, #TEXT_OFFSET +		bic	r0, r0, #1  		add	r0, r0, #0x100  		mov	r1, r6  		sub	r2, sp, r6 @@ -323,12 +331,13 @@ dtb_check_done:  /*   * Check to see if we will overwrite ourselves. - *   r4  = final kernel address + *   r4  = final kernel address (possibly with LSB set)   *   r9  = size of decompressed image   *   r10 = end of this image, including  bss/stack/malloc space if non XIP   * We basically want:   *   r4 - 16k page directory >= r10 -> OK   *   r4 + image length <= address of wont_overwrite -> OK + * Note: the possible LSB in r4 is harmless here.   */  		add	r10, r10, #16384  		cmp	r4, r10 @@ -390,7 +399,8 @@ dtb_check_done:  		add	sp, sp, r6  #endif -		bl	cache_clean_flush +		tst	r4, #1 +		bleq	cache_clean_flush  		adr	r0, BSYM(restart)  		add	r0, r0, r6 @@ -402,7 +412,7 @@ wont_overwrite:   *   r0  = delta   *   r2  = BSS start   *   r3  = BSS end - *   r4  = kernel execution address + *   r4  = kernel execution address (possibly with LSB set)   *   r5  = appended dtb size (0 if not present)   *   r7  = architecture ID   *   r8  = atags pointer @@ -465,6 +475,15 @@ not_relocated:	mov	r0, #0  		cmp	r2, r3  		blo	1b +		/* +		 * Did we skip the cache setup earlier? +		 * That is indicated by the LSB in r4. +		 * Do it now if so. +		 */ +		tst	r4, #1 +		bic	r4, r4, #1 +		blne	cache_on +  /*   * The C runtime environment should now be setup sufficiently.   * Set up some pointers, and start decompressing. @@ -513,6 +532,7 @@ LC0:		.word	LC0			@ r1  		.word	_got_start		@ r11  		.word	_got_end		@ ip  		.word	.L_user_stack_end	@ sp +		.word	_end - restart + 16384 + 1024*1024  		.size	LC0, . - LC0  #ifdef CONFIG_ARCH_RPC diff --git a/arch/arm/boot/compressed/piggy.lz4.S b/arch/arm/boot/compressed/piggy.lz4.S new file mode 100644 index 00000000000..3d9a575618a --- /dev/null +++ b/arch/arm/boot/compressed/piggy.lz4.S @@ -0,0 +1,6 @@ +	.section .piggydata,#alloc +	.globl	input_data +input_data: +	.incbin	"arch/arm/boot/compressed/piggy.lz4" +	.globl	input_data_end +input_data_end: | 
