summaryrefslogtreecommitdiffstats
path: root/ospfd/ospf_packet.c
diff options
context:
space:
mode:
authorpilot <pilot>2007-08-21 16:32:56 +0000
committerpilot <pilot>2007-08-21 16:32:56 +0000
commitb9972dc924a4b81489d8cd51c13f7144608a2bc0 (patch)
treedb9722ddf2cd33ad58751a6cd616158c9ae2206d /ospfd/ospf_packet.c
parent2adcf13e1467e27d4ef08046cbca332f30e00b59 (diff)
downloadquagga-b9972dc924a4b81489d8cd51c13f7144608a2bc0.tar.bz2
quagga-b9972dc924a4b81489d8cd51c13f7144608a2bc0.tar.xz
Bug #362 is fixed now.
Diffstat (limited to 'ospfd/ospf_packet.c')
-rw-r--r--ospfd/ospf_packet.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/ospfd/ospf_packet.c b/ospfd/ospf_packet.c
index 4735f99b..a778a50b 100644
--- a/ospfd/ospf_packet.c
+++ b/ospfd/ospf_packet.c
@@ -602,8 +602,12 @@ ospf_write (struct thread *thread)
ipid = (time(NULL) & 0xffff);
#endif /* WANT_OSPF_WRITE_FRAGMENT */
- /* convenience - max OSPF data per packet */
- maxdatasize = oi->ifp->mtu - sizeof (struct ip);
+ /* convenience - max OSPF data per packet,
+ * and reliability - not more data, than our
+ * socket can accept
+ */
+ maxdatasize = MIN (oi->ifp->mtu, ospf->maxsndbuflen) -
+ sizeof (struct ip);
/* Get one packet from queue. */
op = ospf_fifo_head (oi->obuf);