blob: 3388bb52597cb79593efa30053c882cf66be9bee [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * include/asm-s390/setup.h
3 *
4 * S390 version
Heiko Carstens36a2bd42006-12-04 15:40:38 +01005 * Copyright IBM Corp. 1999,2006
Linus Torvalds1da177e2005-04-16 15:20:36 -07006 */
7
8#ifndef _ASM_S390_SETUP_H
9#define _ASM_S390_SETUP_H
10
Adrian Bunk7d1362c2006-12-06 20:40:38 -080011#define COMMAND_LINE_SIZE 896
12
Heiko Carstens0defa3c2006-02-11 17:56:03 -080013#ifdef __KERNEL__
14
Heiko Carstens1e8e3382005-10-30 15:00:11 -080015#include <asm/types.h>
16
Linus Torvalds1da177e2005-04-16 15:20:36 -070017#define PARMAREA 0x10400
Linus Torvalds1da177e2005-04-16 15:20:36 -070018#define MEMORY_CHUNKS 16 /* max 0x7fff */
Heiko Carstens1e8e3382005-10-30 15:00:11 -080019#define IPL_PARMBLOCK_ORIGIN 0x2000
Linus Torvalds1da177e2005-04-16 15:20:36 -070020
21#ifndef __ASSEMBLY__
22
23#ifndef __s390x__
24#define IPL_DEVICE (*(unsigned long *) (0x10404))
25#define INITRD_START (*(unsigned long *) (0x1040C))
26#define INITRD_SIZE (*(unsigned long *) (0x10414))
27#else /* __s390x__ */
28#define IPL_DEVICE (*(unsigned long *) (0x10400))
29#define INITRD_START (*(unsigned long *) (0x10408))
30#define INITRD_SIZE (*(unsigned long *) (0x10410))
31#endif /* __s390x__ */
32#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
36
37struct mem_chunk {
38 unsigned long addr;
39 unsigned long size;
40 unsigned long type;
41};
42
43extern struct mem_chunk memory_chunk[];
44
Gerald Schaeferc1821c22007-02-05 21:18:17 +010045#ifdef CONFIG_S390_SWITCH_AMODE
46extern unsigned int switch_amode;
47#else
48#define switch_amode (0)
49#endif
50
51#ifdef CONFIG_S390_EXEC_PROTECT
52extern unsigned int s390_noexec;
53#else
54#define s390_noexec (0)
55#endif
56
Linus Torvalds1da177e2005-04-16 15:20:36 -070057/*
58 * Machine features detected in head.S
59 */
60extern unsigned long machine_flags;
61
62#define MACHINE_IS_VM (machine_flags & 1)
63#define MACHINE_IS_P390 (machine_flags & 4)
64#define MACHINE_HAS_MVPG (machine_flags & 16)
Linus Torvalds1da177e2005-04-16 15:20:36 -070065#define MACHINE_HAS_IDTE (machine_flags & 128)
Martin Schwidefsky3c1fcfe2006-09-30 23:27:45 -070066#define MACHINE_HAS_DIAG9C (machine_flags & 256)
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
68#ifndef __s390x__
69#define MACHINE_HAS_IEEE (machine_flags & 2)
70#define MACHINE_HAS_CSP (machine_flags & 8)
Heiko Carstensabdba612006-07-12 16:39:58 +020071#define MACHINE_HAS_DIAG44 (1)
Gerald Schaefer6c2a9e62006-09-20 15:59:44 +020072#define MACHINE_HAS_MVCOS (0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070073#else /* __s390x__ */
74#define MACHINE_HAS_IEEE (1)
75#define MACHINE_HAS_CSP (1)
Heiko Carstensabdba612006-07-12 16:39:58 +020076#define MACHINE_HAS_DIAG44 (machine_flags & 32)
Gerald Schaefer6c2a9e62006-09-20 15:59:44 +020077#define MACHINE_HAS_MVCOS (machine_flags & 512)
Linus Torvalds1da177e2005-04-16 15:20:36 -070078#endif /* __s390x__ */
79
Linus Torvalds1da177e2005-04-16 15:20:36 -070080#define MACHINE_HAS_SCLP (!MACHINE_IS_P390)
81
82/*
83 * Console mode. Override with conmode=
84 */
85extern unsigned int console_mode;
86extern unsigned int console_devno;
87extern unsigned int console_irq;
88
Heiko Carstens2b67fc42007-02-05 21:16:47 +010089extern char vmhalt_cmd[];
90extern char vmpoff_cmd[];
91
Linus Torvalds1da177e2005-04-16 15:20:36 -070092#define CONSOLE_IS_UNDEFINED (console_mode == 0)
93#define CONSOLE_IS_SCLP (console_mode == 1)
94#define CONSOLE_IS_3215 (console_mode == 2)
95#define CONSOLE_IS_3270 (console_mode == 3)
96#define SET_CONSOLE_SCLP do { console_mode = 1; } while (0)
97#define SET_CONSOLE_3215 do { console_mode = 2; } while (0)
98#define SET_CONSOLE_3270 do { console_mode = 3; } while (0)
99
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200100struct ipl_list_hdr {
101 u32 len;
102 u8 reserved1[3];
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800103 u8 version;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200104 u32 blk0_len;
105 u8 pbt;
106 u8 flags;
107 u16 reserved2;
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800108} __attribute__((packed));
109
110struct ipl_block_fcp {
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200111 u8 reserved1[313-1];
112 u8 opt;
113 u8 reserved2[3];
114 u16 reserved3;
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800115 u16 devno;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200116 u8 reserved4[4];
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800117 u64 wwpn;
118 u64 lun;
119 u32 bootprog;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200120 u8 reserved5[12];
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800121 u64 br_lba;
122 u32 scp_data_len;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200123 u8 reserved6[260];
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800124 u8 scp_data[];
125} __attribute__((packed));
126
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200127struct ipl_block_ccw {
128 u8 load_param[8];
129 u8 reserved1[84];
130 u8 reserved2[2];
131 u16 devno;
132 u8 vm_flags;
133 u8 reserved3[3];
134 u32 vm_parm_len;
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800135} __attribute__((packed));
136
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200137struct ipl_parameter_block {
138 struct ipl_list_hdr hdr;
139 union {
140 struct ipl_block_fcp fcp;
141 struct ipl_block_ccw ccw;
142 } ipl_info;
143} __attribute__((packed));
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800144
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200145#define IPL_PARM_BLK_FCP_LEN (sizeof(struct ipl_list_hdr) + \
146 sizeof(struct ipl_block_fcp))
147
148#define IPL_PARM_BLK_CCW_LEN (sizeof(struct ipl_list_hdr) + \
149 sizeof(struct ipl_block_ccw))
150
151#define IPL_MAX_SUPPORTED_VERSION (0)
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800152
153/*
154 * IPL validity flags and parameters as detected in head.S
155 */
Heiko Carstense87bfe52006-09-20 15:59:15 +0200156extern u32 ipl_flags;
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800157extern u16 ipl_devno;
158
Hongjie Yangfe355b72007-02-05 21:18:24 +0100159extern void do_reipl(void);
160extern void ipl_save_parameters(void);
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200161
Heiko Carstense87bfe52006-09-20 15:59:15 +0200162enum {
163 IPL_DEVNO_VALID = 1,
164 IPL_PARMBLOCK_VALID = 2,
Hongjie Yangfe355b72007-02-05 21:18:24 +0100165 IPL_NSS_VALID = 4,
Heiko Carstense87bfe52006-09-20 15:59:15 +0200166};
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800167
Hongjie Yangfe355b72007-02-05 21:18:24 +0100168#define NSS_NAME_SIZE 8
169
170extern char kernel_nss_name[];
171
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800172#define IPL_PARMBLOCK_START ((struct ipl_parameter_block *) \
173 IPL_PARMBLOCK_ORIGIN)
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200174#define IPL_PARMBLOCK_SIZE (IPL_PARMBLOCK_START->hdr.len)
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800175
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800176#else /* __ASSEMBLY__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700177
178#ifndef __s390x__
179#define IPL_DEVICE 0x10404
180#define INITRD_START 0x1040C
181#define INITRD_SIZE 0x10414
182#else /* __s390x__ */
183#define IPL_DEVICE 0x10400
184#define INITRD_START 0x10408
185#define INITRD_SIZE 0x10410
186#endif /* __s390x__ */
187#define COMMAND_LINE 0x10480
188
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800189#endif /* __ASSEMBLY__ */
190#endif /* __KERNEL__ */
191#endif /* _ASM_S390_SETUP_H */