blob: 4a1126d8439a0241d950f9f0c13093f458f6561e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * include/asm-s390/setup.h
3 *
4 * S390 version
5 * Copyright (C) 1999 IBM Deutschland Entwicklung GmbH, IBM Corporation
6 */
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
33/*
34 * Machine features detected in head.S
35 */
36extern unsigned long machine_flags;
37
38#define MACHINE_IS_VM (machine_flags & 1)
39#define MACHINE_IS_P390 (machine_flags & 4)
40#define MACHINE_HAS_MVPG (machine_flags & 16)
Linus Torvalds1da177e2005-04-16 15:20:36 -070041#define MACHINE_HAS_IDTE (machine_flags & 128)
42
43#ifndef __s390x__
44#define MACHINE_HAS_IEEE (machine_flags & 2)
45#define MACHINE_HAS_CSP (machine_flags & 8)
Heiko Carstensabdba612006-07-12 16:39:58 +020046#define MACHINE_HAS_DIAG44 (1)
Linus Torvalds1da177e2005-04-16 15:20:36 -070047#else /* __s390x__ */
48#define MACHINE_HAS_IEEE (1)
49#define MACHINE_HAS_CSP (1)
Heiko Carstensabdba612006-07-12 16:39:58 +020050#define MACHINE_HAS_DIAG44 (machine_flags & 32)
Linus Torvalds1da177e2005-04-16 15:20:36 -070051#endif /* __s390x__ */
52
53
54#define MACHINE_HAS_SCLP (!MACHINE_IS_P390)
55
56/*
57 * Console mode. Override with conmode=
58 */
59extern unsigned int console_mode;
60extern unsigned int console_devno;
61extern unsigned int console_irq;
62
63#define CONSOLE_IS_UNDEFINED (console_mode == 0)
64#define CONSOLE_IS_SCLP (console_mode == 1)
65#define CONSOLE_IS_3215 (console_mode == 2)
66#define CONSOLE_IS_3270 (console_mode == 3)
67#define SET_CONSOLE_SCLP do { console_mode = 1; } while (0)
68#define SET_CONSOLE_3215 do { console_mode = 2; } while (0)
69#define SET_CONSOLE_3270 do { console_mode = 3; } while (0)
70
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020071
72struct ipl_list_hdr {
73 u32 len;
74 u8 reserved1[3];
Heiko Carstens1e8e3382005-10-30 15:00:11 -080075 u8 version;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020076 u32 blk0_len;
77 u8 pbt;
78 u8 flags;
79 u16 reserved2;
Heiko Carstens1e8e3382005-10-30 15:00:11 -080080} __attribute__((packed));
81
82struct ipl_block_fcp {
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020083 u8 reserved1[313-1];
84 u8 opt;
85 u8 reserved2[3];
86 u16 reserved3;
Heiko Carstens1e8e3382005-10-30 15:00:11 -080087 u16 devno;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020088 u8 reserved4[4];
Heiko Carstens1e8e3382005-10-30 15:00:11 -080089 u64 wwpn;
90 u64 lun;
91 u32 bootprog;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020092 u8 reserved5[12];
Heiko Carstens1e8e3382005-10-30 15:00:11 -080093 u64 br_lba;
94 u32 scp_data_len;
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020095 u8 reserved6[260];
Heiko Carstens1e8e3382005-10-30 15:00:11 -080096 u8 scp_data[];
97} __attribute__((packed));
98
Michael Holzheuff6b8ea2006-09-20 15:58:49 +020099struct ipl_block_ccw {
100 u8 load_param[8];
101 u8 reserved1[84];
102 u8 reserved2[2];
103 u16 devno;
104 u8 vm_flags;
105 u8 reserved3[3];
106 u32 vm_parm_len;
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800107} __attribute__((packed));
108
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200109struct ipl_parameter_block {
110 struct ipl_list_hdr hdr;
111 union {
112 struct ipl_block_fcp fcp;
113 struct ipl_block_ccw ccw;
114 } ipl_info;
115} __attribute__((packed));
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800116
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200117#define IPL_PARM_BLK_FCP_LEN (sizeof(struct ipl_list_hdr) + \
118 sizeof(struct ipl_block_fcp))
119
120#define IPL_PARM_BLK_CCW_LEN (sizeof(struct ipl_list_hdr) + \
121 sizeof(struct ipl_block_ccw))
122
123#define IPL_MAX_SUPPORTED_VERSION (0)
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800124
125/*
126 * IPL validity flags and parameters as detected in head.S
127 */
128extern u32 ipl_parameter_flags;
129extern u16 ipl_devno;
130
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200131void do_reipl(void);
132
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800133#define IPL_DEVNO_VALID (ipl_parameter_flags & 1)
134#define IPL_PARMBLOCK_VALID (ipl_parameter_flags & 2)
135
136#define IPL_PARMBLOCK_START ((struct ipl_parameter_block *) \
137 IPL_PARMBLOCK_ORIGIN)
Michael Holzheuff6b8ea2006-09-20 15:58:49 +0200138#define IPL_PARMBLOCK_SIZE (IPL_PARMBLOCK_START->hdr.len)
Heiko Carstens1e8e3382005-10-30 15:00:11 -0800139
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800140#else /* __ASSEMBLY__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700141
142#ifndef __s390x__
143#define IPL_DEVICE 0x10404
144#define INITRD_START 0x1040C
145#define INITRD_SIZE 0x10414
146#else /* __s390x__ */
147#define IPL_DEVICE 0x10400
148#define INITRD_START 0x10408
149#define INITRD_SIZE 0x10410
150#endif /* __s390x__ */
151#define COMMAND_LINE 0x10480
152
Heiko Carstens0defa3c2006-02-11 17:56:03 -0800153#endif /* __ASSEMBLY__ */
154#endif /* __KERNEL__ */
155#endif /* _ASM_S390_SETUP_H */