patch-1.3.33 linux/include/asm-i386/unistd.h
Next file: linux/include/asm-i386/user.h
Previous file: linux/include/asm-i386/segment.h
Back to the patch index
Back to the overall index
-  Lines: 35
-  Date:
Tue Oct 10 08:53:08 1995
-  Orig file: 
v1.3.32/linux/include/asm-i386/unistd.h
-  Orig date: 
Wed Oct  4 14:14:34 1995
diff -u --recursive --new-file v1.3.32/linux/include/asm-i386/unistd.h linux/include/asm-i386/unistd.h
@@ -271,6 +271,34 @@
 	return waitpid(-1,wait_stat,0);
 }
 
+/*
+ * This is the mechanism for creating a new kernel thread.
+ *
+ * NOTE! Only a kernel-only process(ie the swapper or direct descendants
+ * who haven't done an "execve()") should use this: it will work within
+ * a system call from a "real" process, but the process memory space will
+ * not be free'd until both the parent and the child have exited.
+ */
+static inline pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags)
+{
+	long retval;
+
+	__asm__ __volatile__(
+		"int $0x80\n\t"		/* Linux/i386 system call */
+		"testl %0,%0\n\t"	/* child or parent? */
+		"jne 1f\n\t"		/* parent - jump */
+		"pushl %3\n\t"		/* push argument */
+		"call *%4\n\t"		/* call fn */
+		"movl %2,%0\n\t"	/* exit */
+		"int $0x80\n"
+		"1:\t"
+		:"=a" (retval)
+		:"0" (__NR_clone), "i" (__NR_exit),
+		 "r" (arg), "r" (fn),
+		 "b" (flags | CLONE_VM));
+	return retval;
+}
+
 #endif
 
 #endif /* _ASM_I386_UNISTD_H_ */
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen, slshen@lbl.gov
with Sam's (original) version of this