Commit | Line | Data |
---|---|---|
1da177e4 | 1 | /* |
4baa9922 | 2 | * arch/arm/include/asm/mach/arch.h |
1da177e4 LT |
3 | * |
4 | * Copyright (C) 2000 Russell King | |
5 | * | |
6 | * This program is free software; you can redistribute it and/or modify | |
7 | * it under the terms of the GNU General Public License version 2 as | |
8 | * published by the Free Software Foundation. | |
9 | */ | |
10 | ||
11 | #ifndef __ASSEMBLY__ | |
12 | ||
13 | struct tag; | |
14 | struct meminfo; | |
1a1f2be2 | 15 | struct pt_regs; |
abcee5fb MZ |
16 | struct smp_operations; |
17 | #ifdef CONFIG_SMP | |
18 | #define smp_ops(ops) (&(ops)) | |
19 | #else | |
20 | #define smp_ops(ops) (struct smp_operations *)NULL | |
21 | #endif | |
1da177e4 LT |
22 | |
23 | struct machine_desc { | |
1da177e4 | 24 | unsigned int nr; /* architecture number */ |
1da177e4 | 25 | const char *name; /* architecture name */ |
2bb9839e | 26 | unsigned long atag_offset; /* tagged list (relative) */ |
7b482c83 | 27 | const char *const *dt_compat; /* array of device tree |
93c02ab4 | 28 | * 'compatible' strings */ |
1da177e4 | 29 | |
d71e3eb5 NP |
30 | unsigned int nr_irqs; /* number of IRQs */ |
31 | ||
4fddcaeb | 32 | #ifdef CONFIG_ZONE_DMA |
6fa3eb70 | 33 | phys_addr_t dma_zone_size; /* size of DMA-able area */ |
4fddcaeb NP |
34 | #endif |
35 | ||
1da177e4 LT |
36 | unsigned int video_start; /* start of video RAM */ |
37 | unsigned int video_end; /* end of video RAM */ | |
38 | ||
b44c350d RK |
39 | unsigned char reserve_lp0 :1; /* never has lp0 */ |
40 | unsigned char reserve_lp1 :1; /* never has lp1 */ | |
41 | unsigned char reserve_lp2 :1; /* never has lp2 */ | |
42 | char restart_mode; /* default restart mode */ | |
abcee5fb | 43 | struct smp_operations *smp; /* SMP operations */ |
0744a3ee | 44 | void (*fixup)(struct tag *, char **, |
1da177e4 | 45 | struct meminfo *); |
98c672cf | 46 | void (*reserve)(void);/* reserve mem blocks */ |
1da177e4 | 47 | void (*map_io)(void);/* IO mapping function */ |
dec12e62 | 48 | void (*init_early)(void); |
1da177e4 | 49 | void (*init_irq)(void); |
6bb27d73 | 50 | void (*init_time)(void); |
1da177e4 | 51 | void (*init_machine)(void); |
90de4137 | 52 | void (*init_late)(void); |
52108641 | 53 | #ifdef CONFIG_MULTI_IRQ_HANDLER |
54 | void (*handle_irq)(struct pt_regs *); | |
55 | #endif | |
a528721d | 56 | void (*restart)(char, const char *); |
1da177e4 LT |
57 | }; |
58 | ||
8ff1443c RK |
59 | /* |
60 | * Current machine - only accessible during boot. | |
61 | */ | |
62 | extern struct machine_desc *machine_desc; | |
63 | ||
6291319d GL |
64 | /* |
65 | * Machine type table - also only accessible during boot | |
66 | */ | |
67 | extern struct machine_desc __arch_info_begin[], __arch_info_end[]; | |
68 | #define for_each_machine_desc(p) \ | |
69 | for (p = __arch_info_begin; p < __arch_info_end; p++) | |
70 | ||
1da177e4 LT |
71 | /* |
72 | * Set of macros to define architecture features. This is built into | |
73 | * a table by the linker. | |
74 | */ | |
f339ab3d RK |
75 | #define MACHINE_START(_type,_name) \ |
76 | static const struct machine_desc __mach_desc_##_type \ | |
b91d8a12 | 77 | __used \ |
9d0fd1eb | 78 | __attribute__((__section__(".arch.info.init"))) = { \ |
f339ab3d | 79 | .nr = MACH_TYPE_##_type, \ |
1da177e4 LT |
80 | .name = _name, |
81 | ||
1da177e4 LT |
82 | #define MACHINE_END \ |
83 | }; | |
84 | ||
85cad1b0 GL |
85 | #define DT_MACHINE_START(_name, _namestr) \ |
86 | static const struct machine_desc __mach_desc_##_name \ | |
87 | __used \ | |
88 | __attribute__((__section__(".arch.info.init"))) = { \ | |
89 | .nr = ~0, \ | |
90 | .name = _namestr, | |
91 | ||
1da177e4 | 92 | #endif |