On Sun, Aug 15, 2010 at 09:16:32AM +0200, Matthieu Herrb wrote:
> On Sun, Aug 15, 2010 at 2:32 AM, Daniel Ouellet <dan...@presscom.net> wrote:
> > In trying the latest snapshots on sparc64 servers, so far 3 of them all give
> > me the same errors. I can't use the -n flag anymore with rdate as before.
> >
> > It worked on 4.7 and before. Not sure of the exact date it stop working.
> >
> > Any suggestions?
> >
> Probably an aligment problem.
> 
> Try this patch:
> 
> Index: ntp.c
> ===================================================================
> RCS file: /cvs/src/usr.sbin/rdate/ntp.c,v
> retrieving revision 1.29
> diff -u -r1.29 ntp.c
> --- ntp.c       17 Sep 2006 17:03:56 -0000      1.29
> +++ ntp.c       15 Aug 2010 07:12:11 -0000
> @@ -305,7 +305,8 @@
>  int
>  read_packet(int fd, struct ntp_data *data, double *off, double *error)
>  {
> -       u_char  receive[NTP_PACKET_MAX];
> +       u_int64_t receivebuf[howmany(NTP_PACKET_MAX, sizeof(u_int64_t))];
> +       u_char  *receive = (u_char *)receivebuf;;
>         struct  timeval tv;
>         double  x, y;
>         int     length, r;
> 
> 
> -- 
> Matthieu Herrb

There may be a similar potential issue in write_packet. Here I use
bcopy() rather than aligning the buffer on the stack. Not sure what
the preferred idiom is. This way it will continue to work if
recvck/xmitck ever become u_int128_t. :-).

.... Ken

Index: ntp.c
===================================================================
RCS file: /cvs/src/usr.sbin/rdate/ntp.c,v
retrieving revision 1.29
diff -u -p -r1.29 ntp.c
--- ntp.c       17 Sep 2006 17:03:56 -0000      1.29
+++ ntp.c       15 Aug 2010 11:01:55 -0000
@@ -280,9 +280,11 @@ write_packet(int fd, struct ntp_data *da
         * No endian concerns here.  Since we're running as a strict
         * unicast client, we don't have to worry about anyone else finding
         * the transmit field intelligible.
+        *
+        * NOTE: packet is not necessarily aligned, so a (u_int64_t *) would
+        *       be bad on aligned architectures!
         */
-
-       *(u_int64_t *)(packet + NTP_TRANSMIT) = data->xmitck;
+       bcopy(&data->xmitck, (packet + NTP_TRANSMIT), sizeof(data->xmitck));
 
        data->originate = current_time(JAN_1970);
 
@@ -423,8 +425,13 @@ unpack_ntp(struct ntp_data *data, u_char
 
        data->transmit = d / NTP_SCALE;
 
-       /* See write_packet for why this isn't an endian problem. */
-       data->recvck = *(u_int64_t *)(packet + NTP_ORIGINATE);
+       /*
+        * See write_packet for why this isn't an endian problem.
+        *
+        * NOTE: packet is not necessarily aligned, so a (u_int64_t *) would
+        *       be bad on aligned architectures!
+        */
+       bcopy((packet + NTP_ORIGINATE), &data->recvck, sizeof(data->recvck));
 }
 
 /*

Reply via email to