blob: f69f76b3447a0e685959ec43cf10f53ac99adb5c [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002 * S390 version
Heiko Carstensa53c8fa2012-07-20 11:15:04 +02003 * Copyright IBM Corp. 1999, 2010
Linus Torvalds1da177e2005-04-16 15:20:36 -07004 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07005#ifndef _ASM_S390_SETUP_H
6#define _ASM_S390_SETUP_H
7
David Howells9807f752012-10-09 09:47:31 +01008#include <uapi/asm/setup.h>
Hendrik Bruecknera0443fb2008-07-14 09:59:09 +02009
Heiko Carstens0defa3c2006-02-11 17:56:03 -080010
Linus Torvalds1da177e2005-04-16 15:20:36 -070011#define PARMAREA 0x10400
Heiko Carstens23d17422008-07-14 09:59:21 +020012#define MEMORY_CHUNKS 256
Linus Torvalds1da177e2005-04-16 15:20:36 -070013
14#ifndef __ASSEMBLY__
15
Heiko Carstenscbb870c2010-02-26 22:37:43 +010016#include <asm/lowcore.h>
17#include <asm/types.h>
18
Heiko Carstensf4815ac2012-05-23 16:24:51 +020019#ifndef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#define IPL_DEVICE (*(unsigned long *) (0x10404))
21#define INITRD_START (*(unsigned long *) (0x1040C))
22#define INITRD_SIZE (*(unsigned long *) (0x10414))
Michael Holzheu60a0c682011-10-30 15:16:40 +010023#define OLDMEM_BASE (*(unsigned long *) (0x1041C))
24#define OLDMEM_SIZE (*(unsigned long *) (0x10424))
Heiko Carstensf4815ac2012-05-23 16:24:51 +020025#else /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -070026#define IPL_DEVICE (*(unsigned long *) (0x10400))
27#define INITRD_START (*(unsigned long *) (0x10408))
28#define INITRD_SIZE (*(unsigned long *) (0x10410))
Michael Holzheu60a0c682011-10-30 15:16:40 +010029#define OLDMEM_BASE (*(unsigned long *) (0x10418))
30#define OLDMEM_SIZE (*(unsigned long *) (0x10420))
Heiko Carstensf4815ac2012-05-23 16:24:51 +020031#endif /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -070032#define COMMAND_LINE ((char *) (0x10480))
33
Heiko Carstens36a2bd42006-12-04 15:40:38 +010034#define CHUNK_READ_WRITE 0
35#define CHUNK_READ_ONLY 1
Michael Holzheu60a0c682011-10-30 15:16:40 +010036#define CHUNK_OLDMEM 4
37#define CHUNK_CRASHK 5
Heiko Carstens36a2bd42006-12-04 15:40:38 +010038
39struct mem_chunk {
40 unsigned long addr;
41 unsigned long size;
Heiko Carstens23d17422008-07-14 09:59:21 +020042 int type;
Heiko Carstens36a2bd42006-12-04 15:40:38 +010043};
44
45extern struct mem_chunk memory_chunk[];
Michael Holzheu411ed322007-04-27 16:01:49 +020046extern unsigned long real_memory_size;
Heiko Carstens23d75d92009-02-19 15:19:01 +010047extern int memory_end_set;
48extern unsigned long memory_end;
Heiko Carstens36a2bd42006-12-04 15:40:38 +010049
Heiko Carstens23d17422008-07-14 09:59:21 +020050void detect_memory_layout(struct mem_chunk chunk[]);
Michael Holzheu60a0c682011-10-30 15:16:40 +010051void create_mem_hole(struct mem_chunk memory_chunk[], unsigned long addr,
52 unsigned long size, int type);
Heiko Carstens23d17422008-07-14 09:59:21 +020053
Martin Schwidefskyb11b5332009-12-07 12:51:43 +010054#define PRIMARY_SPACE_MODE 0
55#define ACCESS_REGISTER_MODE 1
56#define SECONDARY_SPACE_MODE 2
57#define HOME_SPACE_MODE 3
Gerald Schaeferc1821c22007-02-05 21:18:17 +010058
Heiko Carstensd1b0d842012-09-02 11:02:23 +020059extern unsigned int s390_user_mode;
Gerald Schaeferc1821c22007-02-05 21:18:17 +010060
Linus Torvalds1da177e2005-04-16 15:20:36 -070061/*
62 * Machine features detected in head.S
63 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070064
Heiko Carstens2e5061e2008-04-30 13:38:45 +020065#define MACHINE_FLAG_VM (1UL << 0)
66#define MACHINE_FLAG_IEEE (1UL << 1)
Heiko Carstens2e5061e2008-04-30 13:38:45 +020067#define MACHINE_FLAG_CSP (1UL << 3)
68#define MACHINE_FLAG_MVPG (1UL << 4)
69#define MACHINE_FLAG_DIAG44 (1UL << 5)
70#define MACHINE_FLAG_IDTE (1UL << 6)
71#define MACHINE_FLAG_DIAG9C (1UL << 7)
72#define MACHINE_FLAG_MVCOS (1UL << 8)
73#define MACHINE_FLAG_KVM (1UL << 9)
Heiko Carstens3c7ef082012-09-28 15:06:41 +020074#define MACHINE_FLAG_EDAT1 (1UL << 10)
Heiko Carstens85e9d0e2012-09-27 10:45:06 +020075#define MACHINE_FLAG_EDAT2 (1UL << 11)
Martin Schwidefsky27d71602010-02-26 22:37:38 +010076#define MACHINE_FLAG_LPAR (1UL << 12)
Carsten Ottecd3b70f2010-05-17 10:00:04 +020077#define MACHINE_FLAG_SPP (1UL << 13)
Heiko Carstens9186d7a2010-10-25 16:10:52 +020078#define MACHINE_FLAG_TOPOLOGY (1UL << 14)
Martin Schwidefskyd35339a2012-07-31 11:03:04 +020079#define MACHINE_FLAG_TE (1UL << 15)
Gerald Schaefer1ae1c1d2012-10-08 16:30:24 -070080#define MACHINE_FLAG_RRBM (1UL << 16)
Heiko Carstens2e5061e2008-04-30 13:38:45 +020081
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020082#define MACHINE_IS_VM (S390_lowcore.machine_flags & MACHINE_FLAG_VM)
83#define MACHINE_IS_KVM (S390_lowcore.machine_flags & MACHINE_FLAG_KVM)
Martin Schwidefsky27d71602010-02-26 22:37:38 +010084#define MACHINE_IS_LPAR (S390_lowcore.machine_flags & MACHINE_FLAG_LPAR)
85
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020086#define MACHINE_HAS_DIAG9C (S390_lowcore.machine_flags & MACHINE_FLAG_DIAG9C)
Heiko Carstens3c7ef082012-09-28 15:06:41 +020087#define MACHINE_HAS_PFMF MACHINE_HAS_EDAT1
88#define MACHINE_HAS_HPAGE MACHINE_HAS_EDAT1
Linus Torvalds1da177e2005-04-16 15:20:36 -070089
Heiko Carstensf4815ac2012-05-23 16:24:51 +020090#ifndef CONFIG_64BIT
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020091#define MACHINE_HAS_IEEE (S390_lowcore.machine_flags & MACHINE_FLAG_IEEE)
92#define MACHINE_HAS_CSP (S390_lowcore.machine_flags & MACHINE_FLAG_CSP)
Heiko Carstens2e5061e2008-04-30 13:38:45 +020093#define MACHINE_HAS_IDTE (0)
Heiko Carstensabdba612006-07-12 16:39:58 +020094#define MACHINE_HAS_DIAG44 (1)
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020095#define MACHINE_HAS_MVPG (S390_lowcore.machine_flags & MACHINE_FLAG_MVPG)
Gerald Schaefer6c2a9e62006-09-20 15:59:44 +020096#define MACHINE_HAS_MVCOS (0)
Heiko Carstens3c7ef082012-09-28 15:06:41 +020097#define MACHINE_HAS_EDAT1 (0)
Heiko Carstens85e9d0e2012-09-27 10:45:06 +020098#define MACHINE_HAS_EDAT2 (0)
Carsten Ottecd3b70f2010-05-17 10:00:04 +020099#define MACHINE_HAS_SPP (0)
Heiko Carstens9186d7a2010-10-25 16:10:52 +0200100#define MACHINE_HAS_TOPOLOGY (0)
Gerald Schaefer1ae1c1d2012-10-08 16:30:24 -0700101#define MACHINE_HAS_TE (0)
102#define MACHINE_HAS_RRBM (0)
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200103#else /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104#define MACHINE_HAS_IEEE (1)
105#define MACHINE_HAS_CSP (1)
Christian Ehrhardt25097bf2009-04-14 15:36:16 +0200106#define MACHINE_HAS_IDTE (S390_lowcore.machine_flags & MACHINE_FLAG_IDTE)
107#define MACHINE_HAS_DIAG44 (S390_lowcore.machine_flags & MACHINE_FLAG_DIAG44)
Heiko Carstens2e5061e2008-04-30 13:38:45 +0200108#define MACHINE_HAS_MVPG (1)
Christian Ehrhardt25097bf2009-04-14 15:36:16 +0200109#define MACHINE_HAS_MVCOS (S390_lowcore.machine_flags & MACHINE_FLAG_MVCOS)
Heiko Carstens3c7ef082012-09-28 15:06:41 +0200110#define MACHINE_HAS_EDAT1 (S390_lowcore.machine_flags & MACHINE_FLAG_EDAT1)
Heiko Carstens85e9d0e2012-09-27 10:45:06 +0200111#define MACHINE_HAS_EDAT2 (S390_lowcore.machine_flags & MACHINE_FLAG_EDAT2)
Carsten Ottecd3b70f2010-05-17 10:00:04 +0200112#define MACHINE_HAS_SPP (S390_lowcore.machine_flags & MACHINE_FLAG_SPP)
Heiko Carstens9186d7a2010-10-25 16:10:52 +0200113#define MACHINE_HAS_TOPOLOGY (S390_lowcore.machine_flags & MACHINE_FLAG_TOPOLOGY)
Martin Schwidefskyd35339a2012-07-31 11:03:04 +0200114#define MACHINE_HAS_TE (S390_lowcore.machine_flags & MACHINE_FLAG_TE)
Gerald Schaefer1ae1c1d2012-10-08 16:30:24 -0700115#define MACHINE_HAS_RRBM (S390_lowcore.machine_flags & MACHINE_FLAG_RRBM)
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200116#endif /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117
Michael Holzheu411ed322007-04-27 16:01:49 +0200118#define ZFCPDUMP_HSA_SIZE (32UL<<20)
Michael Holzheu60a0c682011-10-30 15:16:40 +0100119#define ZFCPDUMP_HSA_SIZE_MAX (64UL<<20)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120
121/*
122 * Console mode. Override with conmode=
123 */
124extern unsigned int console_mode;
125extern unsigned int console_devno;
126extern unsigned int console_irq;
127
Heiko Carstens2b67fc42007-02-05 21:16:47 +0100128extern char vmhalt_cmd[];
129extern char vmpoff_cmd[];
130
Linus Torvalds1da177e2005-04-16 15:20:36 -0700131#define CONSOLE_IS_UNDEFINED (console_mode == 0)
132#define CONSOLE_IS_SCLP (console_mode == 1)
133#define CONSOLE_IS_3215 (console_mode == 2)
134#define CONSOLE_IS_3270 (console_mode == 3)
135#define SET_CONSOLE_SCLP do { console_mode = 1; } while (0)
136#define SET_CONSOLE_3215 do { console_mode = 2; } while (0)
137#define SET_CONSOLE_3270 do { console_mode = 3; } while (0)
138
Hongjie Yangfe355b72007-02-05 21:18:24 +0100139#define NSS_NAME_SIZE 8
Hongjie Yangfe355b72007-02-05 21:18:24 +0100140extern char kernel_nss_name[];
141
David Howellsa0616cd2012-03-28 18:30:02 +0100142#ifdef CONFIG_PFAULT
143extern int pfault_init(void);
144extern void pfault_fini(void);
145#else /* CONFIG_PFAULT */
146#define pfault_init() ({-1;})
147#define pfault_fini() do { } while (0)
148#endif /* CONFIG_PFAULT */
149
150extern void cmma_init(void);
151
152extern void (*_machine_restart)(char *command);
153extern void (*_machine_halt)(void);
154extern void (*_machine_power_off)(void);
155
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800156#else /* __ASSEMBLY__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200158#ifndef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700159#define IPL_DEVICE 0x10404
160#define INITRD_START 0x1040C
161#define INITRD_SIZE 0x10414
Michael Holzheu60a0c682011-10-30 15:16:40 +0100162#define OLDMEM_BASE 0x1041C
163#define OLDMEM_SIZE 0x10424
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200164#else /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700165#define IPL_DEVICE 0x10400
166#define INITRD_START 0x10408
167#define INITRD_SIZE 0x10410
Michael Holzheu60a0c682011-10-30 15:16:40 +0100168#define OLDMEM_BASE 0x10418
169#define OLDMEM_SIZE 0x10420
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200170#endif /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700171#define COMMAND_LINE 0x10480
172
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800173#endif /* __ASSEMBLY__ */
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800174#endif /* _ASM_S390_SETUP_H */