Here is a diff to refactor and update dvrmpd to use the new ibuf API.
Instead of doing the checksum calculations in various places do it in
send_packet() as a central place.

Could people using dvrmpd test this diff, thanks
-- 
:wq Claudio

Index: ask_nbrs2.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/ask_nbrs2.c,v
retrieving revision 1.5
diff -u -p -r1.5 ask_nbrs2.c
--- ask_nbrs2.c 7 Dec 2015 19:17:18 -0000       1.5
+++ ask_nbrs2.c 15 Jun 2023 07:43:01 -0000
@@ -36,7 +36,6 @@ send_ask_nbrs2(struct iface *iface, stru
 {
        struct sockaddr_in       dst;
        struct ibuf             *buf;
-       struct dvmrp_hdr        *dvmrp_hdr;
        int                      ret = 0;
 
        log_debug("send_ask_nbrs2: interface %s addr %s",
@@ -56,11 +55,7 @@ send_ask_nbrs2(struct iface *iface, stru
        dst.sin_len = sizeof(struct sockaddr_in);
        dst.sin_addr.s_addr = addr.s_addr;
 
-       /* update chksum */
-       dvmrp_hdr = ibuf_seek(buf, 0, sizeof(*dvmrp_hdr));
-       dvmrp_hdr->chksum = in_cksum(buf->buf, buf->wpos);
-
-       ret = send_packet(iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(iface, buf, &dst);
        ibuf_free(buf);
        return (ret);
 fail:
Index: dvmrpe.h
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/dvmrpe.h,v
retrieving revision 1.7
diff -u -p -r1.7 dvmrpe.h
--- dvmrpe.h    19 Jan 2021 12:23:30 -0000      1.7
+++ dvmrpe.h    15 Jun 2023 07:43:01 -0000
@@ -183,7 +183,8 @@ struct ctl_nbr      *nbr_to_ctl(struct nbr *)
 
 /* packet.c */
 int             gen_dvmrp_hdr(struct ibuf *, struct iface *, u_int8_t);
-int             send_packet(struct iface *, void *, size_t, struct sockaddr_in 
*);
+int             send_packet(struct iface *, struct ibuf *,
+                    struct sockaddr_in *);
 void            recv_packet(int, short, void *);
 
 /* probe.c */
Index: graft.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/graft.c,v
retrieving revision 1.5
diff -u -p -r1.5 graft.c
--- graft.c     7 Dec 2015 19:17:18 -0000       1.5
+++ graft.c     15 Jun 2023 07:43:01 -0000
@@ -36,7 +36,6 @@ send_graft(struct iface *iface, struct i
 {
        struct sockaddr_in       dst;
        struct ibuf             *buf;
-       struct dvmrp_hdr        *dvmrp_hdr;
        int                      ret = 0;
 
        log_debug("send_graft: interface %s addr %s",
@@ -56,11 +55,7 @@ send_graft(struct iface *iface, struct i
        dst.sin_len = sizeof(struct sockaddr_in);
        dst.sin_addr.s_addr = addr.s_addr;
 
-       /* update chksum */
-       dvmrp_hdr = ibuf_seek(buf, 0, sizeof(*dvmrp_hdr));
-       dvmrp_hdr->chksum = in_cksum(buf->buf, buf->wpos);
-
-       ret = send_packet(iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(iface, buf, &dst);
        ibuf_free(buf);
        return (ret);
 fail:
Index: graft_ack.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/graft_ack.c,v
retrieving revision 1.5
diff -u -p -r1.5 graft_ack.c
--- graft_ack.c 7 Dec 2015 19:17:18 -0000       1.5
+++ graft_ack.c 15 Jun 2023 07:43:01 -0000
@@ -36,7 +36,6 @@ send_graft_ack(struct iface *iface, stru
 {
        struct sockaddr_in       dst;
        struct ibuf             *buf;
-       struct dvmrp_hdr        *dvmrp_hdr;
        int                      ret = 0;
 
        log_debug("send_graft_ack: interface %s addr %s",
@@ -56,11 +55,7 @@ send_graft_ack(struct iface *iface, stru
        dst.sin_len = sizeof(struct sockaddr_in);
        dst.sin_addr.s_addr = addr.s_addr;
 
-       /* update chksum */
-       dvmrp_hdr = ibuf_seek(buf, 0, sizeof(*dvmrp_hdr));
-       dvmrp_hdr->chksum = in_cksum(buf->buf, buf->wpos);
-
-       ret = send_packet(iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(iface, buf, &dst);
        ibuf_free(buf);
        return (ret);
 fail:
Index: igmp.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/igmp.c,v
retrieving revision 1.4
diff -u -p -r1.4 igmp.c
--- igmp.c      7 Dec 2015 19:14:49 -0000       1.4
+++ igmp.c      15 Jun 2023 07:43:01 -0000
@@ -73,9 +73,6 @@ send_igmp_query(struct iface *iface, str
                igmp_hdr.max_resp_time = iface->last_member_query_interval;
        }
 
-       /* update chksum */
-       igmp_hdr.chksum = in_cksum(&igmp_hdr, sizeof(igmp_hdr));
-
        ibuf_add(buf, &igmp_hdr, sizeof(igmp_hdr));
 
        /* set destination address */
@@ -83,7 +80,7 @@ send_igmp_query(struct iface *iface, str
        dst.sin_len = sizeof(struct sockaddr_in);
        inet_aton(AllSystems, &dst.sin_addr);
 
-       ret = send_packet(iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(iface, buf, &dst);
        ibuf_free(buf);
        return (ret);
 }
Index: nbrs2.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/nbrs2.c,v
retrieving revision 1.4
diff -u -p -r1.4 nbrs2.c
--- nbrs2.c     5 May 2015 01:26:37 -0000       1.4
+++ nbrs2.c     15 Jun 2023 07:43:01 -0000
@@ -37,7 +37,6 @@ send_nbrs2(struct iface *iface, struct i
 {
        struct sockaddr_in       dst;
        struct ibuf             *buf;
-       struct dvmrp_hdr        *dvmrp_hdr;
        int                      ret = 0;
 
        log_debug("send_nbrs2: interface %s addr %s",
@@ -57,11 +56,7 @@ send_nbrs2(struct iface *iface, struct i
        dst.sin_len = sizeof(struct sockaddr_in);
        dst.sin_addr.s_addr = addr.s_addr;
 
-       /* update chksum */
-       dvmrp_hdr = ibuf_seek(buf, 0, sizeof(*dvmrp_hdr));
-       dvmrp_hdr->chksum = in_cksum(buf->buf, buf->wpos);
-
-       ret = send_packet(iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(iface, buf, &dst);
        ibuf_free(buf);
        return (ret);
 fail:
Index: packet.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/packet.c,v
retrieving revision 1.7
diff -u -p -r1.7 packet.c
--- packet.c    19 Jan 2021 16:02:56 -0000      1.7
+++ packet.c    16 Jun 2023 10:23:47 -0000
@@ -27,6 +27,7 @@
 
 #include <errno.h>
 #include <event.h>
+#include <stddef.h>
 #include <stdlib.h>
 #include <string.h>
 
@@ -61,8 +62,10 @@ gen_dvmrp_hdr(struct ibuf *buf, struct i
 
 /* send and receive packets */
 int
-send_packet(struct iface *iface, void *pkt, size_t len, struct sockaddr_in 
*dst)
+send_packet(struct iface *iface, struct ibuf *pkt, struct sockaddr_in *dst)
 {
+       u_int16_t       chksum;
+
        if (iface->passive) {
                log_warnx("send_packet: cannot send packet on passive "
                    "interface %s", iface->name);
@@ -77,7 +80,15 @@ send_packet(struct iface *iface, void *p
                        return (-1);
                }
 
-       if (sendto(iface->fd, pkt, len, 0,
+       /* update chksum */
+       chksum = in_cksum(ibuf_data(pkt), ibuf_size(pkt));
+       if (ibuf_set(pkt, offsetof(struct dvmrp_hdr, chksum),
+           &chksum, sizeof(chksum)) == -1) {
+               log_warn("send_packet: failed to update checksum");
+               return (-1);
+       }
+
+       if (sendto(iface->fd, ibuf_data(pkt), ibuf_size(pkt), 0,
            (struct sockaddr *)dst, sizeof(*dst)) == -1 ) {
                log_warn("send_packet: error sending packet on interface %s",
                    iface->name);
Index: probe.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/probe.c,v
retrieving revision 1.4
diff -u -p -r1.4 probe.c
--- probe.c     5 May 2015 01:26:37 -0000       1.4
+++ probe.c     15 Jun 2023 07:46:04 -0000
@@ -39,7 +39,6 @@ send_probe(struct iface *iface)
 {
        struct sockaddr_in       dst;
        struct ibuf             *buf;
-       struct dvmrp_hdr        *dvmrp_hdr;
        struct nbr              *nbr;
        int                      ret = 0;
 
@@ -67,11 +66,7 @@ send_probe(struct iface *iface)
        dst.sin_len = sizeof(struct sockaddr_in);
        inet_aton(AllDVMRPRouters, &dst.sin_addr);
 
-       /* update chksum */
-       dvmrp_hdr = ibuf_seek(buf, 0, sizeof(*dvmrp_hdr));
-       dvmrp_hdr->chksum = in_cksum(buf->buf, buf->wpos);
-
-       ret = send_packet(iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(iface, buf, &dst);
        ibuf_free(buf);
        return (ret);
 fail:
Index: prune.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/prune.c,v
retrieving revision 1.6
diff -u -p -r1.6 prune.c
--- prune.c     7 Dec 2015 19:14:49 -0000       1.6
+++ prune.c     15 Jun 2023 07:43:01 -0000
@@ -37,7 +37,6 @@ send_prune(struct nbr *nbr, struct prune
 {
        struct sockaddr_in       dst;
        struct ibuf             *buf;
-       struct dvmrp_hdr        *dvmrp_hdr;
        struct prune_hdr         prune;
        int                      ret = 0;
 
@@ -69,11 +68,7 @@ send_prune(struct nbr *nbr, struct prune
 
        ibuf_add(buf, &prune, sizeof(prune));
 
-       /* update chksum */
-       dvmrp_hdr = ibuf_seek(buf, 0, sizeof(*dvmrp_hdr));
-       dvmrp_hdr->chksum = in_cksum(buf->buf, buf->wpos);
-
-       ret = send_packet(nbr->iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(nbr->iface, buf, &dst);
        ibuf_free(buf);
 
        return (ret);
Index: report.c
===================================================================
RCS file: /cvs/src/usr.sbin/dvmrpd/report.c,v
retrieving revision 1.11
diff -u -p -r1.11 report.c
--- report.c    7 Dec 2015 18:59:31 -0000       1.11
+++ report.c    15 Jun 2023 07:43:01 -0000
@@ -41,7 +41,6 @@ send_report(struct iface *iface, struct 
 {
        struct sockaddr_in       dst;
        struct ibuf             *buf;
-       struct dvmrp_hdr        *dvmrp_hdr;
        int                      ret = 0;
 
        log_debug("send_report: interface %s addr %s",
@@ -63,11 +62,7 @@ send_report(struct iface *iface, struct 
        dst.sin_len = sizeof(struct sockaddr_in);
        dst.sin_addr.s_addr = addr.s_addr;
 
-       /* update chksum */
-       dvmrp_hdr = ibuf_seek(buf, 0, sizeof(*dvmrp_hdr));
-       dvmrp_hdr->chksum = in_cksum(buf->buf, buf->wpos);
-
-       ret = send_packet(iface, buf->buf, buf->wpos, &dst);
+       ret = send_packet(iface, buf, &dst);
        ibuf_free(buf);
        return (ret);
 fail:
@@ -247,7 +242,7 @@ rr_list_send(struct rr_head *rr_list, st
 
                prefixlen = 0;
                while (((le = TAILQ_FIRST(rr_list)) != NULL) &&
-                   (buf->wpos < 1000)) {
+                   (ibuf_size(buf) < 1000)) {
                        /* netmask */
                        netmask = le->re->mask.s_addr;
                        if (prefixlen != mask2prefixlen(netmask)) {
@@ -288,7 +283,7 @@ rr_list_send(struct rr_head *rr_list, st
                        rr_list_remove(le->re);
                        free(le);
                }
-               send_report(iface, addr, buf->buf, buf->wpos);
+               send_report(iface, addr, ibuf_data(buf), ibuf_size(buf));
                ibuf_free(buf);
        }
 }

Reply via email to