NetBSD/sys/kern
yamt 471ef5f249 once exit1() releases big kernel lock, the struct proc can be freed and
re-used by another cpu immediately.  in that case, lwp_exit2() will
access freed memory.  to fix this:

- remove curlwp from p_lwps in exit1() rather than letting lwp_exit2() do so.
- add assertions to ensure freed proc has no lwps.

kern/24329 from me and kern/24574 from Havard Eidnes.
2004-03-02 09:15:26 +00:00
..
cnmagic.c
core_elf32.c
core_elf64.c
core_netbsd.c
exec_aout.c Uppercase CPU, plural is CPUs. 2004-02-13 11:36:08 +00:00
exec_conf.c Support Darwin static binaries (I should say: support the only Darwin 2003-10-19 07:52:22 +00:00
exec_ecoff.c
exec_elf32.c Back out >2 PT_LOAD changes from rev 1.96. They cause older GCC3-compiled 2004-01-07 16:42:53 +00:00
exec_elf64.c
exec_macho.c One more section type in the Mach-O format. Now /usr/X11R6/bin/quartz-wm links 2003-10-20 22:42:40 +00:00
exec_script.c
exec_subr.c
genassym.awk
genassym.sh
genlintstub.awk
init_main.c Bump default size of vnode cache to 1% of physical memory, instead of 2004-01-09 00:04:53 +00:00
init_sysctl.c Use KERN_PROCSLOP for struct kinfo_proc and KERN_LWPSLOP for 2004-02-21 03:27:57 +00:00
init_sysent.c uuidgen(2) syscall. Originally from FreeBSD, ported by John Franklin in 2004-01-29 02:00:02 +00:00
kern_acct.c
kern_clock.c Uppercase CPU, plural is CPUs. 2004-02-13 11:36:08 +00:00
kern_descrip.c fix F_MAXFD fcntl - it returned the value as errno instead 2004-01-07 09:26:29 +00:00
kern_event.c allocate wired memory for the marker kevent in kqueue_scan() instead 2004-02-14 11:56:28 +00:00
kern_exec.c Rename es_check in struct execsw to es_makecmds. 2004-02-06 08:02:58 +00:00
kern_exit.c once exit1() releases big kernel lock, the struct proc can be freed and 2004-03-02 09:15:26 +00:00
kern_fork.c Also defer the writing of KTR_EMUL entry. Otherwise, the parent process 2004-02-12 23:47:21 +00:00
kern_ksyms.c Move detection of a special symbol into a separate function. Add some more 2004-02-19 03:42:01 +00:00
kern_kthread.c
kern_ktrace.c Whitespace nits. 2004-02-25 21:40:40 +00:00
kern_lkm.c Support really large LKMs. Find out how much space is needed for symbols 2004-02-18 23:44:49 +00:00
kern_lock.c Uppercase CPU, plural is CPUs. 2004-02-13 11:36:08 +00:00
kern_lwp.c once exit1() releases big kernel lock, the struct proc can be freed and 2004-03-02 09:15:26 +00:00
kern_malloc_debug.c don't use NULL as vaddr_t. 2003-10-24 00:53:43 +00:00
kern_malloc.c Remove some assigned-to but otherwise unused variables. 2003-10-30 01:58:17 +00:00
kern_microtime.c
kern_ntptime.c Dynamic sysctl. 2003-12-04 19:38:21 +00:00
kern_physio.c Don't shadow a function name with a parameter. 2004-02-17 11:36:01 +00:00
kern_proc.c More typos in comments. 2004-02-27 02:43:25 +00:00
kern_prot.c
kern_ras.c Remove p_nras from struct proc - use LIST_EMPTY(&p->p_raslist) instead. 2003-11-04 10:33:15 +00:00
kern_resource.c Don't need those any more 2003-12-06 04:25:57 +00:00
kern_sa.c kernel part of no-syscall upcall stack return: libpthread registers 2004-01-02 18:52:17 +00:00
kern_sig.c Move the sigfilter hook to a more adequate location, and rename it to better 2003-12-24 22:53:59 +00:00
kern_subr.c Don't pass the (unused) return value args to the 2003-10-31 03:28:12 +00:00
kern_synch.c Uppercase CPU, plural is CPUs. 2004-02-13 11:36:08 +00:00
kern_sysctl.c In sysctl_locate(), use "rnode" like everywhere else, don't call it 2004-01-17 04:01:14 +00:00
kern_systrace.c clean up a little: 2004-01-16 05:03:02 +00:00
kern_time.c kernel part of no-syscall upcall stack return: libpthread registers 2004-01-02 18:52:17 +00:00
kern_timeout.c Make callout_setfunc() a CPP macro. Suggested by enami. 2003-10-30 04:32:56 +00:00
kern_uuid.c uuidgen(2) syscall. Originally from FreeBSD, ported by John Franklin in 2004-01-29 02:00:02 +00:00
kern_verifiedexec.c Remove spurious space accidently introduced in last. 2003-11-18 13:13:03 +00:00
kern_xxx.c
kgdb_stub.c Uppercase CPU, plural is CPUs. 2004-02-13 11:36:08 +00:00
Make.tags.inc
Makefile We have CVS; there is no reason to make .bak files when generating the 2003-11-15 20:26:02 +00:00
makesyscalls.sh
subr_autoconf.c split off the evcnt code (which is unrelated to autoconfiguration) 2004-02-17 05:03:15 +00:00
subr_devsw.c
subr_disk_mbr.c Overhaul MBR handling (part 1): 2003-10-08 04:25:43 +00:00
subr_disk.c change the way to handle NEW_BUFQ_STRATEGY option. 2004-02-28 06:28:47 +00:00
subr_evcnt.c Include "sys/systm.h" to get the prototype for panic() which is required 2004-02-17 08:22:12 +00:00
subr_extent.c
subr_log.c
subr_pool.c Modify pool page header allocation strategy as follows: 2004-02-22 00:19:48 +00:00
subr_prf.c
subr_prof.c Dynamic sysctl. 2003-12-04 19:38:21 +00:00
subr_prop.c Remove trailing blank line. 2003-12-21 11:54:16 +00:00
subr_userconf.c
subr_xxx.c
sys_generic.c use "poll" as the wmesg for poll. 2003-10-10 15:24:28 +00:00
sys_pipe.c pipelock() must release the pipe simplelock during tsleep() 2004-02-26 08:15:31 +00:00
sys_pmc.c
sys_process.c Remove p_nras from struct proc - use LIST_EMPTY(&p->p_raslist) instead. 2003-11-04 10:33:15 +00:00
sys_socket.c
syscalls.c uuidgen(2) syscall. Originally from FreeBSD, ported by John Franklin in 2004-01-29 02:00:02 +00:00
syscalls.conf
syscalls.master uuidgen(2) syscall. Originally from FreeBSD, ported by John Franklin in 2004-01-29 02:00:02 +00:00
sysv_ipc.c
sysv_msg.c allocate virtual memory for SYSV shm, msg and semaphore structures 2003-10-26 10:32:24 +00:00
sysv_sem.c fix semaphore ID bound checking 2003-11-29 11:43:25 +00:00
sysv_shm.c include <uvm/uvm_object.h> for the benefit of ports that don't include 2004-02-06 13:46:27 +00:00
tty_conf.c
tty_pty.c use the new NOTE_SUBMIT to flag if the locking is necessary 2004-02-22 17:51:25 +00:00
tty_subr.c Uppercase CPU, plural is CPUs. 2004-02-13 11:36:08 +00:00
tty_tb.c
tty_tty.c Add the gating of system calls that cause modifications to the underlying 2003-10-15 11:28:59 +00:00
tty.c use the new NOTE_SUBMIT to flag if the locking is necessary 2004-02-22 17:51:25 +00:00
uipc_domain.c Dynamic sysctl. 2003-12-04 19:38:21 +00:00
uipc_mbuf2.c Add m_tag_delete_nonpesrsistent(), for deleting all packet tags on 2003-11-13 01:48:12 +00:00
uipc_mbuf.c m_cat() - if it is safe, copy data portion into 1st mbuf even if 1st mbuf 2004-02-26 02:30:04 +00:00
uipc_proto.c
uipc_sem.c
uipc_socket2.c Cache the "adjusted" value of sb_max when sb_max is changed, in order 2003-10-21 22:55:47 +00:00
uipc_socket.c Cache the "adjusted" value of sb_max when sb_max is changed, in order 2003-10-21 22:55:47 +00:00
uipc_syscalls.c Restore a change that made AF_LOCAL sockets block on connect(2) until 2003-11-29 10:02:42 +00:00
uipc_usrreq.c Avoid using m_clget() on a mbuf already in use, especially when we 2003-12-29 22:08:02 +00:00
vfs_bio.c micro-optimisation - if we're going to return 0, do so before doing 2004-02-22 01:00:41 +00:00
vfs_cache.c
vfs_getcwd.c Some whitespace fix. 2004-02-17 01:45:34 +00:00
vfs_init.c
vfs_lockf.c fix uninitialized variable 2003-10-25 09:06:51 +00:00
vfs_lookup.c Fix the last commit(s). On machines with sizeof(long) != sizeof(int) 2003-12-08 14:23:33 +00:00
vfs_subr.c Add a generic copy-on-write hook to add/remove functions that will be 2004-02-14 00:00:56 +00:00
vfs_syscalls.c fix typo in comment s/MNT_LAXY/MNT_LAZY/ 2004-02-25 04:10:28 +00:00
vfs_vnops.c Add a generic copy-on-write hook to add/remove functions that will be 2004-02-14 00:00:56 +00:00
vnode_if.c Make VOP_STRATEGY(bp) a real VOP as discussed on tech-kern. 2004-01-25 18:06:48 +00:00
vnode_if.sh Make VOP_STRATEGY(bp) a real VOP as discussed on tech-kern. 2004-01-25 18:02:04 +00:00
vnode_if.src Make VOP_STRATEGY(bp) a real VOP as discussed on tech-kern. 2004-01-25 18:02:04 +00:00