Skip to content

Commit

Permalink
Merge pull request #16922 from FRRouting/mergify/bp/stable/9.0/pr-16918
Browse files Browse the repository at this point in the history
zebra snmp fixes (backport #16918)
  • Loading branch information
donaldsharp authored Oct 1, 2024
2 parents 4eddddb + 707dfd0 commit 42126fc
Showing 1 changed file with 15 additions and 15 deletions.
30 changes: 15 additions & 15 deletions zebra/zebra_snmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -227,6 +227,8 @@ static int proto_trans(int type)
return 3; /* static route */
case ZEBRA_ROUTE_RIP:
return 8; /* rip */
case ZEBRA_ROUTE_ISIS:
return 9;
case ZEBRA_ROUTE_RIPNG:
return 1; /* shouldn't happen */
case ZEBRA_ROUTE_OSPF:
Expand All @@ -235,6 +237,8 @@ static int proto_trans(int type)
return 1; /* shouldn't happen */
case ZEBRA_ROUTE_BGP:
return 14; /* bgp */
case ZEBRA_ROUTE_EIGRP:
return 16;
default:
return 1; /* other */
}
Expand All @@ -251,9 +255,11 @@ static void check_replace(struct route_node *np2, struct route_entry *re2,
return;
}

if (prefix_cmp(&(*np)->p, &np2->p) < 0)
if (in_addr_cmp((uint8_t *)&(*np)->p.u.prefix4,
(uint8_t *)&np2->p.u.prefix4) < 0)
return;
if (prefix_cmp(&(*np)->p, &np2->p) > 0) {
if (in_addr_cmp((uint8_t *)&(*np)->p.u.prefix4,
(uint8_t *)&np2->p.u.prefix4) > 0) {
*np = np2;
*re = re2;
return;
Expand Down Expand Up @@ -296,14 +302,8 @@ static void get_fwtable_route_node(struct variable *v, oid objid[],
int i;

/* Init index variables */

pnt = (uint8_t *)&dest;
for (i = 0; i < 4; i++)
*pnt++ = 0;

pnt = (uint8_t *)&nexthop;
for (i = 0; i < 4; i++)
*pnt++ = 0;
memset(&dest, 0, sizeof(dest));
memset(&nexthop, 0, sizeof(nexthop));

proto = 0;
policy = 0;
Expand Down Expand Up @@ -494,23 +494,23 @@ static uint8_t *ipFwTable(struct variable *v, oid objid[], size_t *objid_len,
*val_len = sizeof(int);
return (uint8_t *)&result;
case IPFORWARDMETRIC1:
result = 0;
result = re->metric;
*val_len = sizeof(int);
return (uint8_t *)&result;
case IPFORWARDMETRIC2:
result = 0;
result = -1;
*val_len = sizeof(int);
return (uint8_t *)&result;
case IPFORWARDMETRIC3:
result = 0;
result = -1;
*val_len = sizeof(int);
return (uint8_t *)&result;
case IPFORWARDMETRIC4:
result = 0;
result = -1;
*val_len = sizeof(int);
return (uint8_t *)&result;
case IPFORWARDMETRIC5:
result = 0;
result = -1;
*val_len = sizeof(int);
return (uint8_t *)&result;
default:
Expand Down

0 comments on commit 42126fc

Please sign in to comment.