diff options
Diffstat (limited to 'common')
| -rw-r--r-- | common/cmd_bootm.c | 12 | ||||
| -rw-r--r-- | common/cmd_ximg.c | 5 | 
2 files changed, 10 insertions, 7 deletions
| diff --git a/common/cmd_bootm.c b/common/cmd_bootm.c index 1685c14a526..b07b0f48b20 100644 --- a/common/cmd_bootm.c +++ b/common/cmd_bootm.c @@ -368,7 +368,7 @@ static int bootm_load_os(bootm_headers_t *images, unsigned long *load_end,  	const char *type_name = genimg_get_type_name(os.type); -	load_buf = map_sysmem(load, image_len); +	load_buf = map_sysmem(load, unc_len);  	image_buf = map_sysmem(image_start, image_len);  	switch (comp) {  	case IH_COMP_NONE: @@ -436,11 +436,12 @@ static int bootm_load_os(bootm_headers_t *images, unsigned long *load_end,  	}  #endif /* CONFIG_LZMA */  #ifdef CONFIG_LZO -	case IH_COMP_LZO: +	case IH_COMP_LZO: { +		size_t size; +  		printf("   Uncompressing %s ... ", type_name); -		ret = lzop_decompress(image_buf, image_len, load_buf, -				      &unc_len); +		ret = lzop_decompress(image_buf, image_len, load_buf, &size);  		if (ret != LZO_E_OK) {  			printf("LZO: uncompress or overwrite error %d "  			      "- must RESET board to recover\n", ret); @@ -449,8 +450,9 @@ static int bootm_load_os(bootm_headers_t *images, unsigned long *load_end,  			return BOOTM_ERR_RESET;  		} -		*load_end = load + unc_len; +		*load_end = load + size;  		break; +	}  #endif /* CONFIG_LZO */  	default:  		printf("Unimplemented compression type %d\n", comp); diff --git a/common/cmd_ximg.c b/common/cmd_ximg.c index b439be3d088..65a8319662f 100644 --- a/common/cmd_ximg.c +++ b/common/cmd_ximg.c @@ -20,6 +20,7 @@  #include <bzlib.h>  #endif  #include <asm/byteorder.h> +#include <asm/io.h>  #ifndef CONFIG_SYS_XIMG_LEN  /* use 8MByte as default max gunzip size */ @@ -34,7 +35,7 @@ do_imgextract(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])  	ulong		data, len, count;  	int		verify;  	int		part = 0; -	image_header_t	*hdr; +	image_header_t	*hdr = NULL;  #if defined(CONFIG_FIT)  	const char	*uname = NULL;  	const void*	fit_hdr; @@ -222,7 +223,7 @@ do_imgextract(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])  				 * which requires at most 2300 KB of memory.  				 */  				i = BZ2_bzBuffToBuffDecompress( -					(char *)ntohl(hdr->ih_load), +					map_sysmem(ntohl(hdr->ih_load), 0),  					&unc_len, (char *)data, len,  					CONFIG_SYS_MALLOC_LEN < (4096 * 1024),  					0); | 
