summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/kern/syscalls.master18
-rw-r--r--sys/kern/uipc_syscalls.c69
2 files changed, 41 insertions, 46 deletions
diff --git a/sys/kern/syscalls.master b/sys/kern/syscalls.master
index c679ebefcce..9bf47b2760a 100644
--- a/sys/kern/syscalls.master
+++ b/sys/kern/syscalls.master
@@ -1,4 +1,4 @@
-; $OpenBSD: syscalls.master,v 1.32 1998/11/18 01:14:25 art Exp $
+; $OpenBSD: syscalls.master,v 1.33 1999/02/15 20:00:49 millert Exp $
; $NetBSD: syscalls.master,v 1.32 1996/04/23 10:24:21 mycroft Exp $
; @(#)syscalls.master 8.2 (Berkeley) 1/13/94
@@ -89,13 +89,13 @@
const struct msghdr *msg, int flags); }
29 STD { ssize_t sys_recvfrom(int s, void *buf, size_t len, \
int flags, struct sockaddr *from, \
- int *fromlenaddr); }
+ socklen_t *fromlenaddr); }
30 STD { int sys_accept(int s, struct sockaddr *name, \
- int *anamelen); }
+ socklen_t *anamelen); }
31 STD { int sys_getpeername(int fdes, struct sockaddr *asa, \
int *alen); }
32 STD { int sys_getsockname(int fdes, struct sockaddr *asa, \
- int *alen); }
+ socklen_t *alen); }
33 STD { int sys_access(const char *path, int flags); }
34 STD { int sys_chflags(const char *path, u_int flags); }
35 STD { int sys_fchflags(int fd, u_int flags); }
@@ -190,7 +190,7 @@
96 STD { int sys_setpriority(int which, int who, int prio); }
97 STD { int sys_socket(int domain, int type, int protocol); }
98 STD { int sys_connect(int s, const struct sockaddr *name, \
- int namelen); }
+ socklen_t namelen); }
99 COMPAT_43 { int sys_accept(int s, caddr_t name, \
int *anamelen); } oaccept
100 STD { int sys_getpriority(int which, int who); }
@@ -200,9 +200,9 @@
int flags); } orecv
103 STD { int sys_sigreturn(struct sigcontext *sigcntxp); }
104 STD { int sys_bind(int s, const struct sockaddr *name, \
- int namelen); }
+ socklen_t namelen); }
105 STD { int sys_setsockopt(int s, int level, int name, \
- const void *val, int valsize); }
+ const void *val, socklen_t valsize); }
106 STD { int sys_listen(int s, int backlog); }
107 OBSOL vtimes
108 COMPAT_43 { int sys_sigvec(int signum, struct sigvec *nsv, \
@@ -225,7 +225,7 @@
struct timezone *tzp); }
117 STD { int sys_getrusage(int who, struct rusage *rusage); }
118 STD { int sys_getsockopt(int s, int level, int name, \
- void *val, int *avalsize); }
+ void *val, socklen_t *avalsize); }
119 OBSOL resuba
120 STD { ssize_t sys_readv(int fd, \
const struct iovec *iovp, int iovcnt); }
@@ -260,7 +260,7 @@
140 STD { int sys_adjtime(const struct timeval *delta, \
struct timeval *olddelta); }
141 COMPAT_43 { int sys_getpeername(int fdes, caddr_t asa, \
- int *alen); } ogetpeername
+ socklen_t *alen); } ogetpeername
142 COMPAT_43 { int32_t sys_gethostid(void); } ogethostid
143 COMPAT_43 { int sys_sethostid(int32_t hostid); } osethostid
144 COMPAT_43 { int sys_getrlimit(int which, \
diff --git a/sys/kern/uipc_syscalls.c b/sys/kern/uipc_syscalls.c
index 39b89b18242..746d7275754 100644
--- a/sys/kern/uipc_syscalls.c
+++ b/sys/kern/uipc_syscalls.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uipc_syscalls.c,v 1.17 1999/02/14 21:11:01 millert Exp $ */
+/* $OpenBSD: uipc_syscalls.c,v 1.18 1999/02/15 20:00:50 millert Exp $ */
/* $NetBSD: uipc_syscalls.c,v 1.19 1996/02/09 19:00:48 christos Exp $ */
/*
@@ -104,7 +104,7 @@ sys_bind(p, v, retval)
register struct sys_bind_args /* {
syscallarg(int) s;
syscallarg(struct sockaddr *) name;
- syscallarg(int) namelen;
+ syscallarg(socklen_t) namelen;
} */ *uap = v;
struct file *fp;
struct mbuf *nam;
@@ -149,20 +149,17 @@ sys_accept(p, v, retval)
register struct sys_accept_args /* {
syscallarg(int) s;
syscallarg(struct sockaddr *) name;
- syscallarg(int *) anamelen;
+ syscallarg(socklen_t *) anamelen;
} */ *uap = v;
struct file *fp;
struct mbuf *nam;
- int namelen, error, s, tmpfd;
+ socklen_t namelen;
+ int error, s, tmpfd;
register struct socket *so;
- if (SCARG(uap, name)) {
- if ((error = copyin((caddr_t)SCARG(uap, anamelen),
- (caddr_t)&namelen, sizeof (namelen))))
- return (error);
- if (namelen < 0)
- return (EFAULT);
- }
+ if (SCARG(uap, name) && (error = copyin((caddr_t)SCARG(uap, anamelen),
+ (caddr_t)&namelen, sizeof (namelen))))
+ return (error);
if ((error = getsock(p->p_fd, SCARG(uap, s), &fp)) != 0)
return (error);
s = splsoftnet();
@@ -214,7 +211,7 @@ sys_accept(p, v, retval)
namelen = nam->m_len;
/* SHOULD COPY OUT A CHAIN HERE */
if ((error = copyout(mtod(nam, caddr_t),
- (caddr_t)SCARG(uap, name), (u_int)namelen)) == 0)
+ (caddr_t)SCARG(uap, name), namelen)) == 0)
error = copyout((caddr_t)&namelen,
(caddr_t)SCARG(uap, anamelen),
sizeof (*SCARG(uap, anamelen)));
@@ -234,7 +231,7 @@ sys_connect(p, v, retval)
register struct sys_connect_args /* {
syscallarg(int) s;
syscallarg(struct sockaddr *) name;
- syscallarg(int) namelen;
+ syscallarg(socklen_t) namelen;
} */ *uap = v;
struct file *fp;
register struct socket *so;
@@ -529,7 +526,7 @@ sys_recvfrom(p, v, retval)
syscallarg(size_t) len;
syscallarg(int) flags;
syscallarg(struct sockaddr *) from;
- syscallarg(int *) fromlenaddr;
+ syscallarg(socklen_t *) fromlenaddr;
} */ *uap = v;
struct msghdr msg;
struct iovec aiov;
@@ -614,7 +611,8 @@ recvit(p, s, mp, namelenp, retsize)
struct uio auio;
register struct iovec *iov;
register int i;
- int len, error;
+ size_t len;
+ int error;
struct mbuf *from = 0, *control = 0;
#ifdef KTRACE
struct iovec *ktriov = NULL;
@@ -767,7 +765,7 @@ sys_setsockopt(p, v, retval)
syscallarg(int) level;
syscallarg(int) name;
syscallarg(caddr_t) val;
- syscallarg(int) valsize;
+ syscallarg(socklen_t) valsize;
} */ *uap = v;
struct file *fp;
struct mbuf *m = NULL;
@@ -782,7 +780,7 @@ sys_setsockopt(p, v, retval)
if (m == NULL)
return (ENOBUFS);
error = copyin(SCARG(uap, val), mtod(m, caddr_t),
- (u_int)SCARG(uap, valsize));
+ SCARG(uap, valsize));
if (error) {
(void) m_free(m);
return (error);
@@ -805,11 +803,12 @@ sys_getsockopt(p, v, retval)
syscallarg(int) level;
syscallarg(int) name;
syscallarg(caddr_t) val;
- syscallarg(int *) avalsize;
+ syscallarg(socklen_t *) avalsize;
} */ *uap = v;
struct file *fp;
struct mbuf *m = NULL;
- int valsize, error;
+ socklen_t valsize;
+ int error;
if ((error = getsock(p->p_fd, SCARG(uap, s), &fp)) != 0)
return (error);
@@ -820,15 +819,12 @@ sys_getsockopt(p, v, retval)
return (error);
} else
valsize = 0;
- if (valsize < 0)
- return (EFAULT);
if ((error = sogetopt((struct socket *)fp->f_data, SCARG(uap, level),
SCARG(uap, name), &m)) == 0 && SCARG(uap, val) && valsize &&
m != NULL) {
if (valsize > m->m_len)
valsize = m->m_len;
- error = copyout(mtod(m, caddr_t), SCARG(uap, val),
- (u_int)valsize);
+ error = copyout(mtod(m, caddr_t), SCARG(uap, val), valsize);
if (error == 0)
error = copyout((caddr_t)&valsize,
(caddr_t)SCARG(uap, avalsize), sizeof (valsize));
@@ -899,20 +895,19 @@ sys_getsockname(p, v, retval)
register struct sys_getsockname_args /* {
syscallarg(int) fdes;
syscallarg(caddr_t) asa;
- syscallarg(int *) alen;
+ syscallarg(socklen_t *) alen;
} */ *uap = v;
struct file *fp;
register struct socket *so;
struct mbuf *m;
- int len, error;
+ socklen_t len;
+ int error;
if ((error = getsock(p->p_fd, SCARG(uap, fdes), &fp)) != 0)
return (error);
error = copyin((caddr_t)SCARG(uap, alen), (caddr_t)&len, sizeof (len));
if (error)
return (error);
- if (len < 0)
- return (EFAULT);
so = (struct socket *)fp->f_data;
m = m_getclr(M_WAIT, MT_SONAME);
if (m == NULL)
@@ -922,7 +917,7 @@ sys_getsockname(p, v, retval)
goto bad;
if (len > m->m_len)
len = m->m_len;
- error = copyout(mtod(m, caddr_t), (caddr_t)SCARG(uap, asa), (u_int)len);
+ error = copyout(mtod(m, caddr_t), (caddr_t)SCARG(uap, asa), len);
if (error == 0)
error = copyout((caddr_t)&len, (caddr_t)SCARG(uap, alen),
sizeof (len));
@@ -944,12 +939,13 @@ sys_getpeername(p, v, retval)
register struct sys_getpeername_args /* {
syscallarg(int) fdes;
syscallarg(caddr_t) asa;
- syscallarg(int *) alen;
+ syscallarg(socklen_t *) alen;
} */ *uap = v;
struct file *fp;
register struct socket *so;
struct mbuf *m;
- int len, error;
+ socklen_t len;
+ int error;
if ((error = getsock(p->p_fd, SCARG(uap, fdes), &fp)) != 0)
return (error);
@@ -959,8 +955,6 @@ sys_getpeername(p, v, retval)
error = copyin((caddr_t)SCARG(uap, alen), (caddr_t)&len, sizeof (len));
if (error)
return (error);
- if (len < 0)
- return (EFAULT);
m = m_getclr(M_WAIT, MT_SONAME);
if (m == NULL)
return (ENOBUFS);
@@ -969,7 +963,7 @@ sys_getpeername(p, v, retval)
goto bad;
if (len > m->m_len)
len = m->m_len;
- error = copyout(mtod(m, caddr_t), (caddr_t)SCARG(uap, asa), (u_int)len);
+ error = copyout(mtod(m, caddr_t), (caddr_t)SCARG(uap, asa), len);
if (error == 0)
error = copyout((caddr_t)&len, (caddr_t)SCARG(uap, alen),
sizeof (len));
@@ -982,15 +976,16 @@ int
sockargs(mp, buf, buflen, type)
struct mbuf **mp;
caddr_t buf;
- int buflen, type;
+ socklen_t buflen;
+ int type;
{
register struct sockaddr *sa;
register struct mbuf *m;
int error;
- if ((u_int)buflen > MLEN) {
+ if (buflen > MLEN) {
#ifdef COMPAT_OLDSOCK
- if (type == MT_SONAME && (u_int)buflen <= 112)
+ if (type == MT_SONAME && buflen <= 112)
buflen = MLEN; /* unix domain compat. hack */
else
#endif
@@ -1000,7 +995,7 @@ sockargs(mp, buf, buflen, type)
if (m == NULL)
return (ENOBUFS);
m->m_len = buflen;
- error = copyin(buf, mtod(m, caddr_t), (u_int)buflen);
+ error = copyin(buf, mtod(m, caddr_t), buflen);
if (error) {
(void) m_free(m);
return (error);