Commit | Line | Data |
---|---|---|
1da177e4 LT |
1 | /* |
2 | * include/asm-s390/setup.h | |
3 | * | |
4 | * S390 version | |
cd3b70f5 | 5 | * Copyright IBM Corp. 1999,2010 |
1da177e4 LT |
6 | */ |
7 | ||
8 | #ifndef _ASM_S390_SETUP_H | |
9 | #define _ASM_S390_SETUP_H | |
10 | ||
684d2fd4 | 11 | #define COMMAND_LINE_SIZE 4096 |
a0443fbb HB |
12 | |
13 | #define ARCH_COMMAND_LINE_SIZE 896 | |
7d1362c0 | 14 | |
0defa3c1 HC |
15 | #ifdef __KERNEL__ |
16 | ||
1da177e4 | 17 | #define PARMAREA 0x10400 |
23d17421 | 18 | #define MEMORY_CHUNKS 256 |
1da177e4 LT |
19 | |
20 | #ifndef __ASSEMBLY__ | |
21 | ||
cbb870c8 HC |
22 | #include <asm/lowcore.h> |
23 | #include <asm/types.h> | |
24 | ||
1da177e4 LT |
25 | #ifndef __s390x__ |
26 | #define IPL_DEVICE (*(unsigned long *) (0x10404)) | |
27 | #define INITRD_START (*(unsigned long *) (0x1040C)) | |
28 | #define INITRD_SIZE (*(unsigned long *) (0x10414)) | |
60a0c68d MH |
29 | #define OLDMEM_BASE (*(unsigned long *) (0x1041C)) |
30 | #define OLDMEM_SIZE (*(unsigned long *) (0x10424)) | |
1da177e4 LT |
31 | #else /* __s390x__ */ |
32 | #define IPL_DEVICE (*(unsigned long *) (0x10400)) | |
33 | #define INITRD_START (*(unsigned long *) (0x10408)) | |
34 | #define INITRD_SIZE (*(unsigned long *) (0x10410)) | |
60a0c68d MH |
35 | #define OLDMEM_BASE (*(unsigned long *) (0x10418)) |
36 | #define OLDMEM_SIZE (*(unsigned long *) (0x10420)) | |
1da177e4 LT |
37 | #endif /* __s390x__ */ |
38 | #define COMMAND_LINE ((char *) (0x10480)) | |
39 | ||
36a2bd42 HC |
40 | #define CHUNK_READ_WRITE 0 |
41 | #define CHUNK_READ_ONLY 1 | |
60a0c68d MH |
42 | #define CHUNK_OLDMEM 4 |
43 | #define CHUNK_CRASHK 5 | |
36a2bd42 HC |
44 | |
45 | struct mem_chunk { | |
46 | unsigned long addr; | |
47 | unsigned long size; | |
23d17421 | 48 | int type; |
36a2bd42 HC |
49 | }; |
50 | ||
51 | extern struct mem_chunk memory_chunk[]; | |
411ed322 | 52 | extern unsigned long real_memory_size; |
23d75d9c HC |
53 | extern int memory_end_set; |
54 | extern unsigned long memory_end; | |
36a2bd42 | 55 | |
23d17421 | 56 | void detect_memory_layout(struct mem_chunk chunk[]); |
60a0c68d MH |
57 | void create_mem_hole(struct mem_chunk memory_chunk[], unsigned long addr, |
58 | unsigned long size, int type); | |
23d17421 | 59 | |
b11b5334 MS |
60 | #define PRIMARY_SPACE_MODE 0 |
61 | #define ACCESS_REGISTER_MODE 1 | |
62 | #define SECONDARY_SPACE_MODE 2 | |
63 | #define HOME_SPACE_MODE 3 | |
64 | ||
65 | extern unsigned int user_mode; | |
c1821c2e | 66 | |
1da177e4 LT |
67 | /* |
68 | * Machine features detected in head.S | |
69 | */ | |
1da177e4 | 70 | |
2e5061e4 HC |
71 | #define MACHINE_FLAG_VM (1UL << 0) |
72 | #define MACHINE_FLAG_IEEE (1UL << 1) | |
2e5061e4 HC |
73 | #define MACHINE_FLAG_CSP (1UL << 3) |
74 | #define MACHINE_FLAG_MVPG (1UL << 4) | |
75 | #define MACHINE_FLAG_DIAG44 (1UL << 5) | |
76 | #define MACHINE_FLAG_IDTE (1UL << 6) | |
77 | #define MACHINE_FLAG_DIAG9C (1UL << 7) | |
78 | #define MACHINE_FLAG_MVCOS (1UL << 8) | |
79 | #define MACHINE_FLAG_KVM (1UL << 9) | |
53492b1d GS |
80 | #define MACHINE_FLAG_HPAGE (1UL << 10) |
81 | #define MACHINE_FLAG_PFMF (1UL << 11) | |
27d71602 | 82 | #define MACHINE_FLAG_LPAR (1UL << 12) |
cd3b70f5 | 83 | #define MACHINE_FLAG_SPP (1UL << 13) |
9186d7a9 | 84 | #define MACHINE_FLAG_TOPOLOGY (1UL << 14) |
cfa1e7e1 | 85 | #define MACHINE_FLAG_STCKF (1UL << 15) |
2e5061e4 | 86 | |
25097bf1 CE |
87 | #define MACHINE_IS_VM (S390_lowcore.machine_flags & MACHINE_FLAG_VM) |
88 | #define MACHINE_IS_KVM (S390_lowcore.machine_flags & MACHINE_FLAG_KVM) | |
27d71602 MS |
89 | #define MACHINE_IS_LPAR (S390_lowcore.machine_flags & MACHINE_FLAG_LPAR) |
90 | ||
25097bf1 | 91 | #define MACHINE_HAS_DIAG9C (S390_lowcore.machine_flags & MACHINE_FLAG_DIAG9C) |
1da177e4 LT |
92 | |
93 | #ifndef __s390x__ | |
25097bf1 CE |
94 | #define MACHINE_HAS_IEEE (S390_lowcore.machine_flags & MACHINE_FLAG_IEEE) |
95 | #define MACHINE_HAS_CSP (S390_lowcore.machine_flags & MACHINE_FLAG_CSP) | |
2e5061e4 | 96 | #define MACHINE_HAS_IDTE (0) |
abdba61a | 97 | #define MACHINE_HAS_DIAG44 (1) |
25097bf1 | 98 | #define MACHINE_HAS_MVPG (S390_lowcore.machine_flags & MACHINE_FLAG_MVPG) |
6c2a9e6d | 99 | #define MACHINE_HAS_MVCOS (0) |
53492b1d GS |
100 | #define MACHINE_HAS_HPAGE (0) |
101 | #define MACHINE_HAS_PFMF (0) | |
cd3b70f5 | 102 | #define MACHINE_HAS_SPP (0) |
9186d7a9 | 103 | #define MACHINE_HAS_TOPOLOGY (0) |
cfa1e7e1 | 104 | #define MACHINE_HAS_STCKF (0) |
1da177e4 LT |
105 | #else /* __s390x__ */ |
106 | #define MACHINE_HAS_IEEE (1) | |
107 | #define MACHINE_HAS_CSP (1) | |
25097bf1 CE |
108 | #define MACHINE_HAS_IDTE (S390_lowcore.machine_flags & MACHINE_FLAG_IDTE) |
109 | #define MACHINE_HAS_DIAG44 (S390_lowcore.machine_flags & MACHINE_FLAG_DIAG44) | |
2e5061e4 | 110 | #define MACHINE_HAS_MVPG (1) |
25097bf1 CE |
111 | #define MACHINE_HAS_MVCOS (S390_lowcore.machine_flags & MACHINE_FLAG_MVCOS) |
112 | #define MACHINE_HAS_HPAGE (S390_lowcore.machine_flags & MACHINE_FLAG_HPAGE) | |
113 | #define MACHINE_HAS_PFMF (S390_lowcore.machine_flags & MACHINE_FLAG_PFMF) | |
cd3b70f5 | 114 | #define MACHINE_HAS_SPP (S390_lowcore.machine_flags & MACHINE_FLAG_SPP) |
9186d7a9 | 115 | #define MACHINE_HAS_TOPOLOGY (S390_lowcore.machine_flags & MACHINE_FLAG_TOPOLOGY) |
cfa1e7e1 | 116 | #define MACHINE_HAS_STCKF (S390_lowcore.machine_flags & MACHINE_FLAG_STCKF) |
1da177e4 LT |
117 | #endif /* __s390x__ */ |
118 | ||
411ed322 | 119 | #define ZFCPDUMP_HSA_SIZE (32UL<<20) |
60a0c68d | 120 | #define ZFCPDUMP_HSA_SIZE_MAX (64UL<<20) |
1da177e4 LT |
121 | |
122 | /* | |
123 | * Console mode. Override with conmode= | |
124 | */ | |
125 | extern unsigned int console_mode; | |
126 | extern unsigned int console_devno; | |
127 | extern unsigned int console_irq; | |
128 | ||
2b67fc46 HC |
129 | extern char vmhalt_cmd[]; |
130 | extern char vmpoff_cmd[]; | |
131 | ||
1da177e4 LT |
132 | #define CONSOLE_IS_UNDEFINED (console_mode == 0) |
133 | #define CONSOLE_IS_SCLP (console_mode == 1) | |
134 | #define CONSOLE_IS_3215 (console_mode == 2) | |
135 | #define CONSOLE_IS_3270 (console_mode == 3) | |
136 | #define SET_CONSOLE_SCLP do { console_mode = 1; } while (0) | |
137 | #define SET_CONSOLE_3215 do { console_mode = 2; } while (0) | |
138 | #define SET_CONSOLE_3270 do { console_mode = 3; } while (0) | |
139 | ||
fe355b7f | 140 | #define NSS_NAME_SIZE 8 |
fe355b7f HY |
141 | extern char kernel_nss_name[]; |
142 | ||
0defa3c1 | 143 | #else /* __ASSEMBLY__ */ |
1da177e4 LT |
144 | |
145 | #ifndef __s390x__ | |
146 | #define IPL_DEVICE 0x10404 | |
147 | #define INITRD_START 0x1040C | |
148 | #define INITRD_SIZE 0x10414 | |
60a0c68d MH |
149 | #define OLDMEM_BASE 0x1041C |
150 | #define OLDMEM_SIZE 0x10424 | |
1da177e4 LT |
151 | #else /* __s390x__ */ |
152 | #define IPL_DEVICE 0x10400 | |
153 | #define INITRD_START 0x10408 | |
154 | #define INITRD_SIZE 0x10410 | |
60a0c68d MH |
155 | #define OLDMEM_BASE 0x10418 |
156 | #define OLDMEM_SIZE 0x10420 | |
1da177e4 LT |
157 | #endif /* __s390x__ */ |
158 | #define COMMAND_LINE 0x10480 | |
159 | ||
0defa3c1 HC |
160 | #endif /* __ASSEMBLY__ */ |
161 | #endif /* __KERNEL__ */ | |
162 | #endif /* _ASM_S390_SETUP_H */ |