s390/mem_detect: rely on diag260() if sclp_early_get_memsize() fails
authorVasily Gorbik <gor@linux.ibm.com>
Fri, 27 Jan 2023 13:57:43 +0000 (14:57 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 10 Mar 2023 08:33:00 +0000 (09:33 +0100)
[ Upstream commit eb33f9eb304a4c18beb5ba6362eaa5c4beaf40d8 ]

In case sclp_early_get_memsize() fails but diag260() succeeds make sure
some sane value is returned. This error scenario is highly unlikely,
but this change makes system able to boot in such case.

Suggested-by: Alexander Gordeev <agordeev@linux.ibm.com>
Reviewed-by: Alexander Gordeev <agordeev@linux.ibm.com>
Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
Signed-off-by: Heiko Carstens <hca@linux.ibm.com>
Stable-dep-of: 22476f47b6b7 ("s390/boot: fix mem_detect extended area allocation")
Signed-off-by: Sasha Levin <sashal@kernel.org>
arch/s390/boot/mem_detect.c

index 0a5821ef4f1fd74390fbbebef5540d59c1f069a5..41792a3a5e36468c5ceec276dcdd908de8356827 100644 (file)
@@ -176,7 +176,7 @@ unsigned long detect_memory(void)
 
        if (!diag260()) {
                mem_detect.info_source = MEM_DETECT_DIAG260;
-               return max_physmem_end;
+               return max_physmem_end ?: get_mem_detect_end();
        }
 
        if (max_physmem_end) {