diff options
| author | Donatas Abraitis <donatas@opensourcerouting.org> | 2022-05-13 14:43:11 +0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-05-13 14:43:11 +0300 |
| commit | ef013a6985f5d522451a5d4ffec70205fef13d71 (patch) | |
| tree | f41244d9ae9e61cd77d3677aa5d798f5ed77a7b6 | |
| parent | f205a2309c7dc961216417fb49b4639892b219be (diff) | |
| parent | e51c0f771dccf82cd7201f6e03f902fc85a7f3c2 (diff) | |
Merge pull request #11194 from donaldsharp/untrusted
Some more Coverity issues solved
| -rw-r--r-- | babeld/message.c | 8 | ||||
| -rw-r--r-- | bfdd/bfdd.c | 2 | ||||
| -rw-r--r-- | bgpd/bgp_attr.c | 2 |
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; |
