s390/decompressor: fix initrd corruption caused by bss clear
authorMarcelo Henrique Cerri <marcelo.cerri@canonical.com>
Mon, 13 Mar 2017 15:14:58 +0000 (12:14 -0300)
committerBen Hutchings <ben@decadent.org.uk>
Tue, 18 Jul 2017 17:38:36 +0000 (18:38 +0100)
commitdeed5bc137d0cc561d537b9c018cd1fbe7498f0a
tree7198a75ec2ef157dc4651bfb4d22c62dcf84b3e8
parentd940902921d277f53338dddd5068840893e9b372
s390/decompressor: fix initrd corruption caused by bss clear

commit d82c0d12c92705ef468683c9b7a8298dd61ed191 upstream.

Reorder the operations in decompress_kernel() to ensure initrd is moved
to a safe location before the bss section is zeroed.

During decompression bss can overlap with the initrd and this can
corrupt the initrd contents depending on the size of the compressed
kernel (which affects where the initrd is placed by the bootloader) and
the size of the bss section of the decompressor.

Also use the correct initrd size when checking for overlaps with
parmblock.

Fixes: 06c0dd72aea3 ([S390] fix boot failures with compressed kernels)
Reviewed-by: Joy Latten <joy.latten@canonical.com>
Reviewed-by: Vineetha HariPai <vineetha.hari.pai@canonical.com>
Signed-off-by: Marcelo Henrique Cerri <marcelo.cerri@canonical.com>
Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
arch/s390/boot/compressed/misc.c