blob: dbde7c2365779f1c229cb98755a48be7e438c8b4 [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
Linus Torvalds1da177e2005-04-16 15:20:36 -070012
13#ifndef __ASSEMBLY__
14
Heiko Carstenscbb870c2010-02-26 22:37:43 +010015#include <asm/lowcore.h>
16#include <asm/types.h>
17
Heiko Carstensf4815ac2012-05-23 16:24:51 +020018#ifndef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -070019#define IPL_DEVICE (*(unsigned long *) (0x10404))
20#define INITRD_START (*(unsigned long *) (0x1040C))
21#define INITRD_SIZE (*(unsigned long *) (0x10414))
Michael Holzheu60a0c682011-10-30 15:16:40 +010022#define OLDMEM_BASE (*(unsigned long *) (0x1041C))
23#define OLDMEM_SIZE (*(unsigned long *) (0x10424))
Heiko Carstensf4815ac2012-05-23 16:24:51 +020024#else /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -070025#define IPL_DEVICE (*(unsigned long *) (0x10400))
26#define INITRD_START (*(unsigned long *) (0x10408))
27#define INITRD_SIZE (*(unsigned long *) (0x10410))
Michael Holzheu60a0c682011-10-30 15:16:40 +010028#define OLDMEM_BASE (*(unsigned long *) (0x10418))
29#define OLDMEM_SIZE (*(unsigned long *) (0x10420))
Heiko Carstensf4815ac2012-05-23 16:24:51 +020030#endif /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -070031#define COMMAND_LINE ((char *) (0x10480))
32
Heiko Carstens23d75d92009-02-19 15:19:01 +010033extern int memory_end_set;
34extern unsigned long memory_end;
Philipp Hachtmann50be6342014-01-29 18:16:01 +010035extern unsigned long max_physmem_end;
Heiko Carstens36a2bd42006-12-04 15:40:38 +010036
Philipp Hachtmann50be6342014-01-29 18:16:01 +010037extern void detect_memory_memblock(void);
Heiko Carstens23d17422008-07-14 09:59:21 +020038
Linus Torvalds1da177e2005-04-16 15:20:36 -070039/*
40 * Machine features detected in head.S
41 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070042
Heiko Carstens2e5061e2008-04-30 13:38:45 +020043#define MACHINE_FLAG_VM (1UL << 0)
44#define MACHINE_FLAG_IEEE (1UL << 1)
Martin Schwidefskyabf09be2012-11-07 13:17:37 +010045#define MACHINE_FLAG_CSP (1UL << 2)
46#define MACHINE_FLAG_MVPG (1UL << 3)
47#define MACHINE_FLAG_DIAG44 (1UL << 4)
48#define MACHINE_FLAG_IDTE (1UL << 5)
49#define MACHINE_FLAG_DIAG9C (1UL << 6)
Martin Schwidefskyabf09be2012-11-07 13:17:37 +010050#define MACHINE_FLAG_KVM (1UL << 8)
51#define MACHINE_FLAG_ESOP (1UL << 9)
Heiko Carstens3c7ef082012-09-28 15:06:41 +020052#define MACHINE_FLAG_EDAT1 (1UL << 10)
Heiko Carstens85e9d0e2012-09-27 10:45:06 +020053#define MACHINE_FLAG_EDAT2 (1UL << 11)
Martin Schwidefsky27d71602010-02-26 22:37:38 +010054#define MACHINE_FLAG_LPAR (1UL << 12)
Hendrik Brueckner23d18e82013-02-11 18:11:09 +010055#define MACHINE_FLAG_LPP (1UL << 13)
Heiko Carstens9186d7a2010-10-25 16:10:52 +020056#define MACHINE_FLAG_TOPOLOGY (1UL << 14)
Martin Schwidefskyd35339a2012-07-31 11:03:04 +020057#define MACHINE_FLAG_TE (1UL << 15)
Martin Schwidefsky1b948d62014-04-03 13:55:01 +020058#define MACHINE_FLAG_TLB_LC (1UL << 17)
Heiko Carstens2e5061e2008-04-30 13:38:45 +020059
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020060#define MACHINE_IS_VM (S390_lowcore.machine_flags & MACHINE_FLAG_VM)
61#define MACHINE_IS_KVM (S390_lowcore.machine_flags & MACHINE_FLAG_KVM)
Martin Schwidefsky27d71602010-02-26 22:37:38 +010062#define MACHINE_IS_LPAR (S390_lowcore.machine_flags & MACHINE_FLAG_LPAR)
63
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020064#define MACHINE_HAS_DIAG9C (S390_lowcore.machine_flags & MACHINE_FLAG_DIAG9C)
Martin Schwidefskyabf09be2012-11-07 13:17:37 +010065#define MACHINE_HAS_ESOP (S390_lowcore.machine_flags & MACHINE_FLAG_ESOP)
Heiko Carstens3c7ef082012-09-28 15:06:41 +020066#define MACHINE_HAS_PFMF MACHINE_HAS_EDAT1
67#define MACHINE_HAS_HPAGE MACHINE_HAS_EDAT1
Linus Torvalds1da177e2005-04-16 15:20:36 -070068
Heiko Carstensf4815ac2012-05-23 16:24:51 +020069#ifndef CONFIG_64BIT
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020070#define MACHINE_HAS_IEEE (S390_lowcore.machine_flags & MACHINE_FLAG_IEEE)
71#define MACHINE_HAS_CSP (S390_lowcore.machine_flags & MACHINE_FLAG_CSP)
Heiko Carstens2e5061e2008-04-30 13:38:45 +020072#define MACHINE_HAS_IDTE (0)
Heiko Carstensabdba612006-07-12 16:39:58 +020073#define MACHINE_HAS_DIAG44 (1)
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020074#define MACHINE_HAS_MVPG (S390_lowcore.machine_flags & MACHINE_FLAG_MVPG)
Heiko Carstens3c7ef082012-09-28 15:06:41 +020075#define MACHINE_HAS_EDAT1 (0)
Heiko Carstens85e9d0e2012-09-27 10:45:06 +020076#define MACHINE_HAS_EDAT2 (0)
Hendrik Brueckner23d18e82013-02-11 18:11:09 +010077#define MACHINE_HAS_LPP (0)
Heiko Carstens9186d7a2010-10-25 16:10:52 +020078#define MACHINE_HAS_TOPOLOGY (0)
Gerald Schaefer1ae1c1d2012-10-08 16:30:24 -070079#define MACHINE_HAS_TE (0)
Martin Schwidefsky1b948d62014-04-03 13:55:01 +020080#define MACHINE_HAS_TLB_LC (0)
Heiko Carstensf4815ac2012-05-23 16:24:51 +020081#else /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -070082#define MACHINE_HAS_IEEE (1)
83#define MACHINE_HAS_CSP (1)
Christian Ehrhardt25097bf2009-04-14 15:36:16 +020084#define MACHINE_HAS_IDTE (S390_lowcore.machine_flags & MACHINE_FLAG_IDTE)
85#define MACHINE_HAS_DIAG44 (S390_lowcore.machine_flags & MACHINE_FLAG_DIAG44)
Heiko Carstens2e5061e2008-04-30 13:38:45 +020086#define MACHINE_HAS_MVPG (1)
Heiko Carstens3c7ef082012-09-28 15:06:41 +020087#define MACHINE_HAS_EDAT1 (S390_lowcore.machine_flags & MACHINE_FLAG_EDAT1)
Heiko Carstens85e9d0e2012-09-27 10:45:06 +020088#define MACHINE_HAS_EDAT2 (S390_lowcore.machine_flags & MACHINE_FLAG_EDAT2)
Hendrik Brueckner23d18e82013-02-11 18:11:09 +010089#define MACHINE_HAS_LPP (S390_lowcore.machine_flags & MACHINE_FLAG_LPP)
Heiko Carstens9186d7a2010-10-25 16:10:52 +020090#define MACHINE_HAS_TOPOLOGY (S390_lowcore.machine_flags & MACHINE_FLAG_TOPOLOGY)
Martin Schwidefskyd35339a2012-07-31 11:03:04 +020091#define MACHINE_HAS_TE (S390_lowcore.machine_flags & MACHINE_FLAG_TE)
Martin Schwidefsky1b948d62014-04-03 13:55:01 +020092#define MACHINE_HAS_TLB_LC (S390_lowcore.machine_flags & MACHINE_FLAG_TLB_LC)
Heiko Carstensf4815ac2012-05-23 16:24:51 +020093#endif /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -070094
Linus Torvalds1da177e2005-04-16 15:20:36 -070095/*
96 * Console mode. Override with conmode=
97 */
98extern unsigned int console_mode;
99extern unsigned int console_devno;
100extern unsigned int console_irq;
101
Heiko Carstens2b67fc42007-02-05 21:16:47 +0100102extern char vmhalt_cmd[];
103extern char vmpoff_cmd[];
104
Linus Torvalds1da177e2005-04-16 15:20:36 -0700105#define CONSOLE_IS_UNDEFINED (console_mode == 0)
106#define CONSOLE_IS_SCLP (console_mode == 1)
107#define CONSOLE_IS_3215 (console_mode == 2)
108#define CONSOLE_IS_3270 (console_mode == 3)
109#define SET_CONSOLE_SCLP do { console_mode = 1; } while (0)
110#define SET_CONSOLE_3215 do { console_mode = 2; } while (0)
111#define SET_CONSOLE_3270 do { console_mode = 3; } while (0)
112
Hongjie Yangfe355b72007-02-05 21:18:24 +0100113#define NSS_NAME_SIZE 8
Hongjie Yangfe355b72007-02-05 21:18:24 +0100114extern char kernel_nss_name[];
115
David Howellsa0616cd2012-03-28 18:30:02 +0100116#ifdef CONFIG_PFAULT
117extern int pfault_init(void);
118extern void pfault_fini(void);
119#else /* CONFIG_PFAULT */
120#define pfault_init() ({-1;})
121#define pfault_fini() do { } while (0)
122#endif /* CONFIG_PFAULT */
123
124extern void cmma_init(void);
125
126extern void (*_machine_restart)(char *command);
127extern void (*_machine_halt)(void);
128extern void (*_machine_power_off)(void);
129
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800130#else /* __ASSEMBLY__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700131
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200132#ifndef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700133#define IPL_DEVICE 0x10404
134#define INITRD_START 0x1040C
135#define INITRD_SIZE 0x10414
Michael Holzheu60a0c682011-10-30 15:16:40 +0100136#define OLDMEM_BASE 0x1041C
137#define OLDMEM_SIZE 0x10424
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200138#else /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700139#define IPL_DEVICE 0x10400
140#define INITRD_START 0x10408
141#define INITRD_SIZE 0x10410
Michael Holzheu60a0c682011-10-30 15:16:40 +0100142#define OLDMEM_BASE 0x10418
143#define OLDMEM_SIZE 0x10420
Heiko Carstensf4815ac2012-05-23 16:24:51 +0200144#endif /* CONFIG_64BIT */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145#define COMMAND_LINE 0x10480
146
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800147#endif /* __ASSEMBLY__ */
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800148#endif /* _ASM_S390_SETUP_H */