Deleted Added
full compact
kern_sendfile.c (169236) kern_sendfile.c (169624)
1/*-
2 * Copyright (c) 1982, 1986, 1989, 1990, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * sendfile(2) and related extensions:
6 * Copyright (c) 1998, David Greenman. All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without

--- 19 unchanged lines hidden (view full) ---

28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 *
32 * @(#)uipc_syscalls.c 8.4 (Berkeley) 2/21/94
33 */
34
35#include <sys/cdefs.h>
1/*-
2 * Copyright (c) 1982, 1986, 1989, 1990, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * sendfile(2) and related extensions:
6 * Copyright (c) 1998, David Greenman. All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without

--- 19 unchanged lines hidden (view full) ---

28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 *
32 * @(#)uipc_syscalls.c 8.4 (Berkeley) 2/21/94
33 */
34
35#include <sys/cdefs.h>
36__FBSDID("$FreeBSD: head/sys/kern/uipc_syscalls.c 169236 2007-05-03 14:42:42Z rwatson $");
36__FBSDID("$FreeBSD: head/sys/kern/uipc_syscalls.c 169624 2007-05-16 20:41:08Z rwatson $");
37
38#include "opt_sctp.h"
39#include "opt_compat.h"
40#include "opt_ktrace.h"
41#include "opt_mac.h"
42
43#include <sys/param.h>
44#include <sys/systm.h>

--- 103 unchanged lines hidden (view full) ---

148 */
149#if defined(COMPAT_43)
150#define COMPAT_OLDSOCK
151#endif
152
153int
154socket(td, uap)
155 struct thread *td;
37
38#include "opt_sctp.h"
39#include "opt_compat.h"
40#include "opt_ktrace.h"
41#include "opt_mac.h"
42
43#include <sys/param.h>
44#include <sys/systm.h>

--- 103 unchanged lines hidden (view full) ---

148 */
149#if defined(COMPAT_43)
150#define COMPAT_OLDSOCK
151#endif
152
153int
154socket(td, uap)
155 struct thread *td;
156 register struct socket_args /* {
156 struct socket_args /* {
157 int domain;
158 int type;
159 int protocol;
160 } */ *uap;
161{
162 struct filedesc *fdp;
163 struct socket *so;
164 struct file *fp;

--- 28 unchanged lines hidden (view full) ---

193 fdrop(fp, td);
194 return (error);
195}
196
197/* ARGSUSED */
198int
199bind(td, uap)
200 struct thread *td;
157 int domain;
158 int type;
159 int protocol;
160 } */ *uap;
161{
162 struct filedesc *fdp;
163 struct socket *so;
164 struct file *fp;

--- 28 unchanged lines hidden (view full) ---

193 fdrop(fp, td);
194 return (error);
195}
196
197/* ARGSUSED */
198int
199bind(td, uap)
200 struct thread *td;
201 register struct bind_args /* {
201 struct bind_args /* {
202 int s;
203 caddr_t name;
204 int namelen;
205 } */ *uap;
206{
207 struct sockaddr *sa;
208 int error;
209

--- 36 unchanged lines hidden (view full) ---

246 NET_UNLOCK_GIANT();
247 return (error);
248}
249
250/* ARGSUSED */
251int
252listen(td, uap)
253 struct thread *td;
202 int s;
203 caddr_t name;
204 int namelen;
205 } */ *uap;
206{
207 struct sockaddr *sa;
208 int error;
209

--- 36 unchanged lines hidden (view full) ---

246 NET_UNLOCK_GIANT();
247 return (error);
248}
249
250/* ARGSUSED */
251int
252listen(td, uap)
253 struct thread *td;
254 register struct listen_args /* {
254 struct listen_args /* {
255 int s;
256 int backlog;
257 } */ *uap;
258{
259 struct socket *so;
260 struct file *fp;
261 int error;
262

--- 19 unchanged lines hidden (view full) ---

282}
283
284/*
285 * accept1()
286 */
287static int
288accept1(td, uap, compat)
289 struct thread *td;
255 int s;
256 int backlog;
257 } */ *uap;
258{
259 struct socket *so;
260 struct file *fp;
261 int error;
262

--- 19 unchanged lines hidden (view full) ---

282}
283
284/*
285 * accept1()
286 */
287static int
288accept1(td, uap, compat)
289 struct thread *td;
290 register struct accept_args /* {
290 struct accept_args /* {
291 int s;
292 struct sockaddr * __restrict name;
293 socklen_t * __restrict anamelen;
294 } */ *uap;
295 int compat;
296{
297 struct sockaddr *name;
298 socklen_t namelen;

--- 216 unchanged lines hidden (view full) ---

515 return (accept1(td, uap, 1));
516}
517#endif /* COMPAT_OLDSOCK */
518
519/* ARGSUSED */
520int
521connect(td, uap)
522 struct thread *td;
291 int s;
292 struct sockaddr * __restrict name;
293 socklen_t * __restrict anamelen;
294 } */ *uap;
295 int compat;
296{
297 struct sockaddr *name;
298 socklen_t namelen;

--- 216 unchanged lines hidden (view full) ---

515 return (accept1(td, uap, 1));
516}
517#endif /* COMPAT_OLDSOCK */
518
519/* ARGSUSED */
520int
521connect(td, uap)
522 struct thread *td;
523 register struct connect_args /* {
523 struct connect_args /* {
524 int s;
525 caddr_t name;
526 int namelen;
527 } */ *uap;
528{
529 struct sockaddr *sa;
530 int error;
531

--- 66 unchanged lines hidden (view full) ---

598done2:
599 NET_UNLOCK_GIANT();
600 return (error);
601}
602
603int
604socketpair(td, uap)
605 struct thread *td;
524 int s;
525 caddr_t name;
526 int namelen;
527 } */ *uap;
528{
529 struct sockaddr *sa;
530 int error;
531

--- 66 unchanged lines hidden (view full) ---

598done2:
599 NET_UNLOCK_GIANT();
600 return (error);
601}
602
603int
604socketpair(td, uap)
605 struct thread *td;
606 register struct socketpair_args /* {
606 struct socketpair_args /* {
607 int domain;
608 int type;
609 int protocol;
610 int *rsv;
611 } */ *uap;
612{
607 int domain;
608 int type;
609 int protocol;
610 int *rsv;
611 } */ *uap;
612{
613 register struct filedesc *fdp = td->td_proc->p_fd;
613 struct filedesc *fdp = td->td_proc->p_fd;
614 struct file *fp1, *fp2;
615 struct socket *so1, *so2;
616 int fd, error, sv[2];
617
618#ifdef MAC
619 /* We might want to have a separate check for socket pairs. */
620 error = mac_check_socket_create(td->td_ucred, uap->domain, uap->type,
621 uap->protocol);

--- 63 unchanged lines hidden (view full) ---

685 (void)soclose(so1);
686done2:
687 NET_UNLOCK_GIANT();
688 return (error);
689}
690
691static int
692sendit(td, s, mp, flags)
614 struct file *fp1, *fp2;
615 struct socket *so1, *so2;
616 int fd, error, sv[2];
617
618#ifdef MAC
619 /* We might want to have a separate check for socket pairs. */
620 error = mac_check_socket_create(td->td_ucred, uap->domain, uap->type,
621 uap->protocol);

--- 63 unchanged lines hidden (view full) ---

685 (void)soclose(so1);
686done2:
687 NET_UNLOCK_GIANT();
688 return (error);
689}
690
691static int
692sendit(td, s, mp, flags)
693 register struct thread *td;
693 struct thread *td;
694 int s;
694 int s;
695 register struct msghdr *mp;
695 struct msghdr *mp;
696 int flags;
697{
698 struct mbuf *control;
699 struct sockaddr *to;
700 int error;
701
702 if (mp->msg_name != NULL) {
703 error = getsockaddr(&to, mp->msg_name, mp->msg_namelen);

--- 16 unchanged lines hidden (view full) ---

720 goto bad;
721 }
722 error = sockargs(&control, mp->msg_control,
723 mp->msg_controllen, MT_CONTROL);
724 if (error)
725 goto bad;
726#ifdef COMPAT_OLDSOCK
727 if (mp->msg_flags == MSG_COMPAT) {
696 int flags;
697{
698 struct mbuf *control;
699 struct sockaddr *to;
700 int error;
701
702 if (mp->msg_name != NULL) {
703 error = getsockaddr(&to, mp->msg_name, mp->msg_namelen);

--- 16 unchanged lines hidden (view full) ---

720 goto bad;
721 }
722 error = sockargs(&control, mp->msg_control,
723 mp->msg_controllen, MT_CONTROL);
724 if (error)
725 goto bad;
726#ifdef COMPAT_OLDSOCK
727 if (mp->msg_flags == MSG_COMPAT) {
728 register struct cmsghdr *cm;
728 struct cmsghdr *cm;
729
730 M_PREPEND(control, sizeof(*cm), M_TRYWAIT);
731 if (control == 0) {
732 error = ENOBUFS;
733 goto bad;
734 } else {
735 cm = mtod(control, struct cmsghdr *);
736 cm->cmsg_len = control->m_len;

--- 92 unchanged lines hidden (view full) ---

829bad2:
830 NET_UNLOCK_GIANT();
831 return (error);
832}
833
834int
835sendto(td, uap)
836 struct thread *td;
729
730 M_PREPEND(control, sizeof(*cm), M_TRYWAIT);
731 if (control == 0) {
732 error = ENOBUFS;
733 goto bad;
734 } else {
735 cm = mtod(control, struct cmsghdr *);
736 cm->cmsg_len = control->m_len;

--- 92 unchanged lines hidden (view full) ---

829bad2:
830 NET_UNLOCK_GIANT();
831 return (error);
832}
833
834int
835sendto(td, uap)
836 struct thread *td;
837 register struct sendto_args /* {
837 struct sendto_args /* {
838 int s;
839 caddr_t buf;
840 size_t len;
841 int flags;
842 caddr_t to;
843 int tolen;
844 } */ *uap;
845{

--- 14 unchanged lines hidden (view full) ---

860 error = sendit(td, uap->s, &msg, uap->flags);
861 return (error);
862}
863
864#ifdef COMPAT_OLDSOCK
865int
866osend(td, uap)
867 struct thread *td;
838 int s;
839 caddr_t buf;
840 size_t len;
841 int flags;
842 caddr_t to;
843 int tolen;
844 } */ *uap;
845{

--- 14 unchanged lines hidden (view full) ---

860 error = sendit(td, uap->s, &msg, uap->flags);
861 return (error);
862}
863
864#ifdef COMPAT_OLDSOCK
865int
866osend(td, uap)
867 struct thread *td;
868 register struct osend_args /* {
868 struct osend_args /* {
869 int s;
870 caddr_t buf;
871 int len;
872 int flags;
873 } */ *uap;
874{
875 struct msghdr msg;
876 struct iovec aiov;

--- 249 unchanged lines hidden (view full) ---

1126#endif
1127 }
1128 return (error);
1129}
1130
1131int
1132recvfrom(td, uap)
1133 struct thread *td;
869 int s;
870 caddr_t buf;
871 int len;
872 int flags;
873 } */ *uap;
874{
875 struct msghdr msg;
876 struct iovec aiov;

--- 249 unchanged lines hidden (view full) ---

1126#endif
1127 }
1128 return (error);
1129}
1130
1131int
1132recvfrom(td, uap)
1133 struct thread *td;
1134 register struct recvfrom_args /* {
1134 struct recvfrom_args /* {
1135 int s;
1136 caddr_t buf;
1137 size_t len;
1138 int flags;
1139 struct sockaddr * __restrict from;
1140 socklen_t * __restrict fromlenaddr;
1141 } */ *uap;
1142{

--- 32 unchanged lines hidden (view full) ---

1175 return (recvfrom(td, uap));
1176}
1177#endif
1178
1179#ifdef COMPAT_OLDSOCK
1180int
1181orecv(td, uap)
1182 struct thread *td;
1135 int s;
1136 caddr_t buf;
1137 size_t len;
1138 int flags;
1139 struct sockaddr * __restrict from;
1140 socklen_t * __restrict fromlenaddr;
1141 } */ *uap;
1142{

--- 32 unchanged lines hidden (view full) ---

1175 return (recvfrom(td, uap));
1176}
1177#endif
1178
1179#ifdef COMPAT_OLDSOCK
1180int
1181orecv(td, uap)
1182 struct thread *td;
1183 register struct orecv_args /* {
1183 struct orecv_args /* {
1184 int s;
1185 caddr_t buf;
1186 int len;
1187 int flags;
1188 } */ *uap;
1189{
1190 struct msghdr msg;
1191 struct iovec aiov;

--- 79 unchanged lines hidden (view full) ---

1271 free(iov, M_IOV);
1272 return (error);
1273}
1274
1275/* ARGSUSED */
1276int
1277shutdown(td, uap)
1278 struct thread *td;
1184 int s;
1185 caddr_t buf;
1186 int len;
1187 int flags;
1188 } */ *uap;
1189{
1190 struct msghdr msg;
1191 struct iovec aiov;

--- 79 unchanged lines hidden (view full) ---

1271 free(iov, M_IOV);
1272 return (error);
1273}
1274
1275/* ARGSUSED */
1276int
1277shutdown(td, uap)
1278 struct thread *td;
1279 register struct shutdown_args /* {
1279 struct shutdown_args /* {
1280 int s;
1281 int how;
1282 } */ *uap;
1283{
1284 struct socket *so;
1285 struct file *fp;
1286 int error;
1287

--- 7 unchanged lines hidden (view full) ---

1295 NET_UNLOCK_GIANT();
1296 return (error);
1297}
1298
1299/* ARGSUSED */
1300int
1301setsockopt(td, uap)
1302 struct thread *td;
1280 int s;
1281 int how;
1282 } */ *uap;
1283{
1284 struct socket *so;
1285 struct file *fp;
1286 int error;
1287

--- 7 unchanged lines hidden (view full) ---

1295 NET_UNLOCK_GIANT();
1296 return (error);
1297}
1298
1299/* ARGSUSED */
1300int
1301setsockopt(td, uap)
1302 struct thread *td;
1303 register struct setsockopt_args /* {
1303 struct setsockopt_args /* {
1304 int s;
1305 int level;
1306 int name;
1307 caddr_t val;
1308 int valsize;
1309 } */ *uap;
1310{
1311

--- 47 unchanged lines hidden (view full) ---

1359 NET_UNLOCK_GIANT();
1360 return(error);
1361}
1362
1363/* ARGSUSED */
1364int
1365getsockopt(td, uap)
1366 struct thread *td;
1304 int s;
1305 int level;
1306 int name;
1307 caddr_t val;
1308 int valsize;
1309 } */ *uap;
1310{
1311

--- 47 unchanged lines hidden (view full) ---

1359 NET_UNLOCK_GIANT();
1360 return(error);
1361}
1362
1363/* ARGSUSED */
1364int
1365getsockopt(td, uap)
1366 struct thread *td;
1367 register struct getsockopt_args /* {
1367 struct getsockopt_args /* {
1368 int s;
1369 int level;
1370 int name;
1371 void * __restrict val;
1372 socklen_t * __restrict avalsize;
1373 } */ *uap;
1374{
1375 socklen_t valsize;

--- 67 unchanged lines hidden (view full) ---

1443
1444/*
1445 * getsockname1() - Get socket name.
1446 */
1447/* ARGSUSED */
1448static int
1449getsockname1(td, uap, compat)
1450 struct thread *td;
1368 int s;
1369 int level;
1370 int name;
1371 void * __restrict val;
1372 socklen_t * __restrict avalsize;
1373 } */ *uap;
1374{
1375 socklen_t valsize;

--- 67 unchanged lines hidden (view full) ---

1443
1444/*
1445 * getsockname1() - Get socket name.
1446 */
1447/* ARGSUSED */
1448static int
1449getsockname1(td, uap, compat)
1450 struct thread *td;
1451 register struct getsockname_args /* {
1451 struct getsockname_args /* {
1452 int fdes;
1453 struct sockaddr * __restrict asa;
1454 socklen_t * __restrict alen;
1455 } */ *uap;
1456 int compat;
1457{
1458 struct sockaddr *sa;
1459 socklen_t len;

--- 79 unchanged lines hidden (view full) ---

1539
1540/*
1541 * getpeername1() - Get name of peer for connected socket.
1542 */
1543/* ARGSUSED */
1544static int
1545getpeername1(td, uap, compat)
1546 struct thread *td;
1452 int fdes;
1453 struct sockaddr * __restrict asa;
1454 socklen_t * __restrict alen;
1455 } */ *uap;
1456 int compat;
1457{
1458 struct sockaddr *sa;
1459 socklen_t len;

--- 79 unchanged lines hidden (view full) ---

1539
1540/*
1541 * getpeername1() - Get name of peer for connected socket.
1542 */
1543/* ARGSUSED */
1544static int
1545getpeername1(td, uap, compat)
1546 struct thread *td;
1547 register struct getpeername_args /* {
1547 struct getpeername_args /* {
1548 int fdes;
1549 struct sockaddr * __restrict asa;
1550 socklen_t * __restrict alen;
1551 } */ *uap;
1552 int compat;
1553{
1554 struct sockaddr *sa;
1555 socklen_t len;

--- 84 unchanged lines hidden (view full) ---

1640#endif /* COMPAT_OLDSOCK */
1641
1642int
1643sockargs(mp, buf, buflen, type)
1644 struct mbuf **mp;
1645 caddr_t buf;
1646 int buflen, type;
1647{
1548 int fdes;
1549 struct sockaddr * __restrict asa;
1550 socklen_t * __restrict alen;
1551 } */ *uap;
1552 int compat;
1553{
1554 struct sockaddr *sa;
1555 socklen_t len;

--- 84 unchanged lines hidden (view full) ---

1640#endif /* COMPAT_OLDSOCK */
1641
1642int
1643sockargs(mp, buf, buflen, type)
1644 struct mbuf **mp;
1645 caddr_t buf;
1646 int buflen, type;
1647{
1648 register struct sockaddr *sa;
1649 register struct mbuf *m;
1648 struct sockaddr *sa;
1649 struct mbuf *m;
1650 int error;
1651
1652 if ((u_int)buflen > MLEN) {
1653#ifdef COMPAT_OLDSOCK
1654 if (type == MT_SONAME && (u_int)buflen <= 112)
1655 buflen = MLEN; /* unix domain compat. hack */
1656 else
1657#endif

--- 1011 unchanged lines hidden ---
1650 int error;
1651
1652 if ((u_int)buflen > MLEN) {
1653#ifdef COMPAT_OLDSOCK
1654 if (type == MT_SONAME && (u_int)buflen <= 112)
1655 buflen = MLEN; /* unix domain compat. hack */
1656 else
1657#endif

--- 1011 unchanged lines hidden ---