diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 2004-12-08 17:35:17 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 2004-12-08 17:35:17 +0000 |
commit | 8bf51d85b909c86c9fd82740b6008033d9358883 (patch) | |
tree | 7a2015acaca4e19baa76cb74710c70330db2849e /usr.sbin | |
parent | 9b87f93448fdfd5ec12156b7bcdb288c675ed0b8 (diff) |
use two tiny macros for copying fields out to simplify reading; henning@ ok
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/ntpd/ntp_msg.c | 111 |
1 files changed, 40 insertions, 71 deletions
diff --git a/usr.sbin/ntpd/ntp_msg.c b/usr.sbin/ntpd/ntp_msg.c index 2d7f942db26..0a1496d6475 100644 --- a/usr.sbin/ntpd/ntp_msg.c +++ b/usr.sbin/ntpd/ntp_msg.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ntp_msg.c,v 1.12 2004/12/08 15:47:38 mickey Exp $ */ +/* $OpenBSD: ntp_msg.c,v 1.13 2004/12/08 17:35:16 mickey Exp $ */ /* * Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org> @@ -34,40 +34,25 @@ ntp_getmsg(char *p, ssize_t len, struct ntp_msg *msg) return (-1); } - memcpy(&msg->status, p, sizeof(msg->status)); - p += sizeof(msg->status); - memcpy(&msg->stratum, p, sizeof(msg->stratum)); - p += sizeof(msg->stratum); - memcpy(&msg->ppoll, p, sizeof(msg->ppoll)); - p += sizeof(msg->ppoll); - memcpy(&msg->precision, p, sizeof(msg->precision)); - p += sizeof(msg->precision); - memcpy(&msg->rootdelay.int_parts, p, sizeof(msg->rootdelay.int_parts)); - p += sizeof(msg->rootdelay.int_parts); - memcpy(&msg->rootdelay.fractions, p, sizeof(msg->rootdelay.fractions)); - p += sizeof(msg->rootdelay.fractions); - memcpy(&msg->dispersion.int_parts, p, sizeof(msg->dispersion.int_parts)); - p += sizeof(msg->dispersion.int_parts); - memcpy(&msg->dispersion.fractions, p, sizeof(msg->dispersion.fractions)); - p += sizeof(msg->dispersion.fractions); - memcpy(&msg->refid, p, sizeof(msg->refid)); - p += sizeof(msg->refid); - memcpy(&msg->reftime.int_partl, p, sizeof(msg->reftime.int_partl)); - p += sizeof(msg->reftime.int_partl); - memcpy(&msg->reftime.fractionl, p, sizeof(msg->reftime.fractionl)); - p += sizeof(msg->reftime.fractionl); - memcpy(&msg->orgtime.int_partl, p, sizeof(msg->orgtime.int_partl)); - p += sizeof(msg->orgtime.int_partl); - memcpy(&msg->orgtime.fractionl, p, sizeof(msg->orgtime.fractionl)); - p += sizeof(msg->orgtime.fractionl); - memcpy(&msg->rectime.int_partl, p, sizeof(msg->rectime.int_partl)); - p += sizeof(msg->rectime.int_partl); - memcpy(&msg->rectime.fractionl, p, sizeof(msg->rectime.fractionl)); - p += sizeof(msg->rectime.fractionl); - memcpy(&msg->xmttime.int_partl, p, sizeof(msg->xmttime.int_partl)); - p += sizeof(msg->xmttime.int_partl); - memcpy(&msg->xmttime.fractionl, p, sizeof(msg->xmttime.fractionl)); - p += sizeof(msg->xmttime.fractionl); +#define copyin(f,p) memcpy(&(f), (p), sizeof(f)); (p) += sizeof(f) + + copyin(msg->status, p); + copyin(msg->stratum, p); + copyin(msg->ppoll, p); + copyin(msg->precision, p); + copyin(msg->rootdelay.int_parts, p); + copyin(msg->rootdelay.fractions, p); + copyin(msg->dispersion.int_parts, p); + copyin(msg->dispersion.fractions, p); + copyin(msg->refid, p); + copyin(msg->reftime.int_partl, p); + copyin(msg->reftime.fractionl, p); + copyin(msg->orgtime.int_partl, p); + copyin(msg->orgtime.fractionl, p); + copyin(msg->rectime.int_partl, p); + copyin(msg->rectime.fractionl, p); + copyin(msg->xmttime.int_partl, p); + copyin(msg->xmttime.fractionl, p); return (0); } @@ -77,44 +62,28 @@ ntp_sendmsg(int fd, struct sockaddr *sa, struct ntp_msg *msg, ssize_t len, int auth) { char buf[NTP_MSGSIZE]; - char *p; + char *p = buf; u_int8_t sa_len; - p = buf; - memcpy(p, &msg->status, sizeof(msg->status)); - p += sizeof(msg->status); - memcpy(p, &msg->stratum, sizeof(msg->stratum)); - p += sizeof(msg->stratum); - memcpy(p, &msg->ppoll, sizeof(msg->ppoll)); - p += sizeof(msg->ppoll); - memcpy(p, &msg->precision, sizeof(msg->precision)); - p += sizeof(msg->precision); - memcpy(p, &msg->rootdelay.int_parts, sizeof(msg->rootdelay.int_parts)); - p += sizeof(msg->rootdelay.int_parts); - memcpy(p, &msg->rootdelay.fractions, sizeof(msg->rootdelay.fractions)); - p += sizeof(msg->rootdelay.fractions); - memcpy(p, &msg->dispersion.int_parts, sizeof(msg->dispersion.int_parts)); - p += sizeof(msg->dispersion.int_parts); - memcpy(p, &msg->dispersion.fractions, sizeof(msg->dispersion.fractions)); - p += sizeof(msg->dispersion.fractions); - memcpy(p, &msg->refid, sizeof(msg->refid)); - p += sizeof(msg->refid); - memcpy(p, &msg->reftime.int_partl, sizeof(msg->reftime.int_partl)); - p += sizeof(msg->reftime.int_partl); - memcpy(p, &msg->reftime.fractionl, sizeof(msg->reftime.fractionl)); - p += sizeof(msg->reftime.fractionl); - memcpy(p, &msg->orgtime.int_partl, sizeof(msg->orgtime.int_partl)); - p += sizeof(msg->orgtime.int_partl); - memcpy(p, &msg->orgtime.fractionl, sizeof(msg->orgtime.fractionl)); - p += sizeof(msg->orgtime.fractionl); - memcpy(p, &msg->rectime.int_partl, sizeof(msg->rectime.int_partl)); - p += sizeof(msg->rectime.int_partl); - memcpy(p, &msg->rectime.fractionl, sizeof(msg->rectime.fractionl)); - p += sizeof(msg->rectime.fractionl); - memcpy(p, &msg->xmttime.int_partl, sizeof(msg->xmttime.int_partl)); - p += sizeof(msg->xmttime.int_partl); - memcpy(p, &msg->xmttime.fractionl, sizeof(msg->xmttime.fractionl)); - p += sizeof(msg->xmttime.fractionl); +#define copyout(p,f) memcpy((p), &(f), sizeof(f)); p += sizeof(f) + + copyout(p, msg->status); + copyout(p, msg->stratum); + copyout(p, msg->ppoll); + copyout(p, msg->precision); + copyout(p, msg->rootdelay.int_parts); + copyout(p, msg->rootdelay.fractions); + copyout(p, msg->dispersion.int_parts); + copyout(p, msg->dispersion.fractions); + copyout(p, msg->refid); + copyout(p, msg->reftime.int_partl); + copyout(p, msg->reftime.fractionl); + copyout(p, msg->orgtime.int_partl); + copyout(p, msg->orgtime.fractionl); + copyout(p, msg->rectime.int_partl); + copyout(p, msg->rectime.fractionl); + copyout(p, msg->xmttime.int_partl); + copyout(p, msg->xmttime.fractionl); if (sa != NULL) sa_len = SA_LEN(sa); |