summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDonatas Abraitis <donatas@opensourcerouting.org>2022-05-13 14:43:11 +0300
committerGitHub <noreply@github.com>2022-05-13 14:43:11 +0300
commitef013a6985f5d522451a5d4ffec70205fef13d71 (patch)
treef41244d9ae9e61cd77d3677aa5d798f5ed77a7b6
parentf205a2309c7dc961216417fb49b4639892b219be (diff)
parente51c0f771dccf82cd7201f6e03f902fc85a7f3c2 (diff)
Merge pull request #11194 from donaldsharp/untrusted
Some more Coverity issues solved
-rw-r--r--babeld/message.c8
-rw-r--r--bfdd/bfdd.c2
-rw-r--r--bgpd/bgp_attr.c2
3 files changed, 7 insertions, 5 deletions
diff --git a/babeld/message.c b/babeld/message.c
index 559b8c4e4a..0ddfda8d7b 100644
--- a/babeld/message.c
+++ b/babeld/message.c
@@ -286,7 +286,7 @@ channels_len(unsigned char *channels)
followed by a sequence of TLVs. TLVs of known types are also checked to meet
minimum length constraints defined for each. Return 0 for no errors. */
static int
-babel_packet_examin(const unsigned char *packet, int packetlen)
+babel_packet_examin(const unsigned char *packet, int packetlen, int *blength)
{
int i = 0, bodylen;
const unsigned char *message;
@@ -323,6 +323,8 @@ babel_packet_examin(const unsigned char *packet, int packetlen)
}
i += len + 2;
}
+
+ *blength = bodylen;
return 0;
}
@@ -356,7 +358,7 @@ parse_packet(const unsigned char *from, struct interface *ifp,
return;
}
- if (babel_packet_examin (packet, packetlen)) {
+ if (babel_packet_examin (packet, packetlen, &bodylen)) {
flog_err(EC_BABEL_PACKET,
"Received malformed packet on %s from %s.",
ifp->name, format_address(from));
@@ -369,8 +371,6 @@ parse_packet(const unsigned char *from, struct interface *ifp,
return;
}
- DO_NTOHS(bodylen, packet + 2);
-
i = 0;
while(i < bodylen) {
message = packet + 4 + i;
diff --git a/bfdd/bfdd.c b/bfdd/bfdd.c
index c764941513..7ef229da1b 100644
--- a/bfdd/bfdd.c
+++ b/bfdd/bfdd.c
@@ -337,6 +337,8 @@ int main(int argc, char *argv[])
bool ctlsockused = false;
int opt;
+ bglobal.bg_use_dplane = false;
+
/* Initialize system sockets. */
bg_init();
diff --git a/bgpd/bgp_attr.c b/bgpd/bgp_attr.c
index 6c10469da8..d57281a700 100644
--- a/bgpd/bgp_attr.c
+++ b/bgpd/bgp_attr.c
@@ -4430,7 +4430,7 @@ void bgp_packet_mpunreach_prefix(struct stream *s, const struct prefix *p,
bool addpath_capable, uint32_t addpath_tx_id,
struct attr *attr)
{
- uint8_t wlabel[3] = {0x80, 0x00, 0x00};
+ uint8_t wlabel[4] = {0x80, 0x00, 0x00};
if (safi == SAFI_LABELED_UNICAST) {
label = (mpls_label_t *)wlabel;