aboutsummaryrefslogtreecommitdiffstats
path: root/arch/s390/kernel/ipl.c
diff options
context:
space:
mode:
authorHeiko Carstens <heiko.carstens@de.ibm.com>2007-04-27 10:01:25 -0400
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2007-04-27 10:01:38 -0400
commit6fc321fd7dd91f0592f37503219196835314fbb7 (patch)
treed512811f8f6761608829c8df44a55a2ada074cdc /arch/s390/kernel/ipl.c
parent29c380f5f06d0c5a320b9bb6f8987065e7b81c91 (diff)
[S390] cio/ipl: Clean interface between cio and ipl code.
Clean interface between cio and ipl code, so Peter stops complaining. Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com> Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Diffstat (limited to 'arch/s390/kernel/ipl.c')
-rw-r--r--arch/s390/kernel/ipl.c23
1 files changed, 22 insertions, 1 deletions
diff --git a/arch/s390/kernel/ipl.c b/arch/s390/kernel/ipl.c
index f731185bf2bd..a83cf1fdd8f5 100644
--- a/arch/s390/kernel/ipl.c
+++ b/arch/s390/kernel/ipl.c
@@ -47,7 +47,7 @@ enum ipl_type {
47 * Must be in data section since the bss section 47 * Must be in data section since the bss section
48 * is not cleared when these are accessed. 48 * is not cleared when these are accessed.
49 */ 49 */
50u16 ipl_devno __attribute__((__section__(".data"))) = 0; 50static u16 ipl_devno __attribute__((__section__(".data"))) = 0;
51u32 ipl_flags __attribute__((__section__(".data"))) = 0; 51u32 ipl_flags __attribute__((__section__(".data"))) = 0;
52 52
53static char *ipl_type_str(enum ipl_type type) 53static char *ipl_type_str(enum ipl_type type)
@@ -1038,6 +1038,27 @@ static int __init s390_ipl_init(void)
1038 1038
1039__initcall(s390_ipl_init); 1039__initcall(s390_ipl_init);
1040 1040
1041void __init ipl_save_parameters(void)
1042{
1043 struct cio_iplinfo iplinfo;
1044 unsigned int *ipl_ptr;
1045 void *src, *dst;
1046
1047 if (cio_get_iplinfo(&iplinfo))
1048 return;
1049
1050 ipl_devno = iplinfo.devno;
1051 ipl_flags |= IPL_DEVNO_VALID;
1052 if (!iplinfo.is_qdio)
1053 return;
1054 ipl_flags |= IPL_PARMBLOCK_VALID;
1055 ipl_ptr = (unsigned int *)__LC_IPL_PARMBLOCK_PTR;
1056 src = (void *)(unsigned long)*ipl_ptr;
1057 dst = (void *)IPL_PARMBLOCK_ORIGIN;
1058 memmove(dst, src, PAGE_SIZE);
1059 *ipl_ptr = IPL_PARMBLOCK_ORIGIN;
1060}
1061
1041static LIST_HEAD(rcall); 1062static LIST_HEAD(rcall);
1042static DEFINE_MUTEX(rcall_mutex); 1063static DEFINE_MUTEX(rcall_mutex);
1043 1064