diff options
author | Tim J. Robbins <tjr@FreeBSD.org> | 2003-09-28 09:16:09 +0000 |
---|---|---|
committer | Tim J. Robbins <tjr@FreeBSD.org> | 2003-09-28 09:16:09 +0000 |
commit | 99d21d504cd3ea6da3c0c6c1e3eb990bd0b6ea7b (patch) | |
tree | 2ee231ae925c27cf38b2a25fac1aa5f5ac5b5e56 /libexec/talkd | |
parent | c32cccd0bba223f35417edd6a895960274f2de19 (diff) | |
download | src-99d21d504cd3ea6da3c0c6c1e3eb990bd0b6ea7b.tar.gz src-99d21d504cd3ea6da3c0c6c1e3eb990bd0b6ea7b.zip |
Notes
Diffstat (limited to 'libexec/talkd')
-rw-r--r-- | libexec/talkd/talkd.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/libexec/talkd/talkd.c b/libexec/talkd/talkd.c index ae2c6eb05f3e..66ae372589be 100644 --- a/libexec/talkd/talkd.c +++ b/libexec/talkd/talkd.c @@ -86,6 +86,7 @@ main(int argc, char *argv[]) { register CTL_MSG *mp = &request; int cc; + struct sockaddr ctl_addr; #ifdef NOTDEF /* @@ -116,12 +117,13 @@ main(int argc, char *argv[]) continue; } lastmsgtime = time(0); + (void)memcpy(&ctl_addr, &mp->ctl_addr, sizeof(ctl_addr)); + ctl_addr.sa_family = ntohs(mp->ctl_addr.sa_family); + ctl_addr.sa_len = sizeof(ctl_addr); process_request(mp, &response); /* can block here, is this what I want? */ - mp->ctl_addr.sa_family = htons(mp->ctl_addr.sa_family); - cc = sendto(sockt, (char *)&response, - sizeof (response), 0, (struct sockaddr *)&mp->ctl_addr, - sizeof (mp->ctl_addr)); + cc = sendto(sockt, (char *)&response, sizeof (response), 0, + &ctl_addr, sizeof (ctl_addr)); if (cc != sizeof (response)) syslog(LOG_WARNING, "sendto: %m"); } |