diff options
Diffstat (limited to 'arch/s390/boot/compressed/misc.c')
-rw-r--r-- | arch/s390/boot/compressed/misc.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/arch/s390/boot/compressed/misc.c b/arch/s390/boot/compressed/misc.c index 0851eb1e919e..028f23ea81d1 100644 --- a/arch/s390/boot/compressed/misc.c +++ b/arch/s390/boot/compressed/misc.c | |||
@@ -19,6 +19,7 @@ | |||
19 | #undef memset | 19 | #undef memset |
20 | #undef memcpy | 20 | #undef memcpy |
21 | #undef memmove | 21 | #undef memmove |
22 | #define memmove memmove | ||
22 | #define memzero(s, n) memset((s), 0, (n)) | 23 | #define memzero(s, n) memset((s), 0, (n)) |
23 | 24 | ||
24 | /* Symbols defined by linker scripts */ | 25 | /* Symbols defined by linker scripts */ |
@@ -54,6 +55,10 @@ static unsigned long free_mem_end_ptr; | |||
54 | #include "../../../../lib/decompress_unlzo.c" | 55 | #include "../../../../lib/decompress_unlzo.c" |
55 | #endif | 56 | #endif |
56 | 57 | ||
58 | #ifdef CONFIG_KERNEL_XZ | ||
59 | #include "../../../../lib/decompress_unxz.c" | ||
60 | #endif | ||
61 | |||
57 | extern _sclp_print_early(const char *); | 62 | extern _sclp_print_early(const char *); |
58 | 63 | ||
59 | int puts(const char *s) | 64 | int puts(const char *s) |
@@ -133,11 +138,12 @@ unsigned long decompress_kernel(void) | |||
133 | unsigned long output_addr; | 138 | unsigned long output_addr; |
134 | unsigned char *output; | 139 | unsigned char *output; |
135 | 140 | ||
136 | check_ipl_parmblock((void *) 0, (unsigned long) output + SZ__bss_start); | 141 | output_addr = ((unsigned long) &_end + HEAP_SIZE + 4095UL) & -4096UL; |
142 | check_ipl_parmblock((void *) 0, output_addr + SZ__bss_start); | ||
137 | memset(&_bss, 0, &_ebss - &_bss); | 143 | memset(&_bss, 0, &_ebss - &_bss); |
138 | free_mem_ptr = (unsigned long)&_end; | 144 | free_mem_ptr = (unsigned long)&_end; |
139 | free_mem_end_ptr = free_mem_ptr + HEAP_SIZE; | 145 | free_mem_end_ptr = free_mem_ptr + HEAP_SIZE; |
140 | output = (unsigned char *) ((free_mem_end_ptr + 4095UL) & -4096UL); | 146 | output = (unsigned char *) output_addr; |
141 | 147 | ||
142 | #ifdef CONFIG_BLK_DEV_INITRD | 148 | #ifdef CONFIG_BLK_DEV_INITRD |
143 | /* | 149 | /* |