diff options
author | robert <robert@FreeBSD.org> | 2002-10-17 15:52:42 +0000 |
---|---|---|
committer | robert <robert@FreeBSD.org> | 2002-10-17 15:52:42 +0000 |
commit | 98f9976c416b138a7aa31424783acb71d4e33356 (patch) | |
tree | 0b4142b6f18eb7ac641ebab7d90f80846f7c112f /sys/kern/uipc_usrreq.c | |
parent | e6696e09a3f2420002bf2bd9650b6d49ac19f312 (diff) | |
download | FreeBSD-src-98f9976c416b138a7aa31424783acb71d4e33356.zip FreeBSD-src-98f9976c416b138a7aa31424783acb71d4e33356.tar.gz |
- Allocate only enough space for a temporary buffer to hold
the path including the terminating NUL character from
`struct sockaddr_un' rather than SOCK_MAXADDRLEN bytes.
- Use strlcpy() instead of strncpy() to copy strings.
Diffstat (limited to 'sys/kern/uipc_usrreq.c')
-rw-r--r-- | sys/kern/uipc_usrreq.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/sys/kern/uipc_usrreq.c b/sys/kern/uipc_usrreq.c index dac95c9..5bbb35c 100644 --- a/sys/kern/uipc_usrreq.c +++ b/sys/kern/uipc_usrreq.c @@ -600,12 +600,14 @@ unp_bind(unp, nam, td) if (unp->unp_vnode != NULL) return (EINVAL); + namelen = soun->sun_len - offsetof(struct sockaddr_un, sun_path); if (namelen <= 0) return EINVAL; - buf = malloc(SOCK_MAXADDRLEN, M_TEMP, M_WAITOK); - strncpy(buf, soun->sun_path, namelen); - buf[namelen] = 0; /* null-terminate the string */ + + buf = malloc(namelen + 1, M_TEMP, M_WAITOK); + strlcpy(buf, soun->sun_path, namelen + 1); + restart: NDINIT(&nd, CREATE, NOFOLLOW | LOCKPARENT | SAVENAME, UIO_SYSSPACE, buf, td); @@ -680,8 +682,7 @@ unp_connect(so, nam, td) len = nam->sa_len - offsetof(struct sockaddr_un, sun_path); if (len <= 0) return EINVAL; - strncpy(buf, soun->sun_path, len); - buf[len] = 0; + strlcpy(buf, soun->sun_path, len + 1); NDINIT(&nd, LOOKUP, FOLLOW | LOCKLEAF, UIO_SYSSPACE, buf, td); error = namei(&nd); |