-
- if (snapend < dat) {
- printf(" [|aodv]");
- return;
- }
- i = min(length, (u_int)(snapend - dat));
- if (i < sizeof(ap->rreq6_draft_01)) {
- printf(" [|rreq6]");
- return;
- }
- i -= sizeof(ap->rreq6_draft_01);
- printf(" rreq %u %s%s%s%s%shops %u id 0x%08lx\n"
- "\tdst %s seq %lu src %s seq %lu", length,
- ap->rreq6_draft_01.rreq_type & RREQ_JOIN ? "[J]" : "",
- ap->rreq6_draft_01.rreq_type & RREQ_REPAIR ? "[R]" : "",
- ap->rreq6_draft_01.rreq_type & RREQ_GRAT ? "[G]" : "",
- ap->rreq6_draft_01.rreq_type & RREQ_DEST ? "[D]" : "",
- ap->rreq6_draft_01.rreq_type & RREQ_UNKNOWN ? "[U] " : " ",
- ap->rreq6_draft_01.rreq_hops,
- (unsigned long)EXTRACT_32BITS(&ap->rreq6_draft_01.rreq_id),
- ip6addr_string(&ap->rreq6_draft_01.rreq_da),
- (unsigned long)EXTRACT_32BITS(&ap->rreq6_draft_01.rreq_ds),
- ip6addr_string(&ap->rreq6_draft_01.rreq_oa),
- (unsigned long)EXTRACT_32BITS(&ap->rreq6_draft_01.rreq_os));
+ const struct aodv_rreq6_draft_01 *ap = (const struct aodv_rreq6_draft_01 *)dat;
+
+ ND_TCHECK(*ap);
+ if (length < sizeof(*ap))
+ goto trunc;
+ ND_PRINT((ndo, " rreq %u %s%s%s%s%shops %u id 0x%08x\n"
+ "\tdst %s seq %u src %s seq %u", length,
+ EXTRACT_U_1(ap->rreq_type) & RREQ_JOIN ? "[J]" : "",
+ EXTRACT_U_1(ap->rreq_type) & RREQ_REPAIR ? "[R]" : "",
+ EXTRACT_U_1(ap->rreq_type) & RREQ_GRAT ? "[G]" : "",
+ EXTRACT_U_1(ap->rreq_type) & RREQ_DEST ? "[D]" : "",
+ EXTRACT_U_1(ap->rreq_type) & RREQ_UNKNOWN ? "[U] " : " ",
+ EXTRACT_U_1(ap->rreq_hops),
+ EXTRACT_BE_U_4(ap->rreq_id),
+ ip6addr_string(ndo, &ap->rreq_da),
+ EXTRACT_BE_U_4(ap->rreq_ds),
+ ip6addr_string(ndo, &ap->rreq_oa),
+ EXTRACT_BE_U_4(ap->rreq_os)));
+ i = length - sizeof(*ap);