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/netinet/raw_ip.c,v rcsdiff: /ftp/cvs/cvsroot/src/sys/netinet/raw_ip.c,v: warning: Unknown phrases like `commitid ...;' are present. retrieving revision 1.70.2.6 retrieving revision 1.92 diff -u -p -r1.70.2.6 -r1.92 --- src/sys/netinet/raw_ip.c 2005/04/01 14:31:50 1.70.2.6 +++ src/sys/netinet/raw_ip.c 2006/09/19 21:42:30 1.92 @@ -1,4 +1,4 @@ -/* $NetBSD: raw_ip.c,v 1.70.2.6 2005/04/01 14:31:50 skrll Exp $ */ +/* $NetBSD: raw_ip.c,v 1.92 2006/09/19 21:42:30 elad Exp $ */ /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. @@ -61,7 +61,7 @@ */ #include -__KERNEL_RCSID(0, "$NetBSD: raw_ip.c,v 1.70.2.6 2005/04/01 14:31:50 skrll Exp $"); +__KERNEL_RCSID(0, "$NetBSD: raw_ip.c,v 1.92 2006/09/19 21:42:30 elad Exp $"); #include "opt_inet.h" #include "opt_ipsec.h" @@ -77,6 +77,7 @@ __KERNEL_RCSID(0, "$NetBSD: raw_ip.c,v 1 #include #include #include +#include #include #include @@ -88,6 +89,7 @@ __KERNEL_RCSID(0, "$NetBSD: raw_ip.c,v 1 #include #include #include +#include #include #include @@ -504,17 +506,15 @@ rip_usrreq(struct socket *so, int req, struct mbuf *m, struct mbuf *nam, struct mbuf *control, struct lwp *l) { struct inpcb *inp; - struct proc *p; int s; int error = 0; #ifdef MROUTING extern struct socket *ip_mrouter; #endif - p = l ? l->l_proc : NULL; if (req == PRU_CONTROL) return (in_control(so, (long)m, (caddr_t)nam, - (struct ifnet *)control, p)); + (struct ifnet *)control, l)); if (req == PRU_PURGEIF) { in_pcbpurgeif0(&rawcbtable, (struct ifnet *)control); @@ -541,7 +541,10 @@ rip_usrreq(struct socket *so, int req, error = EISCONN; break; } - if (p == 0 || (error = suser(p->p_ucred, &p->p_acflag))) { + if (l == 0 || (error = kauth_authorize_network(l->l_cred, + KAUTH_NETWORK_SOCKET, + KAUTH_REQ_NETWORK_SOCKET_RAWSOCK, so, NULL, + NULL))) { error = EACCES; break; }