diff options
author | Russell King <rmk+kernel@arm.linux.org.uk> | 2010-05-07 12:40:33 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2010-07-16 05:57:35 -0400 |
commit | be370302742ff9948f2a42b15cb2ba174d97b930 (patch) | |
tree | 977bfa71c1e1483c22a40d85dfd3b233e5ac5d06 /arch | |
parent | 7961239599de71130c852ecfa9a4140f3f60547b (diff) |
ARM: Remove DISCONTIGMEM support
Everything should now be using sparsemem rather than discontigmem, so
remove the code supporting discontigmem from ARM.
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch')
30 files changed, 143 insertions, 432 deletions
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 98922f7d2d12..410edd65f117 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
@@ -719,7 +719,6 @@ config ARCH_SHARK | |||
719 | config ARCH_LH7A40X | 719 | config ARCH_LH7A40X |
720 | bool "Sharp LH7A40X" | 720 | bool "Sharp LH7A40X" |
721 | select CPU_ARM922T | 721 | select CPU_ARM922T |
722 | select ARCH_DISCONTIGMEM_ENABLE if !LH7A40X_CONTIGMEM | ||
723 | select ARCH_SPARSEMEM_ENABLE if !LH7A40X_CONTIGMEM | 722 | select ARCH_SPARSEMEM_ENABLE if !LH7A40X_CONTIGMEM |
724 | select ARCH_USES_GETTIMEOFFSET | 723 | select ARCH_USES_GETTIMEOFFSET |
725 | help | 724 | help |
@@ -1241,10 +1240,6 @@ config OABI_COMPAT | |||
1241 | config ARCH_HAS_HOLES_MEMORYMODEL | 1240 | config ARCH_HAS_HOLES_MEMORYMODEL |
1242 | bool | 1241 | bool |
1243 | 1242 | ||
1244 | # Discontigmem is deprecated | ||
1245 | config ARCH_DISCONTIGMEM_ENABLE | ||
1246 | bool | ||
1247 | |||
1248 | config ARCH_SPARSEMEM_ENABLE | 1243 | config ARCH_SPARSEMEM_ENABLE |
1249 | bool | 1244 | bool |
1250 | 1245 | ||
@@ -1252,13 +1247,7 @@ config ARCH_SPARSEMEM_DEFAULT | |||
1252 | def_bool ARCH_SPARSEMEM_ENABLE | 1247 | def_bool ARCH_SPARSEMEM_ENABLE |
1253 | 1248 | ||
1254 | config ARCH_SELECT_MEMORY_MODEL | 1249 | config ARCH_SELECT_MEMORY_MODEL |
1255 | def_bool ARCH_DISCONTIGMEM_ENABLE && ARCH_SPARSEMEM_ENABLE | 1250 | def_bool ARCH_SPARSEMEM_ENABLE |
1256 | |||
1257 | config NODES_SHIFT | ||
1258 | int | ||
1259 | default "4" if ARCH_LH7A40X | ||
1260 | default "2" | ||
1261 | depends on NEED_MULTIPLE_NODES | ||
1262 | 1251 | ||
1263 | config HIGHMEM | 1252 | config HIGHMEM |
1264 | bool "High Memory Support (EXPERIMENTAL)" | 1253 | bool "High Memory Support (EXPERIMENTAL)" |
diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h index 4312ee5e3d0b..e263ec7c5dcb 100644 --- a/arch/arm/include/asm/memory.h +++ b/arch/arm/include/asm/memory.h | |||
@@ -234,76 +234,11 @@ static inline __deprecated void *bus_to_virt(unsigned long x) | |||
234 | * virt_to_page(k) convert a _valid_ virtual address to struct page * | 234 | * virt_to_page(k) convert a _valid_ virtual address to struct page * |
235 | * virt_addr_valid(k) indicates whether a virtual address is valid | 235 | * virt_addr_valid(k) indicates whether a virtual address is valid |
236 | */ | 236 | */ |
237 | #ifndef CONFIG_DISCONTIGMEM | ||
238 | |||
239 | #define ARCH_PFN_OFFSET PHYS_PFN_OFFSET | 237 | #define ARCH_PFN_OFFSET PHYS_PFN_OFFSET |
240 | 238 | ||
241 | #define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT) | 239 | #define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT) |
242 | #define virt_addr_valid(kaddr) ((unsigned long)(kaddr) >= PAGE_OFFSET && (unsigned long)(kaddr) < (unsigned long)high_memory) | 240 | #define virt_addr_valid(kaddr) ((unsigned long)(kaddr) >= PAGE_OFFSET && (unsigned long)(kaddr) < (unsigned long)high_memory) |
243 | 241 | ||
244 | #define PHYS_TO_NID(addr) (0) | ||
245 | |||
246 | #else /* CONFIG_DISCONTIGMEM */ | ||
247 | |||
248 | /* | ||
249 | * This is more complex. We have a set of mem_map arrays spread | ||
250 | * around in memory. | ||
251 | */ | ||
252 | #include <linux/numa.h> | ||
253 | |||
254 | #define arch_pfn_to_nid(pfn) PFN_TO_NID(pfn) | ||
255 | #define arch_local_page_offset(pfn, nid) LOCAL_MAP_NR((pfn) << PAGE_SHIFT) | ||
256 | |||
257 | #define virt_to_page(kaddr) \ | ||
258 | (ADDR_TO_MAPBASE(kaddr) + LOCAL_MAP_NR(kaddr)) | ||
259 | |||
260 | #define virt_addr_valid(kaddr) (KVADDR_TO_NID(kaddr) < MAX_NUMNODES) | ||
261 | |||
262 | /* | ||
263 | * Common discontigmem stuff. | ||
264 | * PHYS_TO_NID is used by the ARM kernel/setup.c | ||
265 | */ | ||
266 | #define PHYS_TO_NID(addr) PFN_TO_NID((addr) >> PAGE_SHIFT) | ||
267 | |||
268 | /* | ||
269 | * Given a kaddr, ADDR_TO_MAPBASE finds the owning node of the memory | ||
270 | * and returns the mem_map of that node. | ||
271 | */ | ||
272 | #define ADDR_TO_MAPBASE(kaddr) NODE_MEM_MAP(KVADDR_TO_NID(kaddr)) | ||
273 | |||
274 | /* | ||
275 | * Given a page frame number, find the owning node of the memory | ||
276 | * and returns the mem_map of that node. | ||
277 | */ | ||
278 | #define PFN_TO_MAPBASE(pfn) NODE_MEM_MAP(PFN_TO_NID(pfn)) | ||
279 | |||
280 | #ifdef NODE_MEM_SIZE_BITS | ||
281 | #define NODE_MEM_SIZE_MASK ((1 << NODE_MEM_SIZE_BITS) - 1) | ||
282 | |||
283 | /* | ||
284 | * Given a kernel address, find the home node of the underlying memory. | ||
285 | */ | ||
286 | #define KVADDR_TO_NID(addr) \ | ||
287 | (((unsigned long)(addr) - PAGE_OFFSET) >> NODE_MEM_SIZE_BITS) | ||
288 | |||
289 | /* | ||
290 | * Given a page frame number, convert it to a node id. | ||
291 | */ | ||
292 | #define PFN_TO_NID(pfn) \ | ||
293 | (((pfn) - PHYS_PFN_OFFSET) >> (NODE_MEM_SIZE_BITS - PAGE_SHIFT)) | ||
294 | |||
295 | /* | ||
296 | * Given a kaddr, LOCAL_MEM_MAP finds the owning node of the memory | ||
297 | * and returns the index corresponding to the appropriate page in the | ||
298 | * node's mem_map. | ||
299 | */ | ||
300 | #define LOCAL_MAP_NR(addr) \ | ||
301 | (((unsigned long)(addr) & NODE_MEM_SIZE_MASK) >> PAGE_SHIFT) | ||
302 | |||
303 | #endif /* NODE_MEM_SIZE_BITS */ | ||
304 | |||
305 | #endif /* !CONFIG_DISCONTIGMEM */ | ||
306 | |||
307 | /* | 242 | /* |
308 | * Optional coherency support. Currently used only by selected | 243 | * Optional coherency support. Currently used only by selected |
309 | * Intel XSC3-based systems. | 244 | * Intel XSC3-based systems. |
diff --git a/arch/arm/include/asm/mmzone.h b/arch/arm/include/asm/mmzone.h deleted file mode 100644 index ae63a4fd28c8..000000000000 --- a/arch/arm/include/asm/mmzone.h +++ /dev/null | |||
@@ -1,30 +0,0 @@ | |||
1 | /* | ||
2 | * arch/arm/include/asm/mmzone.h | ||
3 | * | ||
4 | * 1999-12-29 Nicolas Pitre Created | ||
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 | #ifndef __ASM_MMZONE_H | ||
11 | #define __ASM_MMZONE_H | ||
12 | |||
13 | /* | ||
14 | * Currently defined in arch/arm/mm/discontig.c | ||
15 | */ | ||
16 | extern pg_data_t discontig_node_data[]; | ||
17 | |||
18 | /* | ||
19 | * Return a pointer to the node data for node n. | ||
20 | */ | ||
21 | #define NODE_DATA(nid) (&discontig_node_data[nid]) | ||
22 | |||
23 | /* | ||
24 | * NODE_MEM_MAP gives the kaddr for the mem_map of the node. | ||
25 | */ | ||
26 | #define NODE_MEM_MAP(nid) (NODE_DATA(nid)->node_mem_map) | ||
27 | |||
28 | #include <mach/memory.h> | ||
29 | |||
30 | #endif | ||
diff --git a/arch/arm/include/asm/setup.h b/arch/arm/include/asm/setup.h index f392fb4437af..f1e5a9bca249 100644 --- a/arch/arm/include/asm/setup.h +++ b/arch/arm/include/asm/setup.h | |||
@@ -201,8 +201,7 @@ static struct tagtable __tagtable_##fn __tag = { tag, fn } | |||
201 | struct membank { | 201 | struct membank { |
202 | unsigned long start; | 202 | unsigned long start; |
203 | unsigned long size; | 203 | unsigned long size; |
204 | unsigned short node; | 204 | unsigned int highmem; |
205 | unsigned short highmem; | ||
206 | }; | 205 | }; |
207 | 206 | ||
208 | struct meminfo { | 207 | struct meminfo { |
@@ -212,9 +211,8 @@ struct meminfo { | |||
212 | 211 | ||
213 | extern struct meminfo meminfo; | 212 | extern struct meminfo meminfo; |
214 | 213 | ||
215 | #define for_each_nodebank(iter,mi,no) \ | 214 | #define for_each_bank(iter,mi) \ |
216 | for (iter = 0; iter < (mi)->nr_banks; iter++) \ | 215 | for (iter = 0; iter < (mi)->nr_banks; iter++) |
217 | if ((mi)->bank[iter].node == no) | ||
218 | 216 | ||
219 | #define bank_pfn_start(bank) __phys_to_pfn((bank)->start) | 217 | #define bank_pfn_start(bank) __phys_to_pfn((bank)->start) |
220 | #define bank_pfn_end(bank) __phys_to_pfn((bank)->start + (bank)->size) | 218 | #define bank_pfn_end(bank) __phys_to_pfn((bank)->start + (bank)->size) |
diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c index 122d999bdc7c..387d2e9cb51f 100644 --- a/arch/arm/kernel/setup.c +++ b/arch/arm/kernel/setup.c | |||
@@ -402,13 +402,12 @@ static int __init arm_add_memory(unsigned long start, unsigned long size) | |||
402 | size -= start & ~PAGE_MASK; | 402 | size -= start & ~PAGE_MASK; |
403 | bank->start = PAGE_ALIGN(start); | 403 | bank->start = PAGE_ALIGN(start); |
404 | bank->size = size & PAGE_MASK; | 404 | bank->size = size & PAGE_MASK; |
405 | bank->node = PHYS_TO_NID(start); | ||
406 | 405 | ||
407 | /* | 406 | /* |
408 | * Check whether this memory region has non-zero size or | 407 | * Check whether this memory region has non-zero size or |
409 | * invalid node number. | 408 | * invalid node number. |
410 | */ | 409 | */ |
411 | if (bank->size == 0 || bank->node >= MAX_NUMNODES) | 410 | if (bank->size == 0) |
412 | return -EINVAL; | 411 | return -EINVAL; |
413 | 412 | ||
414 | meminfo.nr_banks++; | 413 | meminfo.nr_banks++; |
diff --git a/arch/arm/mach-aaec2000/include/mach/memory.h b/arch/arm/mach-aaec2000/include/mach/memory.h index c00822543d9f..4f93c567a35a 100644 --- a/arch/arm/mach-aaec2000/include/mach/memory.h +++ b/arch/arm/mach-aaec2000/include/mach/memory.h | |||
@@ -14,14 +14,4 @@ | |||
14 | 14 | ||
15 | #define PHYS_OFFSET UL(0xf0000000) | 15 | #define PHYS_OFFSET UL(0xf0000000) |
16 | 16 | ||
17 | /* | ||
18 | * The nodes are the followings: | ||
19 | * | ||
20 | * node 0: 0xf000.0000 - 0xf3ff.ffff | ||
21 | * node 1: 0xf400.0000 - 0xf7ff.ffff | ||
22 | * node 2: 0xf800.0000 - 0xfbff.ffff | ||
23 | * node 3: 0xfc00.0000 - 0xffff.ffff | ||
24 | */ | ||
25 | #define NODE_MEM_SIZE_BITS 26 | ||
26 | |||
27 | #endif /* __ASM_ARCH_MEMORY_H */ | 17 | #endif /* __ASM_ARCH_MEMORY_H */ |
diff --git a/arch/arm/mach-clps711x/Kconfig b/arch/arm/mach-clps711x/Kconfig index dbaae5f746a1..eb34bd1251d4 100644 --- a/arch/arm/mach-clps711x/Kconfig +++ b/arch/arm/mach-clps711x/Kconfig | |||
@@ -30,7 +30,6 @@ config ARCH_CLEP7312 | |||
30 | config ARCH_EDB7211 | 30 | config ARCH_EDB7211 |
31 | bool "EDB7211" | 31 | bool "EDB7211" |
32 | select ISA | 32 | select ISA |
33 | select ARCH_DISCONTIGMEM_ENABLE | ||
34 | select ARCH_SPARSEMEM_ENABLE | 33 | select ARCH_SPARSEMEM_ENABLE |
35 | select ARCH_SELECT_MEMORY_MODEL | 34 | select ARCH_SELECT_MEMORY_MODEL |
36 | help | 35 | help |
diff --git a/arch/arm/mach-clps711x/clep7312.c b/arch/arm/mach-clps711x/clep7312.c index 09fb57e45213..3c3bf45039ff 100644 --- a/arch/arm/mach-clps711x/clep7312.c +++ b/arch/arm/mach-clps711x/clep7312.c | |||
@@ -32,7 +32,6 @@ fixup_clep7312(struct machine_desc *desc, struct tag *tags, | |||
32 | mi->nr_banks=1; | 32 | mi->nr_banks=1; |
33 | mi->bank[0].start = 0xc0000000; | 33 | mi->bank[0].start = 0xc0000000; |
34 | mi->bank[0].size = 0x01000000; | 34 | mi->bank[0].size = 0x01000000; |
35 | mi->bank[0].node = 0; | ||
36 | } | 35 | } |
37 | 36 | ||
38 | 37 | ||
diff --git a/arch/arm/mach-clps711x/edb7211-arch.c b/arch/arm/mach-clps711x/edb7211-arch.c index dc81cc68595d..41a4425617c1 100644 --- a/arch/arm/mach-clps711x/edb7211-arch.c +++ b/arch/arm/mach-clps711x/edb7211-arch.c | |||
@@ -43,10 +43,8 @@ fixup_edb7211(struct machine_desc *desc, struct tag *tags, | |||
43 | */ | 43 | */ |
44 | mi->bank[0].start = 0xc0000000; | 44 | mi->bank[0].start = 0xc0000000; |
45 | mi->bank[0].size = 8*1024*1024; | 45 | mi->bank[0].size = 8*1024*1024; |
46 | mi->bank[0].node = 0; | ||
47 | mi->bank[1].start = 0xc1000000; | 46 | mi->bank[1].start = 0xc1000000; |
48 | mi->bank[1].size = 8*1024*1024; | 47 | mi->bank[1].size = 8*1024*1024; |
49 | mi->bank[1].node = 1; | ||
50 | mi->nr_banks = 2; | 48 | mi->nr_banks = 2; |
51 | } | 49 | } |
52 | 50 | ||
diff --git a/arch/arm/mach-clps711x/fortunet.c b/arch/arm/mach-clps711x/fortunet.c index 7430e4049d87..a696099aa4f8 100644 --- a/arch/arm/mach-clps711x/fortunet.c +++ b/arch/arm/mach-clps711x/fortunet.c | |||
@@ -39,7 +39,6 @@ struct meminfo memmap = { | |||
39 | { | 39 | { |
40 | .start = 0xC0000000, | 40 | .start = 0xC0000000, |
41 | .size = 0x01000000, | 41 | .size = 0x01000000, |
42 | .node = 0 | ||
43 | }, | 42 | }, |
44 | }, | 43 | }, |
45 | }; | 44 | }; |
diff --git a/arch/arm/mach-clps711x/include/mach/memory.h b/arch/arm/mach-clps711x/include/mach/memory.h index f70d52be48a2..f45c8e892cb5 100644 --- a/arch/arm/mach-clps711x/include/mach/memory.h +++ b/arch/arm/mach-clps711x/include/mach/memory.h | |||
@@ -20,7 +20,6 @@ | |||
20 | #ifndef __ASM_ARCH_MEMORY_H | 20 | #ifndef __ASM_ARCH_MEMORY_H |
21 | #define __ASM_ARCH_MEMORY_H | 21 | #define __ASM_ARCH_MEMORY_H |
22 | 22 | ||
23 | |||
24 | /* | 23 | /* |
25 | * Physical DRAM offset. | 24 | * Physical DRAM offset. |
26 | */ | 25 | */ |
@@ -72,7 +71,6 @@ | |||
72 | * node 2: 0xd0000000 - 0xd7ffffff | 71 | * node 2: 0xd0000000 - 0xd7ffffff |
73 | * node 3: 0xd8000000 - 0xdfffffff | 72 | * node 3: 0xd8000000 - 0xdfffffff |
74 | */ | 73 | */ |
75 | #define NODE_MEM_SIZE_BITS 24 | ||
76 | #define SECTION_SIZE_BITS 24 | 74 | #define SECTION_SIZE_BITS 24 |
77 | #define MAX_PHYSMEM_BITS 32 | 75 | #define MAX_PHYSMEM_BITS 32 |
78 | 76 | ||
diff --git a/arch/arm/mach-iop13xx/include/mach/memory.h b/arch/arm/mach-iop13xx/include/mach/memory.h index 25b1da9a5035..7415e4338651 100644 --- a/arch/arm/mach-iop13xx/include/mach/memory.h +++ b/arch/arm/mach-iop13xx/include/mach/memory.h | |||
@@ -69,6 +69,4 @@ static inline unsigned long __lbus_to_virt(dma_addr_t x) | |||
69 | #endif /* CONFIG_ARCH_IOP13XX */ | 69 | #endif /* CONFIG_ARCH_IOP13XX */ |
70 | #endif /* !ASSEMBLY */ | 70 | #endif /* !ASSEMBLY */ |
71 | 71 | ||
72 | #define PFN_TO_NID(addr) (0) | ||
73 | |||
74 | #endif | 72 | #endif |
diff --git a/arch/arm/mach-lh7a40x/include/mach/memory.h b/arch/arm/mach-lh7a40x/include/mach/memory.h index 189d20e543e7..edb8f5faf5d5 100644 --- a/arch/arm/mach-lh7a40x/include/mach/memory.h +++ b/arch/arm/mach-lh7a40x/include/mach/memory.h | |||
@@ -19,50 +19,6 @@ | |||
19 | */ | 19 | */ |
20 | #define PHYS_OFFSET UL(0xc0000000) | 20 | #define PHYS_OFFSET UL(0xc0000000) |
21 | 21 | ||
22 | #ifdef CONFIG_DISCONTIGMEM | ||
23 | |||
24 | /* | ||
25 | * Given a kernel address, find the home node of the underlying memory. | ||
26 | */ | ||
27 | |||
28 | # ifdef CONFIG_LH7A40X_ONE_BANK_PER_NODE | ||
29 | # define KVADDR_TO_NID(addr) \ | ||
30 | ( ((((unsigned long) (addr) - PAGE_OFFSET) >> 24) & 1)\ | ||
31 | | ((((unsigned long) (addr) - PAGE_OFFSET) >> 25) & ~1)) | ||
32 | # else /* 2 banks per node */ | ||
33 | # define KVADDR_TO_NID(addr) \ | ||
34 | (((unsigned long) (addr) - PAGE_OFFSET) >> 26) | ||
35 | # endif | ||
36 | |||
37 | /* | ||
38 | * Given a page frame number, convert it to a node id. | ||
39 | */ | ||
40 | |||
41 | # ifdef CONFIG_LH7A40X_ONE_BANK_PER_NODE | ||
42 | # define PFN_TO_NID(pfn) \ | ||
43 | (((((pfn) - PHYS_PFN_OFFSET) >> (24 - PAGE_SHIFT)) & 1)\ | ||
44 | | ((((pfn) - PHYS_PFN_OFFSET) >> (25 - PAGE_SHIFT)) & ~1)) | ||
45 | # else /* 2 banks per node */ | ||
46 | # define PFN_TO_NID(pfn) \ | ||
47 | (((pfn) - PHYS_PFN_OFFSET) >> (26 - PAGE_SHIFT)) | ||
48 | #endif | ||
49 | |||
50 | /* | ||
51 | * Given a kaddr, LOCAL_MEM_MAP finds the owning node of the memory | ||
52 | * and returns the index corresponding to the appropriate page in the | ||
53 | * node's mem_map. | ||
54 | */ | ||
55 | |||
56 | # ifdef CONFIG_LH7A40X_ONE_BANK_PER_NODE | ||
57 | # define LOCAL_MAP_NR(addr) \ | ||
58 | (((unsigned long)(addr) & 0x003fffff) >> PAGE_SHIFT) | ||
59 | # else /* 2 banks per node */ | ||
60 | # define LOCAL_MAP_NR(addr) \ | ||
61 | (((unsigned long)(addr) & 0x01ffffff) >> PAGE_SHIFT) | ||
62 | # endif | ||
63 | |||
64 | #endif | ||
65 | |||
66 | /* | 22 | /* |
67 | * Sparsemem version of the above | 23 | * Sparsemem version of the above |
68 | */ | 24 | */ |
diff --git a/arch/arm/mach-msm/board-trout.c b/arch/arm/mach-msm/board-trout.c index dca5a5f062dc..e69a1502e4e8 100644 --- a/arch/arm/mach-msm/board-trout.c +++ b/arch/arm/mach-msm/board-trout.c | |||
@@ -50,7 +50,6 @@ static void __init trout_fixup(struct machine_desc *desc, struct tag *tags, | |||
50 | { | 50 | { |
51 | mi->nr_banks = 1; | 51 | mi->nr_banks = 1; |
52 | mi->bank[0].start = PHYS_OFFSET; | 52 | mi->bank[0].start = PHYS_OFFSET; |
53 | mi->bank[0].node = PHYS_TO_NID(PHYS_OFFSET); | ||
54 | mi->bank[0].size = (101*1024*1024); | 53 | mi->bank[0].size = (101*1024*1024); |
55 | } | 54 | } |
56 | 55 | ||
diff --git a/arch/arm/mach-pxa/corgi.c b/arch/arm/mach-pxa/corgi.c index 3d1dcb9ac08f..95234fb4fcf8 100644 --- a/arch/arm/mach-pxa/corgi.c +++ b/arch/arm/mach-pxa/corgi.c | |||
@@ -715,7 +715,6 @@ static void __init fixup_corgi(struct machine_desc *desc, | |||
715 | sharpsl_save_param(); | 715 | sharpsl_save_param(); |
716 | mi->nr_banks=1; | 716 | mi->nr_banks=1; |
717 | mi->bank[0].start = 0xa0000000; | 717 | mi->bank[0].start = 0xa0000000; |
718 | mi->bank[0].node = 0; | ||
719 | if (machine_is_corgi()) | 718 | if (machine_is_corgi()) |
720 | mi->bank[0].size = (32*1024*1024); | 719 | mi->bank[0].size = (32*1024*1024); |
721 | else | 720 | else |
diff --git a/arch/arm/mach-pxa/eseries.c b/arch/arm/mach-pxa/eseries.c index 96ed13081639..a0ab3082a000 100644 --- a/arch/arm/mach-pxa/eseries.c +++ b/arch/arm/mach-pxa/eseries.c | |||
@@ -34,7 +34,6 @@ void __init eseries_fixup(struct machine_desc *desc, | |||
34 | { | 34 | { |
35 | mi->nr_banks=1; | 35 | mi->nr_banks=1; |
36 | mi->bank[0].start = 0xa0000000; | 36 | mi->bank[0].start = 0xa0000000; |
37 | mi->bank[0].node = 0; | ||
38 | if (machine_is_e800()) | 37 | if (machine_is_e800()) |
39 | mi->bank[0].size = (128*1024*1024); | 38 | mi->bank[0].size = (128*1024*1024); |
40 | else | 39 | else |
diff --git a/arch/arm/mach-pxa/generic.h b/arch/arm/mach-pxa/generic.h index 890fb90a672f..c6305c5b8a72 100644 --- a/arch/arm/mach-pxa/generic.h +++ b/arch/arm/mach-pxa/generic.h | |||
@@ -26,8 +26,7 @@ extern unsigned int get_clk_frequency_khz(int info); | |||
26 | 26 | ||
27 | #define SET_BANK(__nr,__start,__size) \ | 27 | #define SET_BANK(__nr,__start,__size) \ |
28 | mi->bank[__nr].start = (__start), \ | 28 | mi->bank[__nr].start = (__start), \ |
29 | mi->bank[__nr].size = (__size), \ | 29 | mi->bank[__nr].size = (__size) |
30 | mi->bank[__nr].node = (((unsigned)(__start) - PHYS_OFFSET) >> 27) | ||
31 | 30 | ||
32 | #define ARRAY_AND_SIZE(x) (x), ARRAY_SIZE(x) | 31 | #define ARRAY_AND_SIZE(x) (x), ARRAY_SIZE(x) |
33 | 32 | ||
diff --git a/arch/arm/mach-pxa/include/mach/memory.h b/arch/arm/mach-pxa/include/mach/memory.h index f626730ee42e..81fd4a081c82 100644 --- a/arch/arm/mach-pxa/include/mach/memory.h +++ b/arch/arm/mach-pxa/include/mach/memory.h | |||
@@ -17,18 +17,6 @@ | |||
17 | */ | 17 | */ |
18 | #define PHYS_OFFSET UL(0xa0000000) | 18 | #define PHYS_OFFSET UL(0xa0000000) |
19 | 19 | ||
20 | /* | ||
21 | * The nodes are matched with the physical SDRAM banks as follows: | ||
22 | * | ||
23 | * node 0: 0xa0000000-0xa3ffffff --> 0xc0000000-0xc3ffffff | ||
24 | * node 1: 0xa4000000-0xa7ffffff --> 0xc4000000-0xc7ffffff | ||
25 | * node 2: 0xa8000000-0xabffffff --> 0xc8000000-0xcbffffff | ||
26 | * node 3: 0xac000000-0xafffffff --> 0xcc000000-0xcfffffff | ||
27 | * | ||
28 | * This needs a node mem size of 26 bits. | ||
29 | */ | ||
30 | #define NODE_MEM_SIZE_BITS 26 | ||
31 | |||
32 | #if !defined(__ASSEMBLY__) && defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) | 20 | #if !defined(__ASSEMBLY__) && defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) |
33 | void cmx2xx_pci_adjust_zones(int node, unsigned long *size, | 21 | void cmx2xx_pci_adjust_zones(int node, unsigned long *size, |
34 | unsigned long *holes); | 22 | unsigned long *holes); |
diff --git a/arch/arm/mach-pxa/poodle.c b/arch/arm/mach-pxa/poodle.c index f4abdaafdac4..bc2758b54446 100644 --- a/arch/arm/mach-pxa/poodle.c +++ b/arch/arm/mach-pxa/poodle.c | |||
@@ -463,7 +463,6 @@ static void __init fixup_poodle(struct machine_desc *desc, | |||
463 | sharpsl_save_param(); | 463 | sharpsl_save_param(); |
464 | mi->nr_banks=1; | 464 | mi->nr_banks=1; |
465 | mi->bank[0].start = 0xa0000000; | 465 | mi->bank[0].start = 0xa0000000; |
466 | mi->bank[0].node = 0; | ||
467 | mi->bank[0].size = (32*1024*1024); | 466 | mi->bank[0].size = (32*1024*1024); |
468 | } | 467 | } |
469 | 468 | ||
diff --git a/arch/arm/mach-pxa/spitz.c b/arch/arm/mach-pxa/spitz.c index c1048a35f187..51756c723557 100644 --- a/arch/arm/mach-pxa/spitz.c +++ b/arch/arm/mach-pxa/spitz.c | |||
@@ -847,7 +847,6 @@ static void __init fixup_spitz(struct machine_desc *desc, | |||
847 | sharpsl_save_param(); | 847 | sharpsl_save_param(); |
848 | mi->nr_banks = 1; | 848 | mi->nr_banks = 1; |
849 | mi->bank[0].start = 0xa0000000; | 849 | mi->bank[0].start = 0xa0000000; |
850 | mi->bank[0].node = 0; | ||
851 | mi->bank[0].size = (64*1024*1024); | 850 | mi->bank[0].size = (64*1024*1024); |
852 | } | 851 | } |
853 | 852 | ||
diff --git a/arch/arm/mach-pxa/tosa.c b/arch/arm/mach-pxa/tosa.c index 7512b822c6ca..83cc3a18c2e9 100644 --- a/arch/arm/mach-pxa/tosa.c +++ b/arch/arm/mach-pxa/tosa.c | |||
@@ -948,7 +948,6 @@ static void __init fixup_tosa(struct machine_desc *desc, | |||
948 | sharpsl_save_param(); | 948 | sharpsl_save_param(); |
949 | mi->nr_banks=1; | 949 | mi->nr_banks=1; |
950 | mi->bank[0].start = 0xa0000000; | 950 | mi->bank[0].start = 0xa0000000; |
951 | mi->bank[0].node = 0; | ||
952 | mi->bank[0].size = (64*1024*1024); | 951 | mi->bank[0].size = (64*1024*1024); |
953 | } | 952 | } |
954 | 953 | ||
diff --git a/arch/arm/mach-s3c2412/mach-smdk2413.c b/arch/arm/mach-s3c2412/mach-smdk2413.c index ba93a356a839..054c9f92232a 100644 --- a/arch/arm/mach-s3c2412/mach-smdk2413.c +++ b/arch/arm/mach-s3c2412/mach-smdk2413.c | |||
@@ -119,7 +119,6 @@ static void __init smdk2413_fixup(struct machine_desc *desc, | |||
119 | mi->nr_banks=1; | 119 | mi->nr_banks=1; |
120 | mi->bank[0].start = 0x30000000; | 120 | mi->bank[0].start = 0x30000000; |
121 | mi->bank[0].size = SZ_64M; | 121 | mi->bank[0].size = SZ_64M; |
122 | mi->bank[0].node = 0; | ||
123 | } | 122 | } |
124 | } | 123 | } |
125 | 124 | ||
diff --git a/arch/arm/mach-s3c2412/mach-vstms.c b/arch/arm/mach-s3c2412/mach-vstms.c index 3ca9265b6997..f291ac25d312 100644 --- a/arch/arm/mach-s3c2412/mach-vstms.c +++ b/arch/arm/mach-s3c2412/mach-vstms.c | |||
@@ -137,7 +137,6 @@ static void __init vstms_fixup(struct machine_desc *desc, | |||
137 | mi->nr_banks=1; | 137 | mi->nr_banks=1; |
138 | mi->bank[0].start = 0x30000000; | 138 | mi->bank[0].start = 0x30000000; |
139 | mi->bank[0].size = SZ_64M; | 139 | mi->bank[0].size = SZ_64M; |
140 | mi->bank[0].node = 0; | ||
141 | } | 140 | } |
142 | } | 141 | } |
143 | 142 | ||
diff --git a/arch/arm/mach-sa1100/generic.h b/arch/arm/mach-sa1100/generic.h index ec03f187c52b..b7a9a601c2d1 100644 --- a/arch/arm/mach-sa1100/generic.h +++ b/arch/arm/mach-sa1100/generic.h | |||
@@ -13,8 +13,7 @@ extern void __init sa1100_init_gpio(void); | |||
13 | 13 | ||
14 | #define SET_BANK(__nr,__start,__size) \ | 14 | #define SET_BANK(__nr,__start,__size) \ |
15 | mi->bank[__nr].start = (__start), \ | 15 | mi->bank[__nr].start = (__start), \ |
16 | mi->bank[__nr].size = (__size), \ | 16 | mi->bank[__nr].size = (__size) |
17 | mi->bank[__nr].node = (((unsigned)(__start) - PHYS_OFFSET) >> 27) | ||
18 | 17 | ||
19 | extern void (*sa1100fb_backlight_power)(int on); | 18 | extern void (*sa1100fb_backlight_power)(int on); |
20 | extern void (*sa1100fb_lcd_power)(int on); | 19 | extern void (*sa1100fb_lcd_power)(int on); |
diff --git a/arch/arm/mm/Makefile b/arch/arm/mm/Makefile index e8d34a80851c..d63b6c413758 100644 --- a/arch/arm/mm/Makefile +++ b/arch/arm/mm/Makefile | |||
@@ -15,7 +15,6 @@ endif | |||
15 | obj-$(CONFIG_MODULES) += proc-syms.o | 15 | obj-$(CONFIG_MODULES) += proc-syms.o |
16 | 16 | ||
17 | obj-$(CONFIG_ALIGNMENT_TRAP) += alignment.o | 17 | obj-$(CONFIG_ALIGNMENT_TRAP) += alignment.o |
18 | obj-$(CONFIG_DISCONTIGMEM) += discontig.o | ||
19 | obj-$(CONFIG_HIGHMEM) += highmem.o | 18 | obj-$(CONFIG_HIGHMEM) += highmem.o |
20 | 19 | ||
21 | obj-$(CONFIG_CPU_ABRT_NOMMU) += abort-nommu.o | 20 | obj-$(CONFIG_CPU_ABRT_NOMMU) += abort-nommu.o |
diff --git a/arch/arm/mm/discontig.c b/arch/arm/mm/discontig.c deleted file mode 100644 index c8c0c4b0f0a3..000000000000 --- a/arch/arm/mm/discontig.c +++ /dev/null | |||
@@ -1,45 +0,0 @@ | |||
1 | /* | ||
2 | * linux/arch/arm/mm/discontig.c | ||
3 | * | ||
4 | * Discontiguous memory support. | ||
5 | * | ||
6 | * Initial code: Copyright (C) 1999-2000 Nicolas Pitre | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | #include <linux/module.h> | ||
13 | #include <linux/mmzone.h> | ||
14 | #include <linux/bootmem.h> | ||
15 | |||
16 | #if MAX_NUMNODES != 4 && MAX_NUMNODES != 16 | ||
17 | # error Fix Me Please | ||
18 | #endif | ||
19 | |||
20 | /* | ||
21 | * Our node_data structure for discontiguous memory. | ||
22 | */ | ||
23 | |||
24 | pg_data_t discontig_node_data[MAX_NUMNODES] = { | ||
25 | { .bdata = &bootmem_node_data[0] }, | ||
26 | { .bdata = &bootmem_node_data[1] }, | ||
27 | { .bdata = &bootmem_node_data[2] }, | ||
28 | { .bdata = &bootmem_node_data[3] }, | ||
29 | #if MAX_NUMNODES == 16 | ||
30 | { .bdata = &bootmem_node_data[4] }, | ||
31 | { .bdata = &bootmem_node_data[5] }, | ||
32 | { .bdata = &bootmem_node_data[6] }, | ||
33 | { .bdata = &bootmem_node_data[7] }, | ||
34 | { .bdata = &bootmem_node_data[8] }, | ||
35 | { .bdata = &bootmem_node_data[9] }, | ||
36 | { .bdata = &bootmem_node_data[10] }, | ||
37 | { .bdata = &bootmem_node_data[11] }, | ||
38 | { .bdata = &bootmem_node_data[12] }, | ||
39 | { .bdata = &bootmem_node_data[13] }, | ||
40 | { .bdata = &bootmem_node_data[14] }, | ||
41 | { .bdata = &bootmem_node_data[15] }, | ||
42 | #endif | ||
43 | }; | ||
44 | |||
45 | EXPORT_SYMBOL(discontig_node_data); | ||
diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index f6a999465323..4011e524cb1d 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c | |||
@@ -79,38 +79,37 @@ struct meminfo meminfo; | |||
79 | void show_mem(void) | 79 | void show_mem(void) |
80 | { | 80 | { |
81 | int free = 0, total = 0, reserved = 0; | 81 | int free = 0, total = 0, reserved = 0; |
82 | int shared = 0, cached = 0, slab = 0, node, i; | 82 | int shared = 0, cached = 0, slab = 0, i; |
83 | struct meminfo * mi = &meminfo; | 83 | struct meminfo * mi = &meminfo; |
84 | 84 | ||
85 | printk("Mem-info:\n"); | 85 | printk("Mem-info:\n"); |
86 | show_free_areas(); | 86 | show_free_areas(); |
87 | for_each_online_node(node) { | 87 | |
88 | for_each_nodebank (i,mi,node) { | 88 | for_each_bank (i, mi) { |
89 | struct membank *bank = &mi->bank[i]; | 89 | struct membank *bank = &mi->bank[i]; |
90 | unsigned int pfn1, pfn2; | 90 | unsigned int pfn1, pfn2; |
91 | struct page *page, *end; | 91 | struct page *page, *end; |
92 | 92 | ||
93 | pfn1 = bank_pfn_start(bank); | 93 | pfn1 = bank_pfn_start(bank); |
94 | pfn2 = bank_pfn_end(bank); | 94 | pfn2 = bank_pfn_end(bank); |
95 | 95 | ||
96 | page = pfn_to_page(pfn1); | 96 | page = pfn_to_page(pfn1); |
97 | end = pfn_to_page(pfn2 - 1) + 1; | 97 | end = pfn_to_page(pfn2 - 1) + 1; |
98 | 98 | ||
99 | do { | 99 | do { |
100 | total++; | 100 | total++; |
101 | if (PageReserved(page)) | 101 | if (PageReserved(page)) |
102 | reserved++; | 102 | reserved++; |
103 | else if (PageSwapCache(page)) | 103 | else if (PageSwapCache(page)) |
104 | cached++; | 104 | cached++; |
105 | else if (PageSlab(page)) | 105 | else if (PageSlab(page)) |
106 | slab++; | 106 | slab++; |
107 | else if (!page_count(page)) | 107 | else if (!page_count(page)) |
108 | free++; | 108 | free++; |
109 | else | 109 | else |
110 | shared += page_count(page) - 1; | 110 | shared += page_count(page) - 1; |
111 | page++; | 111 | page++; |
112 | } while (page < end); | 112 | } while (page < end); |
113 | } | ||
114 | } | 113 | } |
115 | 114 | ||
116 | printk("%d pages of RAM\n", total); | 115 | printk("%d pages of RAM\n", total); |
@@ -121,7 +120,7 @@ void show_mem(void) | |||
121 | printk("%d pages swap cached\n", cached); | 120 | printk("%d pages swap cached\n", cached); |
122 | } | 121 | } |
123 | 122 | ||
124 | static void __init find_node_limits(int node, struct meminfo *mi, | 123 | static void __init find_limits(struct meminfo *mi, |
125 | unsigned long *min, unsigned long *max_low, unsigned long *max_high) | 124 | unsigned long *min, unsigned long *max_low, unsigned long *max_high) |
126 | { | 125 | { |
127 | int i; | 126 | int i; |
@@ -129,7 +128,7 @@ static void __init find_node_limits(int node, struct meminfo *mi, | |||
129 | *min = -1UL; | 128 | *min = -1UL; |
130 | *max_low = *max_high = 0; | 129 | *max_low = *max_high = 0; |
131 | 130 | ||
132 | for_each_nodebank(i, mi, node) { | 131 | for_each_bank (i, mi) { |
133 | struct membank *bank = &mi->bank[i]; | 132 | struct membank *bank = &mi->bank[i]; |
134 | unsigned long start, end; | 133 | unsigned long start, end; |
135 | 134 | ||
@@ -154,14 +153,14 @@ static void __init find_node_limits(int node, struct meminfo *mi, | |||
154 | * the end, we won't clash. | 153 | * the end, we won't clash. |
155 | */ | 154 | */ |
156 | static unsigned int __init | 155 | static unsigned int __init |
157 | find_bootmap_pfn(int node, struct meminfo *mi, unsigned int bootmap_pages) | 156 | find_bootmap_pfn(struct meminfo *mi, unsigned int bootmap_pages) |
158 | { | 157 | { |
159 | unsigned int start_pfn, i, bootmap_pfn; | 158 | unsigned int start_pfn, i, bootmap_pfn; |
160 | 159 | ||
161 | start_pfn = PAGE_ALIGN(__pa(_end)) >> PAGE_SHIFT; | 160 | start_pfn = PAGE_ALIGN(__pa(_end)) >> PAGE_SHIFT; |
162 | bootmap_pfn = 0; | 161 | bootmap_pfn = 0; |
163 | 162 | ||
164 | for_each_nodebank(i, mi, node) { | 163 | for_each_bank(i, mi) { |
165 | struct membank *bank = &mi->bank[i]; | 164 | struct membank *bank = &mi->bank[i]; |
166 | unsigned int start, end; | 165 | unsigned int start, end; |
167 | 166 | ||
@@ -191,7 +190,7 @@ find_bootmap_pfn(int node, struct meminfo *mi, unsigned int bootmap_pages) | |||
191 | 190 | ||
192 | static int __init check_initrd(struct meminfo *mi) | 191 | static int __init check_initrd(struct meminfo *mi) |
193 | { | 192 | { |
194 | int initrd_node = -2; | 193 | int initrd = -2; |
195 | #ifdef CONFIG_BLK_DEV_INITRD | 194 | #ifdef CONFIG_BLK_DEV_INITRD |
196 | unsigned long end = phys_initrd_start + phys_initrd_size; | 195 | unsigned long end = phys_initrd_start + phys_initrd_size; |
197 | 196 | ||
@@ -202,17 +201,17 @@ static int __init check_initrd(struct meminfo *mi) | |||
202 | if (phys_initrd_size) { | 201 | if (phys_initrd_size) { |
203 | unsigned int i; | 202 | unsigned int i; |
204 | 203 | ||
205 | initrd_node = -1; | 204 | initrd = -1; |
206 | 205 | ||
207 | for (i = 0; i < mi->nr_banks; i++) { | 206 | for (i = 0; i < mi->nr_banks; i++) { |
208 | struct membank *bank = &mi->bank[i]; | 207 | struct membank *bank = &mi->bank[i]; |
209 | if (bank_phys_start(bank) <= phys_initrd_start && | 208 | if (bank_phys_start(bank) <= phys_initrd_start && |
210 | end <= bank_phys_end(bank)) | 209 | end <= bank_phys_end(bank)) |
211 | initrd_node = bank->node; | 210 | initrd = 0; |
212 | } | 211 | } |
213 | } | 212 | } |
214 | 213 | ||
215 | if (initrd_node == -1) { | 214 | if (initrd == -1) { |
216 | printk(KERN_ERR "INITRD: 0x%08lx+0x%08lx extends beyond " | 215 | printk(KERN_ERR "INITRD: 0x%08lx+0x%08lx extends beyond " |
217 | "physical memory - disabling initrd\n", | 216 | "physical memory - disabling initrd\n", |
218 | phys_initrd_start, phys_initrd_size); | 217 | phys_initrd_start, phys_initrd_size); |
@@ -220,10 +219,10 @@ static int __init check_initrd(struct meminfo *mi) | |||
220 | } | 219 | } |
221 | #endif | 220 | #endif |
222 | 221 | ||
223 | return initrd_node; | 222 | return initrd; |
224 | } | 223 | } |
225 | 224 | ||
226 | static void __init bootmem_init_node(int node, struct meminfo *mi, | 225 | static void __init arm_bootmem_init(struct meminfo *mi, |
227 | unsigned long start_pfn, unsigned long end_pfn) | 226 | unsigned long start_pfn, unsigned long end_pfn) |
228 | { | 227 | { |
229 | unsigned long boot_pfn; | 228 | unsigned long boot_pfn; |
@@ -235,37 +234,36 @@ static void __init bootmem_init_node(int node, struct meminfo *mi, | |||
235 | * Allocate the bootmem bitmap page. | 234 | * Allocate the bootmem bitmap page. |
236 | */ | 235 | */ |
237 | boot_pages = bootmem_bootmap_pages(end_pfn - start_pfn); | 236 | boot_pages = bootmem_bootmap_pages(end_pfn - start_pfn); |
238 | boot_pfn = find_bootmap_pfn(node, mi, boot_pages); | 237 | boot_pfn = find_bootmap_pfn(mi, boot_pages); |
239 | 238 | ||
240 | /* | 239 | /* |
241 | * Initialise the bootmem allocator for this node, handing the | 240 | * Initialise the bootmem allocator, handing the |
242 | * memory banks over to bootmem. | 241 | * memory banks over to bootmem. |
243 | */ | 242 | */ |
244 | node_set_online(node); | 243 | node_set_online(0); |
245 | pgdat = NODE_DATA(node); | 244 | pgdat = NODE_DATA(0); |
246 | init_bootmem_node(pgdat, boot_pfn, start_pfn, end_pfn); | 245 | init_bootmem_node(pgdat, boot_pfn, start_pfn, end_pfn); |
247 | 246 | ||
248 | for_each_nodebank(i, mi, node) { | 247 | for_each_bank(i, mi) { |
249 | struct membank *bank = &mi->bank[i]; | 248 | struct membank *bank = &mi->bank[i]; |
250 | if (!bank->highmem) | 249 | if (!bank->highmem) |
251 | free_bootmem_node(pgdat, bank_phys_start(bank), bank_phys_size(bank)); | 250 | free_bootmem(bank_phys_start(bank), bank_phys_size(bank)); |
252 | } | 251 | } |
253 | 252 | ||
254 | /* | 253 | /* |
255 | * Reserve the bootmem bitmap for this node. | 254 | * Reserve the bootmem bitmap. |
256 | */ | 255 | */ |
257 | reserve_bootmem_node(pgdat, boot_pfn << PAGE_SHIFT, | 256 | reserve_bootmem(boot_pfn << PAGE_SHIFT, |
258 | boot_pages << PAGE_SHIFT, BOOTMEM_DEFAULT); | 257 | boot_pages << PAGE_SHIFT, BOOTMEM_DEFAULT); |
259 | } | 258 | } |
260 | 259 | ||
261 | static void __init bootmem_reserve_initrd(int node) | 260 | static void __init bootmem_reserve_initrd(void) |
262 | { | 261 | { |
263 | #ifdef CONFIG_BLK_DEV_INITRD | 262 | #ifdef CONFIG_BLK_DEV_INITRD |
264 | pg_data_t *pgdat = NODE_DATA(node); | ||
265 | int res; | 263 | int res; |
266 | 264 | ||
267 | res = reserve_bootmem_node(pgdat, phys_initrd_start, | 265 | res = reserve_bootmem(phys_initrd_start, |
268 | phys_initrd_size, BOOTMEM_EXCLUSIVE); | 266 | phys_initrd_size, BOOTMEM_EXCLUSIVE); |
269 | 267 | ||
270 | if (res == 0) { | 268 | if (res == 0) { |
271 | initrd_start = __phys_to_virt(phys_initrd_start); | 269 | initrd_start = __phys_to_virt(phys_initrd_start); |
@@ -279,23 +277,23 @@ static void __init bootmem_reserve_initrd(int node) | |||
279 | #endif | 277 | #endif |
280 | } | 278 | } |
281 | 279 | ||
282 | static void __init bootmem_free_node(int node, struct meminfo *mi) | 280 | static void __init arm_bootmem_free(struct meminfo *mi) |
283 | { | 281 | { |
284 | unsigned long zone_size[MAX_NR_ZONES], zhole_size[MAX_NR_ZONES]; | 282 | unsigned long zone_size[MAX_NR_ZONES], zhole_size[MAX_NR_ZONES]; |
285 | unsigned long min, max_low, max_high; | 283 | unsigned long min, max_low, max_high; |
286 | int i; | 284 | int i; |
287 | 285 | ||
288 | find_node_limits(node, mi, &min, &max_low, &max_high); | 286 | find_limits(mi, &min, &max_low, &max_high); |
289 | 287 | ||
290 | /* | 288 | /* |
291 | * initialise the zones within this node. | 289 | * initialise the zones. |
292 | */ | 290 | */ |
293 | memset(zone_size, 0, sizeof(zone_size)); | 291 | memset(zone_size, 0, sizeof(zone_size)); |
294 | 292 | ||
295 | /* | 293 | /* |
296 | * The size of this node has already been determined. If we need | 294 | * The memory size has already been determined. If we need |
297 | * to do anything fancy with the allocation of this memory to the | 295 | * to do anything fancy with the allocation of this memory |
298 | * zones, now is the time to do it. | 296 | * to the zones, now is the time to do it. |
299 | */ | 297 | */ |
300 | zone_size[0] = max_low - min; | 298 | zone_size[0] = max_low - min; |
301 | #ifdef CONFIG_HIGHMEM | 299 | #ifdef CONFIG_HIGHMEM |
@@ -303,11 +301,11 @@ static void __init bootmem_free_node(int node, struct meminfo *mi) | |||
303 | #endif | 301 | #endif |
304 | 302 | ||
305 | /* | 303 | /* |
306 | * For each bank in this node, calculate the size of the holes. | 304 | * Calculate the size of the holes. |
307 | * holes = node_size - sum(bank_sizes_in_node) | 305 | * holes = node_size - sum(bank_sizes) |
308 | */ | 306 | */ |
309 | memcpy(zhole_size, zone_size, sizeof(zhole_size)); | 307 | memcpy(zhole_size, zone_size, sizeof(zhole_size)); |
310 | for_each_nodebank(i, mi, node) { | 308 | for_each_bank(i, mi) { |
311 | int idx = 0; | 309 | int idx = 0; |
312 | #ifdef CONFIG_HIGHMEM | 310 | #ifdef CONFIG_HIGHMEM |
313 | if (mi->bank[i].highmem) | 311 | if (mi->bank[i].highmem) |
@@ -320,9 +318,9 @@ static void __init bootmem_free_node(int node, struct meminfo *mi) | |||
320 | * Adjust the sizes according to any special requirements for | 318 | * Adjust the sizes according to any special requirements for |
321 | * this machine type. | 319 | * this machine type. |
322 | */ | 320 | */ |
323 | arch_adjust_zones(node, zone_size, zhole_size); | 321 | arch_adjust_zones(0, zone_size, zhole_size); |
324 | 322 | ||
325 | free_area_init_node(node, zone_size, min, zhole_size); | 323 | free_area_init_node(0, zone_size, min, zhole_size); |
326 | } | 324 | } |
327 | 325 | ||
328 | #ifndef CONFIG_SPARSEMEM | 326 | #ifndef CONFIG_SPARSEMEM |
@@ -346,16 +344,16 @@ int pfn_valid(unsigned long pfn) | |||
346 | } | 344 | } |
347 | EXPORT_SYMBOL(pfn_valid); | 345 | EXPORT_SYMBOL(pfn_valid); |
348 | 346 | ||
349 | static void arm_memory_present(struct meminfo *mi, int node) | 347 | static void arm_memory_present(struct meminfo *mi) |
350 | { | 348 | { |
351 | } | 349 | } |
352 | #else | 350 | #else |
353 | static void arm_memory_present(struct meminfo *mi, int node) | 351 | static void arm_memory_present(struct meminfo *mi) |
354 | { | 352 | { |
355 | int i; | 353 | int i; |
356 | for_each_nodebank(i, mi, node) { | 354 | for_each_bank(i, mi) { |
357 | struct membank *bank = &mi->bank[i]; | 355 | struct membank *bank = &mi->bank[i]; |
358 | memory_present(node, bank_pfn_start(bank), bank_pfn_end(bank)); | 356 | memory_present(0, bank_pfn_start(bank), bank_pfn_end(bank)); |
359 | } | 357 | } |
360 | } | 358 | } |
361 | #endif | 359 | #endif |
@@ -364,55 +362,35 @@ void __init bootmem_init(void) | |||
364 | { | 362 | { |
365 | struct meminfo *mi = &meminfo; | 363 | struct meminfo *mi = &meminfo; |
366 | unsigned long min, max_low, max_high; | 364 | unsigned long min, max_low, max_high; |
367 | int node, initrd_node; | 365 | int initrd; |
368 | 366 | ||
369 | /* | 367 | /* |
370 | * Locate which node contains the ramdisk image, if any. | 368 | * Locate the ramdisk image, if any. |
371 | */ | 369 | */ |
372 | initrd_node = check_initrd(mi); | 370 | initrd = check_initrd(mi); |
373 | 371 | ||
374 | max_low = max_high = 0; | 372 | max_low = max_high = 0; |
375 | 373 | ||
376 | /* | 374 | find_limits(mi, &min, &max_low, &max_high); |
377 | * Run through each node initialising the bootmem allocator. | ||
378 | */ | ||
379 | for_each_node(node) { | ||
380 | unsigned long node_low, node_high; | ||
381 | |||
382 | find_node_limits(node, mi, &min, &node_low, &node_high); | ||
383 | 375 | ||
384 | if (node_low > max_low) | 376 | arm_bootmem_init(mi, min, max_low); |
385 | max_low = node_low; | ||
386 | if (node_high > max_high) | ||
387 | max_high = node_high; | ||
388 | 377 | ||
389 | /* | 378 | /* |
390 | * If there is no memory in this node, ignore it. | 379 | * Reserve any special regions. |
391 | * (We can't have nodes which have no lowmem) | 380 | */ |
392 | */ | 381 | reserve_special_regions(); |
393 | if (node_low == 0) | ||
394 | continue; | ||
395 | |||
396 | bootmem_init_node(node, mi, min, node_low); | ||
397 | |||
398 | /* | ||
399 | * Reserve any special node zero regions. | ||
400 | */ | ||
401 | if (node == 0) | ||
402 | reserve_node_zero(NODE_DATA(node)); | ||
403 | 382 | ||
404 | /* | 383 | /* |
405 | * If the initrd is in this node, reserve its memory. | 384 | * If the initrd is present, reserve its memory. |
406 | */ | 385 | */ |
407 | if (node == initrd_node) | 386 | if (initrd == 0) |
408 | bootmem_reserve_initrd(node); | 387 | bootmem_reserve_initrd(); |
409 | 388 | ||
410 | /* | 389 | /* |
411 | * Sparsemem tries to allocate bootmem in memory_present(), | 390 | * Sparsemem tries to allocate bootmem in memory_present(), |
412 | * so must be done after the fixed reservations | 391 | * so must be done after the fixed reservations |
413 | */ | 392 | */ |
414 | arm_memory_present(mi, node); | 393 | arm_memory_present(mi); |
415 | } | ||
416 | 394 | ||
417 | /* | 395 | /* |
418 | * sparse_init() needs the bootmem allocator up and running. | 396 | * sparse_init() needs the bootmem allocator up and running. |
@@ -420,12 +398,11 @@ void __init bootmem_init(void) | |||
420 | sparse_init(); | 398 | sparse_init(); |
421 | 399 | ||
422 | /* | 400 | /* |
423 | * Now free memory in each node - free_area_init_node needs | 401 | * Now free the memory - free_area_init_node needs |
424 | * the sparse mem_map arrays initialized by sparse_init() | 402 | * the sparse mem_map arrays initialized by sparse_init() |
425 | * for memmap_init_zone(), otherwise all PFNs are invalid. | 403 | * for memmap_init_zone(), otherwise all PFNs are invalid. |
426 | */ | 404 | */ |
427 | for_each_node(node) | 405 | arm_bootmem_free(mi); |
428 | bootmem_free_node(node, mi); | ||
429 | 406 | ||
430 | high_memory = __va((max_low << PAGE_SHIFT) - 1) + 1; | 407 | high_memory = __va((max_low << PAGE_SHIFT) - 1) + 1; |
431 | 408 | ||
@@ -460,7 +437,7 @@ static inline int free_area(unsigned long pfn, unsigned long end, char *s) | |||
460 | } | 437 | } |
461 | 438 | ||
462 | static inline void | 439 | static inline void |
463 | free_memmap(int node, unsigned long start_pfn, unsigned long end_pfn) | 440 | free_memmap(unsigned long start_pfn, unsigned long end_pfn) |
464 | { | 441 | { |
465 | struct page *start_pg, *end_pg; | 442 | struct page *start_pg, *end_pg; |
466 | unsigned long pg, pgend; | 443 | unsigned long pg, pgend; |
@@ -483,13 +460,13 @@ free_memmap(int node, unsigned long start_pfn, unsigned long end_pfn) | |||
483 | * free the section of the memmap array. | 460 | * free the section of the memmap array. |
484 | */ | 461 | */ |
485 | if (pg < pgend) | 462 | if (pg < pgend) |
486 | free_bootmem_node(NODE_DATA(node), pg, pgend - pg); | 463 | free_bootmem(pg, pgend - pg); |
487 | } | 464 | } |
488 | 465 | ||
489 | /* | 466 | /* |
490 | * The mem_map array can get very big. Free the unused area of the memory map. | 467 | * The mem_map array can get very big. Free the unused area of the memory map. |
491 | */ | 468 | */ |
492 | static void __init free_unused_memmap_node(int node, struct meminfo *mi) | 469 | static void __init free_unused_memmap(struct meminfo *mi) |
493 | { | 470 | { |
494 | unsigned long bank_start, prev_bank_end = 0; | 471 | unsigned long bank_start, prev_bank_end = 0; |
495 | unsigned int i; | 472 | unsigned int i; |
@@ -499,7 +476,7 @@ static void __init free_unused_memmap_node(int node, struct meminfo *mi) | |||
499 | * may not be the case, especially if the user has provided the | 476 | * may not be the case, especially if the user has provided the |
500 | * information on the command line. | 477 | * information on the command line. |
501 | */ | 478 | */ |
502 | for_each_nodebank(i, mi, node) { | 479 | for_each_bank(i, mi) { |
503 | struct membank *bank = &mi->bank[i]; | 480 | struct membank *bank = &mi->bank[i]; |
504 | 481 | ||
505 | bank_start = bank_pfn_start(bank); | 482 | bank_start = bank_pfn_start(bank); |
@@ -514,7 +491,7 @@ static void __init free_unused_memmap_node(int node, struct meminfo *mi) | |||
514 | * between the current bank and the previous, free it. | 491 | * between the current bank and the previous, free it. |
515 | */ | 492 | */ |
516 | if (prev_bank_end && prev_bank_end != bank_start) | 493 | if (prev_bank_end && prev_bank_end != bank_start) |
517 | free_memmap(node, prev_bank_end, bank_start); | 494 | free_memmap(prev_bank_end, bank_start); |
518 | 495 | ||
519 | prev_bank_end = bank_pfn_end(bank); | 496 | prev_bank_end = bank_pfn_end(bank); |
520 | } | 497 | } |
@@ -528,21 +505,14 @@ static void __init free_unused_memmap_node(int node, struct meminfo *mi) | |||
528 | void __init mem_init(void) | 505 | void __init mem_init(void) |
529 | { | 506 | { |
530 | unsigned long reserved_pages, free_pages; | 507 | unsigned long reserved_pages, free_pages; |
531 | int i, node; | 508 | int i; |
532 | 509 | ||
533 | #ifndef CONFIG_DISCONTIGMEM | ||
534 | max_mapnr = pfn_to_page(max_pfn + PHYS_PFN_OFFSET) - mem_map; | 510 | max_mapnr = pfn_to_page(max_pfn + PHYS_PFN_OFFSET) - mem_map; |
535 | #endif | ||
536 | 511 | ||
537 | /* this will put all unused low memory onto the freelists */ | 512 | /* this will put all unused low memory onto the freelists */ |
538 | for_each_online_node(node) { | 513 | free_unused_memmap(&meminfo); |
539 | pg_data_t *pgdat = NODE_DATA(node); | ||
540 | |||
541 | free_unused_memmap_node(node, &meminfo); | ||
542 | 514 | ||
543 | if (pgdat->node_spanned_pages != 0) | 515 | totalram_pages += free_all_bootmem(); |
544 | totalram_pages += free_all_bootmem_node(pgdat); | ||
545 | } | ||
546 | 516 | ||
547 | #ifdef CONFIG_SA1111 | 517 | #ifdef CONFIG_SA1111 |
548 | /* now that our DMA memory is actually so designated, we can free it */ | 518 | /* now that our DMA memory is actually so designated, we can free it */ |
@@ -552,39 +522,35 @@ void __init mem_init(void) | |||
552 | 522 | ||
553 | #ifdef CONFIG_HIGHMEM | 523 | #ifdef CONFIG_HIGHMEM |
554 | /* set highmem page free */ | 524 | /* set highmem page free */ |
555 | for_each_online_node(node) { | 525 | for_each_bank (i, &meminfo) { |
556 | for_each_nodebank (i, &meminfo, node) { | 526 | unsigned long start = bank_pfn_start(&meminfo.bank[i]); |
557 | unsigned long start = bank_pfn_start(&meminfo.bank[i]); | 527 | unsigned long end = bank_pfn_end(&meminfo.bank[i]); |
558 | unsigned long end = bank_pfn_end(&meminfo.bank[i]); | 528 | if (start >= max_low_pfn + PHYS_PFN_OFFSET) |
559 | if (start >= max_low_pfn + PHYS_PFN_OFFSET) | 529 | totalhigh_pages += free_area(start, end, NULL); |
560 | totalhigh_pages += free_area(start, end, NULL); | ||
561 | } | ||
562 | } | 530 | } |
563 | totalram_pages += totalhigh_pages; | 531 | totalram_pages += totalhigh_pages; |
564 | #endif | 532 | #endif |
565 | 533 | ||
566 | reserved_pages = free_pages = 0; | 534 | reserved_pages = free_pages = 0; |
567 | 535 | ||
568 | for_each_online_node(node) { | 536 | for_each_bank(i, &meminfo) { |
569 | for_each_nodebank(i, &meminfo, node) { | 537 | struct membank *bank = &meminfo.bank[i]; |
570 | struct membank *bank = &meminfo.bank[i]; | 538 | unsigned int pfn1, pfn2; |
571 | unsigned int pfn1, pfn2; | 539 | struct page *page, *end; |
572 | struct page *page, *end; | 540 | |
573 | 541 | pfn1 = bank_pfn_start(bank); | |
574 | pfn1 = bank_pfn_start(bank); | 542 | pfn2 = bank_pfn_end(bank); |
575 | pfn2 = bank_pfn_end(bank); | 543 | |
576 | 544 | page = pfn_to_page(pfn1); | |
577 | page = pfn_to_page(pfn1); | 545 | end = pfn_to_page(pfn2 - 1) + 1; |
578 | end = pfn_to_page(pfn2 - 1) + 1; | 546 | |
579 | 547 | do { | |
580 | do { | 548 | if (PageReserved(page)) |
581 | if (PageReserved(page)) | 549 | reserved_pages++; |
582 | reserved_pages++; | 550 | else if (!page_count(page)) |
583 | else if (!page_count(page)) | 551 | free_pages++; |
584 | free_pages++; | 552 | page++; |
585 | page++; | 553 | } while (page < end); |
586 | } while (page < end); | ||
587 | } | ||
588 | } | 554 | } |
589 | 555 | ||
590 | /* | 556 | /* |
diff --git a/arch/arm/mm/mm.h b/arch/arm/mm/mm.h index 815d08eecbb0..7b19c90ab295 100644 --- a/arch/arm/mm/mm.h +++ b/arch/arm/mm/mm.h | |||
@@ -28,7 +28,5 @@ extern void __flush_dcache_page(struct address_space *mapping, struct page *page | |||
28 | 28 | ||
29 | #endif | 29 | #endif |
30 | 30 | ||
31 | struct pglist_data; | ||
32 | |||
33 | void __init bootmem_init(void); | 31 | void __init bootmem_init(void); |
34 | void reserve_node_zero(struct pglist_data *pgdat); | 32 | void reserve_special_regions(void); |
diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c index 6a08087ab022..ddb1bee6de73 100644 --- a/arch/arm/mm/mmu.c +++ b/arch/arm/mm/mmu.c | |||
@@ -827,9 +827,9 @@ static inline void prepare_page_table(void) | |||
827 | } | 827 | } |
828 | 828 | ||
829 | /* | 829 | /* |
830 | * Reserve the various regions of node 0 | 830 | * Reserve the various regions |
831 | */ | 831 | */ |
832 | void __init reserve_node_zero(pg_data_t *pgdat) | 832 | void __init reserve_special_regions(void) |
833 | { | 833 | { |
834 | unsigned long res_size = 0; | 834 | unsigned long res_size = 0; |
835 | 835 | ||
@@ -838,19 +838,17 @@ void __init reserve_node_zero(pg_data_t *pgdat) | |||
838 | * Note that this can only be in node 0. | 838 | * Note that this can only be in node 0. |
839 | */ | 839 | */ |
840 | #ifdef CONFIG_XIP_KERNEL | 840 | #ifdef CONFIG_XIP_KERNEL |
841 | reserve_bootmem_node(pgdat, __pa(_data), _end - _data, | 841 | reserve_bootmem(__pa(_data), _end - _data, BOOTMEM_DEFAULT); |
842 | BOOTMEM_DEFAULT); | ||
843 | #else | 842 | #else |
844 | reserve_bootmem_node(pgdat, __pa(_stext), _end - _stext, | 843 | reserve_bootmem(__pa(_stext), _end - _stext, BOOTMEM_DEFAULT); |
845 | BOOTMEM_DEFAULT); | ||
846 | #endif | 844 | #endif |
847 | 845 | ||
848 | /* | 846 | /* |
849 | * Reserve the page tables. These are already in use, | 847 | * Reserve the page tables. These are already in use, |
850 | * and can only be in node 0. | 848 | * and can only be in node 0. |
851 | */ | 849 | */ |
852 | reserve_bootmem_node(pgdat, __pa(swapper_pg_dir), | 850 | reserve_bootmem(__pa(swapper_pg_dir), |
853 | PTRS_PER_PGD * sizeof(pgd_t), BOOTMEM_DEFAULT); | 851 | PTRS_PER_PGD * sizeof(pgd_t), BOOTMEM_DEFAULT); |
854 | 852 | ||
855 | /* | 853 | /* |
856 | * Hmm... This should go elsewhere, but we really really need to | 854 | * Hmm... This should go elsewhere, but we really really need to |
@@ -874,29 +872,22 @@ void __init reserve_node_zero(pg_data_t *pgdat) | |||
874 | 872 | ||
875 | if (machine_is_h1940() || machine_is_rx3715() | 873 | if (machine_is_h1940() || machine_is_rx3715() |
876 | || machine_is_rx1950()) { | 874 | || machine_is_rx1950()) { |
877 | reserve_bootmem_node(pgdat, 0x30003000, 0x1000, | 875 | reserve_bootmem(0x30003000, 0x1000, BOOTMEM_DEFAULT); |
878 | BOOTMEM_DEFAULT); | 876 | reserve_bootmem(0x30081000, 0x1000, BOOTMEM_DEFAULT); |
879 | reserve_bootmem_node(pgdat, 0x30081000, 0x1000, | ||
880 | BOOTMEM_DEFAULT); | ||
881 | } | 877 | } |
882 | 878 | ||
883 | if (machine_is_palmld() || machine_is_palmtx()) { | 879 | if (machine_is_palmld() || machine_is_palmtx()) { |
884 | reserve_bootmem_node(pgdat, 0xa0000000, 0x1000, | 880 | reserve_bootmem(0xa0000000, 0x1000, BOOTMEM_EXCLUSIVE); |
885 | BOOTMEM_EXCLUSIVE); | 881 | reserve_bootmem(0xa0200000, 0x1000, BOOTMEM_EXCLUSIVE); |
886 | reserve_bootmem_node(pgdat, 0xa0200000, 0x1000, | ||
887 | BOOTMEM_EXCLUSIVE); | ||
888 | } | 882 | } |
889 | 883 | ||
890 | if (machine_is_treo680() || machine_is_centro()) { | 884 | if (machine_is_treo680() || machine_is_centro()) { |
891 | reserve_bootmem_node(pgdat, 0xa0000000, 0x1000, | 885 | reserve_bootmem(0xa0000000, 0x1000, BOOTMEM_EXCLUSIVE); |
892 | BOOTMEM_EXCLUSIVE); | 886 | reserve_bootmem(0xa2000000, 0x1000, BOOTMEM_EXCLUSIVE); |
893 | reserve_bootmem_node(pgdat, 0xa2000000, 0x1000, | ||
894 | BOOTMEM_EXCLUSIVE); | ||
895 | } | 887 | } |
896 | 888 | ||
897 | if (machine_is_palmt5()) | 889 | if (machine_is_palmt5()) |
898 | reserve_bootmem_node(pgdat, 0xa0200000, 0x1000, | 890 | reserve_bootmem(0xa0200000, 0x1000, BOOTMEM_EXCLUSIVE); |
899 | BOOTMEM_EXCLUSIVE); | ||
900 | 891 | ||
901 | /* | 892 | /* |
902 | * U300 - This platform family can share physical memory | 893 | * U300 - This platform family can share physical memory |
@@ -920,8 +911,7 @@ void __init reserve_node_zero(pg_data_t *pgdat) | |||
920 | res_size = __pa(swapper_pg_dir) - PHYS_OFFSET; | 911 | res_size = __pa(swapper_pg_dir) - PHYS_OFFSET; |
921 | #endif | 912 | #endif |
922 | if (res_size) | 913 | if (res_size) |
923 | reserve_bootmem_node(pgdat, PHYS_OFFSET, res_size, | 914 | reserve_bootmem(PHYS_OFFSET, res_size, BOOTMEM_DEFAULT); |
924 | BOOTMEM_DEFAULT); | ||
925 | } | 915 | } |
926 | 916 | ||
927 | /* | 917 | /* |
diff --git a/arch/arm/mm/nommu.c b/arch/arm/mm/nommu.c index 33b327379f07..25376d480b8e 100644 --- a/arch/arm/mm/nommu.c +++ b/arch/arm/mm/nommu.c | |||
@@ -18,20 +18,18 @@ | |||
18 | #include "mm.h" | 18 | #include "mm.h" |
19 | 19 | ||
20 | /* | 20 | /* |
21 | * Reserve the various regions of node 0 | 21 | * Reserve the various regions |
22 | */ | 22 | */ |
23 | void __init reserve_node_zero(pg_data_t *pgdat) | 23 | void __init reserve_special_regions(void) |
24 | { | 24 | { |
25 | /* | 25 | /* |
26 | * Register the kernel text and data with bootmem. | 26 | * Register the kernel text and data with bootmem. |
27 | * Note that this can only be in node 0. | 27 | * Note that this can only be in node 0. |
28 | */ | 28 | */ |
29 | #ifdef CONFIG_XIP_KERNEL | 29 | #ifdef CONFIG_XIP_KERNEL |
30 | reserve_bootmem_node(pgdat, __pa(_data), _end - _data, | 30 | reserve_bootmem(__pa(_data), _end - _data, BOOTMEM_DEFAULT); |
31 | BOOTMEM_DEFAULT); | ||
32 | #else | 31 | #else |
33 | reserve_bootmem_node(pgdat, __pa(_stext), _end - _stext, | 32 | reserve_bootmem(__pa(_stext), _end - _stext, BOOTMEM_DEFAULT); |
34 | BOOTMEM_DEFAULT); | ||
35 | #endif | 33 | #endif |
36 | 34 | ||
37 | /* | 35 | /* |
@@ -39,8 +37,7 @@ void __init reserve_node_zero(pg_data_t *pgdat) | |||
39 | * some architectures which the DRAM is the exception vector to trap, | 37 | * some architectures which the DRAM is the exception vector to trap, |
40 | * alloc_page breaks with error, although it is not NULL, but "0." | 38 | * alloc_page breaks with error, although it is not NULL, but "0." |
41 | */ | 39 | */ |
42 | reserve_bootmem_node(pgdat, CONFIG_VECTORS_BASE, PAGE_SIZE, | 40 | reserve_bootmem(CONFIG_VECTORS_BASE, PAGE_SIZE, BOOTMEM_DEFAULT); |
43 | BOOTMEM_DEFAULT); | ||
44 | } | 41 | } |
45 | 42 | ||
46 | /* | 43 | /* |