summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 39e7b87)
raw | patch | inline | side by side (parent: 39e7b87)
| author | Bruno Prémont <bonbons@linux-vserver.org> | |
| Sat, 15 Jan 2011 18:44:49 +0000 (19:44 +0100) | ||
| committer | Florian Forster <octo@verplant.org> | |
| Sat, 15 Jan 2011 18:59:16 +0000 (19:59 +0100) | 
Current implementation of liboping relies on getting enough CPU shares
and getting those in a timely manner in order to determine correct ping
response times.
Avoid this limitation when kernel is able to provide packet reception
times using SO_TIMESTAMP. (as is done by iputils's ping utility)
Signed-off-by: Florian Forster <octo@verplant.org>
and getting those in a timely manner in order to determine correct ping
response times.
Avoid this limitation when kernel is able to provide packet reception
times using SO_TIMESTAMP. (as is done by iputils's ping utility)
Signed-off-by: Florian Forster <octo@verplant.org>
| src/liboping.c | patch | blob | history | 
diff --git a/src/liboping.c b/src/liboping.c
index 46168434d0c62046d0c9b4f07583009d050674d2..d3fd35c5eb24a636e7690353f18d3095e1cad2c2 100644 (file)
--- a/src/liboping.c
+++ b/src/liboping.c
         * reply. The right object will be returned by ping_receive_ipv*(). For
         * now, we can only rely on ph->fd and ph->addrfamily. */
-       struct timeval diff;
+       struct timeval diff, pkt_now = *now;
        pinghost_t *host = NULL;
        int recv_ttl;
        uint8_t recv_qos;
                        cmsg != NULL;
                        cmsg = CMSG_NXTHDR (&msghdr, cmsg))
        {
+#ifdef SO_TIMESTAMP
+               if (cmsg->cmsg_level == SOL_SOCKET && cmsg->cmsg_type == SO_TIMESTAMP)
+                       memcpy(&pkt_now, CMSG_DATA(cmsg), sizeof(pkt_now));
+#endif /* SO_TIMESTAMP */
+
                if (ph->addrfamily == AF_INET) /* {{{ */
                {
                        if (cmsg->cmsg_level != IPPROTO_IP)
        }
        dprintf ("rcvd: %12i.%06i\n",
-                       (int) now->tv_sec,
-                       (int) now->tv_usec);
+                       (int) pkt_now.tv_sec,
+                       (int) pkt_now.tv_usec);
        dprintf ("sent: %12i.%06i\n",
                        (int) host->timer->tv_sec,
                        (int) host->timer->tv_usec);
-       if (ping_timeval_sub (now, host->timer, &diff) < 0)
+       if (ping_timeval_sub (&pkt_now, host->timer, &diff) < 0)
        {
                timerclear (host->timer);
                return (-1);
                        }
                }
 #endif /* SO_BINDTODEVICE */
-
+#ifdef SO_TIMESTAMP
+               if (1)
+               {
+                       int c = 1;
+                       setsockopt(ph->fd, SOL_SOCKET, SO_TIMESTAMP, &c, sizeof(c));
+               }
+#endif /* SO_TIMESTAMP */
                assert (sizeof (struct sockaddr_storage) >= ai_ptr->ai_addrlen);
                memset (ph->addr, '\0', sizeof (struct sockaddr_storage));
                memcpy (ph->addr, ai_ptr->ai_addr, ai_ptr->ai_addrlen);
![[tokkee]](http://tokkee.org/images/avatar.png)
