Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files. =================================================================== RCS file: /ftp/cvs/cvsroot/src/sys/kern/uipc_socket.c,v retrieving revision 1.164 retrieving revision 1.164.2.1 diff -u -p -r1.164 -r1.164.2.1 --- src/sys/kern/uipc_socket.c 2008/05/01 09:21:56 1.164 +++ src/sys/kern/uipc_socket.c 2008/06/23 04:31:52 1.164.2.1 @@ -1,4 +1,4 @@ -/* $NetBSD: uipc_socket.c,v 1.164 2008/05/01 09:21:56 drochner Exp $ */ +/* $NetBSD: uipc_socket.c,v 1.164.2.1 2008/06/23 04:31:52 wrstuden Exp $ */ /*- * Copyright (c) 2002, 2007, 2008 The NetBSD Foundation, Inc. @@ -63,12 +63,13 @@ */ #include -__KERNEL_RCSID(0, "$NetBSD: uipc_socket.c,v 1.164 2008/05/01 09:21:56 drochner Exp $"); +__KERNEL_RCSID(0, "$NetBSD: uipc_socket.c,v 1.164.2.1 2008/06/23 04:31:52 wrstuden Exp $"); #include "opt_sock_counters.h" #include "opt_sosend_loan.h" #include "opt_mbuftrace.h" #include "opt_somaxkva.h" +#include "opt_multiprocessor.h" /* XXX */ #include #include @@ -127,7 +128,7 @@ EVCNT_ATTACH_STATIC(sosend_kvalimit); static struct callback_entry sokva_reclaimerentry; -#ifdef SOSEND_NO_LOAN +#if defined(SOSEND_NO_LOAN) || defined(MULTIPROCESSOR) int sock_loan_thresh = -1; #else int sock_loan_thresh = 4096; @@ -435,6 +436,7 @@ soinit(void) mutex_init(&so_pendfree_lock, MUTEX_DEFAULT, IPL_VM); softnet_lock = mutex_obj_alloc(MUTEX_DEFAULT, IPL_NONE); cv_init(&socurkva_cv, "sokva"); + soinit2(); /* Set the initial adjusted socket buffer size. */ if (sb_max_set(sb_max)) @@ -498,6 +500,8 @@ socreate(int dom, struct socket **aso, i #endif uid = kauth_cred_geteuid(l->l_cred); so->so_uidinfo = uid_find(uid); + so->so_egid = kauth_cred_getegid(l->l_cred); + so->so_cpid = l->l_proc->p_pid; if (lockso != NULL) { /* Caller wants us to share a lock. */ lock = lockso->so_lock; @@ -850,8 +854,7 @@ sosend(struct socket *so, struct mbuf *a dontroute = (flags & MSG_DONTROUTE) && (so->so_options & SO_DONTROUTE) == 0 && (so->so_proto->pr_flags & PR_ATOMIC); - if (l) - l->l_ru.ru_msgsnd++; + l->l_ru.ru_msgsnd++; if (control) clen = control->m_len; restart: