aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOlaf Hering <olh@suse.de>2005-10-28 20:46:45 -0400
committerPaul Mackerras <paulus@samba.org>2005-10-29 01:07:38 -0400
commit9b0cbe97566dd7123eee0462d91703434fe61090 (patch)
tree816d6f93e2b84741c891e5edd600c6fdab91b675
parent06cf26beffc54bb43aebbefa60f84e0dffde3141 (diff)
[PATCH] ppc64 boot: use memset to clear bss
Use memset to clear bss, instead of own version. Signed-off-by: Olaf Hering <olh@suse.de> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Anton Blanchard <anton@samba.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Paul Mackerras <paulus@samba.org>
-rw-r--r--arch/ppc64/boot/crt0.S19
-rw-r--r--arch/ppc64/boot/main.c3
2 files changed, 3 insertions, 19 deletions
diff --git a/arch/ppc64/boot/crt0.S b/arch/ppc64/boot/crt0.S
index 3861e7f9cf19..da6618a865c9 100644
--- a/arch/ppc64/boot/crt0.S
+++ b/arch/ppc64/boot/crt0.S
@@ -25,24 +25,5 @@ _start:
25 sync 25 sync
26 isync 26 isync
27 27
28 ## Clear out the BSS as per ANSI C requirements
29
30 lis r7,_end@ha
31 addi r7,r7,_end@l # r7 = &_end
32 lis r8,__bss_start@ha #
33 addi r8,r8,__bss_start@l # r8 = &_bss_start
34
35 ## Determine how large an area, in number of words, to clear
36
37 subf r7,r8,r7 # r7 = &_end - &_bss_start + 1
38 addi r7,r7,3 # r7 += 3
39 srwi. r7,r7,2 # r7 = size in words.
40 beq 3f # If the size is zero, don't bother
41 addi r8,r8,-4 # r8 -= 4
42 mtctr r7 # SPRN_CTR = number of words to clear
43 li r0,0 # r0 = 0
442: stwu r0,4(r8) # Clear out a word
45 bdnz 2b # Keep clearing until done
463:
47 b start 28 b start
48 29
diff --git a/arch/ppc64/boot/main.c b/arch/ppc64/boot/main.c
index d039c47f8e5a..c2c1f3309113 100644
--- a/arch/ppc64/boot/main.c
+++ b/arch/ppc64/boot/main.c
@@ -26,6 +26,7 @@ extern void flush_cache(void *, unsigned long);
26#define ONE_MB 0x100000 26#define ONE_MB 0x100000
27 27
28extern char _start[]; 28extern char _start[];
29extern char __bss_start[];
29extern char _end[]; 30extern char _end[];
30extern char _vmlinux_start[]; 31extern char _vmlinux_start[];
31extern char _vmlinux_end[]; 32extern char _vmlinux_end[];
@@ -138,6 +139,8 @@ void start(unsigned long a1, unsigned long a2, void *promptr)
138 Elf64_Ehdr *elf64; 139 Elf64_Ehdr *elf64;
139 Elf64_Phdr *elf64ph; 140 Elf64_Phdr *elf64ph;
140 141
142 memset(__bss_start, 0, _end - __bss_start);
143
141 prom = (int (*)(void *)) promptr; 144 prom = (int (*)(void *)) promptr;
142 chosen_handle = finddevice("/chosen"); 145 chosen_handle = finddevice("/chosen");
143 if (chosen_handle == (void *) -1) 146 if (chosen_handle == (void *) -1)