[uClibc] [PATCH] make uClibc vfork() on PPC use kernel vfork() instead of fork()
Joakim Tjernlund
joakim.tjernlund at lumentis.se
Wed Aug 17 14:21:40 UTC 2005
This patch fixes the the current vfork() impl. for
PPC to actually use the kernel vfork system call instead of fork()
Extra bonus: Remove unused system call file, syscall.S, in Makefile.
Since the release of .28 is very close I wan't Eriks blessing before
checking this in. A little extra testing would be good as well.
Jocke
Index: vfork.S
===================================================================
--- vfork.S (revision 0)
+++ vfork.S (revision 0)
@@ -0,0 +1,22 @@
+#include <sys/syscall.h>
+
+#ifndef __NR_vfork
+
+/* No vfork so use fork instead */
+.weak vfork ; vfork = __libc_fork
+
+#else
+
+.text
+.global __vfork
+.type __vfork, at function
+
+__vfork:
+ li 0, __NR_vfork
+ sc
+ bnslr+
+ b __syscall_error
+.size __vfork,.-__vfork
+
+.weak vfork ; vfork = __vfork
+#endif
Index: Makefile
===================================================================
--- Makefile (revision 11171)
+++ Makefile (working copy)
@@ -25,10 +25,10 @@
CTOR_TARGETS=$(TOPDIR)lib/crti.o $(TOPDIR)lib/crtn.o
SSRC=__longjmp.S setjmp.S bsd-setjmp.S bsd-_setjmp.S brk.S \
- clone.S __uClibc_syscall.S syscall.S
+ clone.S __uClibc_syscall.S vfork.S
SOBJS=$(patsubst %.S,%.o, $(SSRC))
-CSRC=mmap.c vfork.c __syscall_error.c pread_write.c ioctl.c
+CSRC=mmap.c __syscall_error.c pread_write.c ioctl.c
COBJS=$(patsubst %.c,%.o, $(CSRC))
OBJS=$(SOBJS) $(COBJS)
More information about the uClibc
mailing list