blob: 7664bacdd832f0ce1eacbb20cc406ba946f9bb49 [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
Heiko Carstens0defa3c2006-02-11 17:56:03 -080011#ifdef __KERNEL__
12
Heiko Carstens1e8e3382005-10-30 15:00:11 -080013#include <asm/types.h>
14
Linus Torvalds1da177e2005-04-16 15:20:36 -070015#define PARMAREA 0x10400
16#define COMMAND_LINE_SIZE 896
Linus Torvalds1da177e2005-04-16 15:20:36 -070017#define MEMORY_CHUNKS 16 /* max 0x7fff */
Heiko Carstens1e8e3382005-10-30 15:00:11 -080018#define IPL_PARMBLOCK_ORIGIN 0x2000
Linus Torvalds1da177e2005-04-16 15:20:36 -070019
20#ifndef __ASSEMBLY__
21
22#ifndef __s390x__
23#define IPL_DEVICE (*(unsigned long *) (0x10404))
24#define INITRD_START (*(unsigned long *) (0x1040C))
25#define INITRD_SIZE (*(unsigned long *) (0x10414))
26#else /* __s390x__ */
27#define IPL_DEVICE (*(unsigned long *) (0x10400))
28#define INITRD_START (*(unsigned long *) (0x10408))
29#define INITRD_SIZE (*(unsigned long *) (0x10410))
30#endif /* __s390x__ */
31#define COMMAND_LINE ((char *) (0x10480))
32
Heiko Carstens36a2bd42006-12-04 15:40:38 +010033#define CHUNK_READ_WRITE 0
34#define CHUNK_READ_ONLY 1
35
36struct mem_chunk {
37 unsigned long addr;
38 unsigned long size;
39 unsigned long type;
40};
41
42extern struct mem_chunk memory_chunk[];
43
Linus Torvalds1da177e2005-04-16 15:20:36 -070044/*
45 * Machine features detected in head.S
46 */
47extern unsigned long machine_flags;
48
49#define MACHINE_IS_VM (machine_flags & 1)
50#define MACHINE_IS_P390 (machine_flags & 4)
51#define MACHINE_HAS_MVPG (machine_flags & 16)
Linus Torvalds1da177e2005-04-16 15:20:36 -070052#define MACHINE_HAS_IDTE (machine_flags & 128)
Martin Schwidefsky3c1fcfe2006-09-30 23:27:45 -070053#define MACHINE_HAS_DIAG9C (machine_flags & 256)
Linus Torvalds1da177e2005-04-16 15:20:36 -070054
55#ifndef __s390x__
56#define MACHINE_HAS_IEEE (machine_flags & 2)
57#define MACHINE_HAS_CSP (machine_flags & 8)
Heiko Carstensabdba612006-07-12 16:39:58 +020058#define MACHINE_HAS_DIAG44 (1)
Gerald Schaefer6c2a9e62006-09-20 15:59:44 +020059#define MACHINE_HAS_MVCOS (0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070060#else /* __s390x__ */
61#define MACHINE_HAS_IEEE (1)
62#define MACHINE_HAS_CSP (1)
Heiko Carstensabdba612006-07-12 16:39:58 +020063#define MACHINE_HAS_DIAG44 (machine_flags & 32)
Gerald Schaefer6c2a9e62006-09-20 15:59:44 +020064#define MACHINE_HAS_MVCOS (machine_flags & 512)
Linus Torvalds1da177e2005-04-16 15:20:36 -070065#endif /* __s390x__ */
66
Linus Torvalds1da177e2005-04-16 15:20:36 -070067#define MACHINE_HAS_SCLP (!MACHINE_IS_P390)
68
69/*
70 * Console mode. Override with conmode=
71 */
72extern unsigned int console_mode;
73extern unsigned int console_devno;
74extern unsigned int console_irq;
75
76#define CONSOLE_IS_UNDEFINED (console_mode == 0)
77#define CONSOLE_IS_SCLP (console_mode == 1)
78#define CONSOLE_IS_3215 (console_mode == 2)
79#define CONSOLE_IS_3270 (console_mode == 3)
80#define SET_CONSOLE_SCLP do { console_mode = 1; } while (0)
81#define SET_CONSOLE_3215 do { console_mode = 2; } while (0)
82#define SET_CONSOLE_3270 do { console_mode = 3; } while (0)
83
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020084struct ipl_list_hdr {
85 u32 len;
86 u8 reserved1[3];
Heiko Carstens1e8e3382005-10-30 15:00:11 -080087 u8 version;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020088 u32 blk0_len;
89 u8 pbt;
90 u8 flags;
91 u16 reserved2;
Heiko Carstens1e8e3382005-10-30 15:00:11 -080092} __attribute__((packed));
93
94struct ipl_block_fcp {
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020095 u8 reserved1[313-1];
96 u8 opt;
97 u8 reserved2[3];
98 u16 reserved3;
Heiko Carstens1e8e3382005-10-30 15:00:11 -080099 u16 devno;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200100 u8 reserved4[4];
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800101 u64 wwpn;
102 u64 lun;
103 u32 bootprog;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200104 u8 reserved5[12];
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800105 u64 br_lba;
106 u32 scp_data_len;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200107 u8 reserved6[260];
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800108 u8 scp_data[];
109} __attribute__((packed));
110
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200111struct ipl_block_ccw {
112 u8 load_param[8];
113 u8 reserved1[84];
114 u8 reserved2[2];
115 u16 devno;
116 u8 vm_flags;
117 u8 reserved3[3];
118 u32 vm_parm_len;
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800119} __attribute__((packed));
120
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200121struct ipl_parameter_block {
122 struct ipl_list_hdr hdr;
123 union {
124 struct ipl_block_fcp fcp;
125 struct ipl_block_ccw ccw;
126 } ipl_info;
127} __attribute__((packed));
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800128
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200129#define IPL_PARM_BLK_FCP_LEN (sizeof(struct ipl_list_hdr) + \
130 sizeof(struct ipl_block_fcp))
131
132#define IPL_PARM_BLK_CCW_LEN (sizeof(struct ipl_list_hdr) + \
133 sizeof(struct ipl_block_ccw))
134
135#define IPL_MAX_SUPPORTED_VERSION (0)
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800136
137/*
138 * IPL validity flags and parameters as detected in head.S
139 */
Heiko Carstense87bfe52006-09-20 15:59:15 +0200140extern u32 ipl_flags;
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800141extern u16 ipl_devno;
142
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200143void do_reipl(void);
144
Heiko Carstense87bfe52006-09-20 15:59:15 +0200145enum {
146 IPL_DEVNO_VALID = 1,
147 IPL_PARMBLOCK_VALID = 2,
148};
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800149
150#define IPL_PARMBLOCK_START ((struct ipl_parameter_block *) \
151 IPL_PARMBLOCK_ORIGIN)
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200152#define IPL_PARMBLOCK_SIZE (IPL_PARMBLOCK_START->hdr.len)
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800153
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800154#else /* __ASSEMBLY__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700155
156#ifndef __s390x__
157#define IPL_DEVICE 0x10404
158#define INITRD_START 0x1040C
159#define INITRD_SIZE 0x10414
160#else /* __s390x__ */
161#define IPL_DEVICE 0x10400
162#define INITRD_START 0x10408
163#define INITRD_SIZE 0x10410
164#endif /* __s390x__ */
165#define COMMAND_LINE 0x10480
166
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800167#endif /* __ASSEMBLY__ */
168#endif /* __KERNEL__ */
169#endif /* _ASM_S390_SETUP_H */