diff options
author | Bernhard Walle <bwalle@suse.de> | 2008-02-07 03:15:17 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2008-02-07 11:42:25 -0500 |
commit | 72a7fe3967dbf86cb34e24fbf1d957fe24d2f246 (patch) | |
tree | c19f7d0b530577359840e959cce204939caf0649 /arch/frv | |
parent | 25fad945a7f7ff2cf06e437381c6a1121784dbd9 (diff) |
Introduce flags for reserve_bootmem()
This patchset adds a flags variable to reserve_bootmem() and uses the
BOOTMEM_EXCLUSIVE flag in crashkernel reservation code to detect collisions
between crashkernel area and already used memory.
This patch:
Change the reserve_bootmem() function to accept a new flag BOOTMEM_EXCLUSIVE.
If that flag is set, the function returns with -EBUSY if the memory already
has been reserved in the past. This is to avoid conflicts.
Because that code runs before SMP initialisation, there's no race condition
inside reserve_bootmem_core().
[akpm@linux-foundation.org: coding-style fixes]
[akpm@linux-foundation.org: fix powerpc build]
Signed-off-by: Bernhard Walle <bwalle@suse.de>
Cc: <linux-arch@vger.kernel.org>
Cc: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Vivek Goyal <vgoyal@in.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/frv')
-rw-r--r-- | arch/frv/kernel/setup.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/arch/frv/kernel/setup.c b/arch/frv/kernel/setup.c index b38ae1fc15fd..6c01464db699 100644 --- a/arch/frv/kernel/setup.c +++ b/arch/frv/kernel/setup.c | |||
@@ -925,13 +925,15 @@ static void __init setup_linux_memory(void) | |||
925 | #endif | 925 | #endif |
926 | 926 | ||
927 | /* take back the memory occupied by the kernel image and the bootmem alloc map */ | 927 | /* take back the memory occupied by the kernel image and the bootmem alloc map */ |
928 | reserve_bootmem(kstart, kend - kstart + bootmap_size); | 928 | reserve_bootmem(kstart, kend - kstart + bootmap_size, |
929 | BOOTMEM_DEFAULT); | ||
929 | 930 | ||
930 | /* reserve the memory occupied by the initial ramdisk */ | 931 | /* reserve the memory occupied by the initial ramdisk */ |
931 | #ifdef CONFIG_BLK_DEV_INITRD | 932 | #ifdef CONFIG_BLK_DEV_INITRD |
932 | if (LOADER_TYPE && INITRD_START) { | 933 | if (LOADER_TYPE && INITRD_START) { |
933 | if (INITRD_START + INITRD_SIZE <= (low_top_pfn << PAGE_SHIFT)) { | 934 | if (INITRD_START + INITRD_SIZE <= (low_top_pfn << PAGE_SHIFT)) { |
934 | reserve_bootmem(INITRD_START, INITRD_SIZE); | 935 | reserve_bootmem(INITRD_START, INITRD_SIZE, |
936 | BOOTMEM_DEFAULT); | ||
935 | initrd_start = INITRD_START + PAGE_OFFSET; | 937 | initrd_start = INITRD_START + PAGE_OFFSET; |
936 | initrd_end = initrd_start + INITRD_SIZE; | 938 | initrd_end = initrd_start + INITRD_SIZE; |
937 | } | 939 | } |
@@ -986,9 +988,10 @@ static void __init setup_uclinux_memory(void) | |||
986 | 988 | ||
987 | /* now take back the bits the core kernel is occupying */ | 989 | /* now take back the bits the core kernel is occupying */ |
988 | #ifndef CONFIG_PROTECT_KERNEL | 990 | #ifndef CONFIG_PROTECT_KERNEL |
989 | reserve_bootmem(kend, bootmap_size); | 991 | reserve_bootmem(kend, bootmap_size, BOOTMEM_DEFAULT); |
990 | reserve_bootmem((unsigned long) &__kernel_image_start, | 992 | reserve_bootmem((unsigned long) &__kernel_image_start, |
991 | kend - (unsigned long) &__kernel_image_start); | 993 | kend - (unsigned long) &__kernel_image_start, |
994 | BOOTMEM_DEFAULT); | ||
992 | 995 | ||
993 | #else | 996 | #else |
994 | dampr = __get_DAMPR(0); | 997 | dampr = __get_DAMPR(0); |
@@ -996,14 +999,15 @@ static void __init setup_uclinux_memory(void) | |||
996 | dampr = (dampr >> 4) + 17; | 999 | dampr = (dampr >> 4) + 17; |
997 | dampr = 1 << dampr; | 1000 | dampr = 1 << dampr; |
998 | 1001 | ||
999 | reserve_bootmem(__get_DAMPR(0) & xAMPRx_PPFN, dampr); | 1002 | reserve_bootmem(__get_DAMPR(0) & xAMPRx_PPFN, dampr, BOOTMEM_DEFAULT); |
1000 | #endif | 1003 | #endif |
1001 | 1004 | ||
1002 | /* reserve some memory to do uncached DMA through if requested */ | 1005 | /* reserve some memory to do uncached DMA through if requested */ |
1003 | #ifdef CONFIG_RESERVE_DMA_COHERENT | 1006 | #ifdef CONFIG_RESERVE_DMA_COHERENT |
1004 | if (dma_coherent_mem_start) | 1007 | if (dma_coherent_mem_start) |
1005 | reserve_bootmem(dma_coherent_mem_start, | 1008 | reserve_bootmem(dma_coherent_mem_start, |
1006 | dma_coherent_mem_end - dma_coherent_mem_start); | 1009 | dma_coherent_mem_end - dma_coherent_mem_start, |
1010 | BOOTMEM_DEFAULT); | ||
1007 | #endif | 1011 | #endif |
1008 | 1012 | ||
1009 | } /* end setup_uclinux_memory() */ | 1013 | } /* end setup_uclinux_memory() */ |