summaryrefslogtreecommitdiffstats
path: root/arch/s390/include/asm/setup.h
diff options
context:
space:
mode:
authorAlexander Egorenkov <egorenar@linux.ibm.com>2020-10-10 03:34:25 +0200
committerHeiko Carstens <hca@linux.ibm.com>2021-07-27 09:39:13 +0200
commit0029b4d19491cd83cfb85de0fa9ac1e175409377 (patch)
tree68604b1541e9aa5d142e994d6b70556b4acb3b7f /arch/s390/include/asm/setup.h
parents390/cio: remove unused include linux/spinlock.h from cio.h (diff)
downloadlinux-0029b4d19491cd83cfb85de0fa9ac1e175409377.tar.xz
linux-0029b4d19491cd83cfb85de0fa9ac1e175409377.zip
s390/sclp: use only one sclp early buffer to send commands
A buffer that can be used for communication with SCLP is required to lie below 2GB memory address. Therefore, both sclp_info_sccb and sclp_early_sccb must fulfill this requirement if passed directly to the sclp_early_cmd() function. Instead, use only sclp_early_sccb for communication with SCLP. This allows the buffer sclp_info_sccb to be placed anywhere in the memory address space and, therefore, simplifies the process of making the decompressor relocatable later on, one thing less to relocate. And make sure that the length of the new unified early SCLP buffer is no less than the length of the removed sclp_info_sccb buffer which might be larger than the length of the sclp_early_sccb buffer. Signed-off-by: Alexander Egorenkov <egorenar@linux.ibm.com> Acked-by: Heiko Carstens <hca@linux.ibm.com> Reviewed-by: Vasily Gorbik <gor@linux.ibm.com> Signed-off-by: Heiko Carstens <hca@linux.ibm.com>
Diffstat (limited to 'arch/s390/include/asm/setup.h')
-rw-r--r--arch/s390/include/asm/setup.h3
1 files changed, 2 insertions, 1 deletions
diff --git a/arch/s390/include/asm/setup.h b/arch/s390/include/asm/setup.h
index 3a77aa96d092..cf285f57579f 100644
--- a/arch/s390/include/asm/setup.h
+++ b/arch/s390/include/asm/setup.h
@@ -7,6 +7,7 @@
#define _ASM_S390_SETUP_H
#include <linux/bits.h>
+#include <asm/sclp.h>
#include <uapi/asm/setup.h>
#include <linux/build_bug.h>
@@ -14,7 +15,7 @@
#define EP_STRING "S390EP"
#define PARMAREA 0x10400
#define EARLY_SCCB_OFFSET 0x11000
-#define HEAD_END 0x12000
+#define HEAD_END (EARLY_SCCB_OFFSET + EXT_SCCB_READ_SCP)
/*
* Machine features detected in early.c