if (version < 2 || version > 3 || type != VRRP_TYPE_ADVERTISEMENT)
return;
ND_PRINT(", vrid %u, prio %u", GET_U_1(bp + 1), GET_U_1(bp + 2));
- ND_TCHECK_1(bp + 5);
if (version == 2) {
auth_type = GET_U_1(bp + 4);
c = ' ';
bp += 8;
for (i = 0; i < naddrs; i++) {
- ND_TCHECK_1(bp + 3);
ND_PRINT("%c%s", c, GET_IPADDR_STRING(bp));
c = ',';
bp += 4;
}
if (version == 2 && auth_type == VRRP_AUTH_SIMPLE) { /* simple text password */
- ND_TCHECK_1(bp + 7);
ND_PRINT(" auth \"");
- if (nd_printn(ndo, bp, 8, ndo->ndo_snapend)) {
- ND_PRINT("\"");
- goto trunc;
- }
+ /*
+ * RFC 2338 Section 5.3.10: "If the configured authentication string
+ * is shorter than 8 bytes, the remaining space MUST be zero-filled.
+ */
+ nd_printjnp(ndo, bp, 8);
ND_PRINT("\"");
}
}
- return;
-trunc:
- nd_print_trunc(ndo);
}