summaryrefslogtreecommitdiff
path: root/print-hsrp.c
diff options
context:
space:
mode:
authorDenis Ovsienko <infrastation@yandex.ru>2014-03-04 13:55:24 +0400
committerDenis Ovsienko <infrastation@yandex.ru>2014-03-04 14:18:55 +0400
commit121340f51409c65277b29b89d3ddbc8f1083d051 (patch)
tree7354b019a83bb09ea4601a83c613707c11105de2 /print-hsrp.c
parentb011ece874d3cb6bf4da8837404fff67fe5217ab (diff)
downloadtcpdump-121340f51409c65277b29b89d3ddbc8f1083d051.tar.gz
NDOize HSRP, IGRP and UDLD decoders
Diffstat (limited to 'print-hsrp.c')
-rw-r--r--print-hsrp.c46
1 files changed, 22 insertions, 24 deletions
diff --git a/print-hsrp.c b/print-hsrp.c
index fbcf5834..0059284f 100644
--- a/print-hsrp.c
+++ b/print-hsrp.c
@@ -35,8 +35,6 @@
#include <tcpdump-stdinc.h>
-#include <stdio.h>
-
#include "interface.h"
#include "addrtoname.h"
@@ -93,43 +91,43 @@ struct hsrp {
};
void
-hsrp_print(register const u_int8_t *bp, register u_int len)
+hsrp_print(netdissect_options *ndo, register const u_int8_t *bp, register u_int len)
{
struct hsrp *hp = (struct hsrp *) bp;
- TCHECK(hp->hsrp_version);
- printf("HSRPv%d", hp->hsrp_version);
+ ND_TCHECK(hp->hsrp_version);
+ ND_PRINT((ndo, "HSRPv%d", hp->hsrp_version));
if (hp->hsrp_version != 0)
return;
- TCHECK(hp->hsrp_op_code);
- printf("-");
- printf("%s ", tok2strary(op_code_str, "unknown (%d)", hp->hsrp_op_code));
- printf("%d: ", len);
- TCHECK(hp->hsrp_state);
- printf("state=%s ", tok2str(states, "Unknown (%d)", hp->hsrp_state));
- TCHECK(hp->hsrp_group);
- printf("group=%d ", hp->hsrp_group);
- TCHECK(hp->hsrp_reserved);
+ ND_TCHECK(hp->hsrp_op_code);
+ ND_PRINT((ndo, "-"));
+ ND_PRINT((ndo, "%s ", tok2strary(op_code_str, "unknown (%d)", hp->hsrp_op_code)));
+ ND_PRINT((ndo, "%d: ", len));
+ ND_TCHECK(hp->hsrp_state);
+ ND_PRINT((ndo, "state=%s ", tok2str(states, "Unknown (%d)", hp->hsrp_state)));
+ ND_TCHECK(hp->hsrp_group);
+ ND_PRINT((ndo, "group=%d ", hp->hsrp_group));
+ ND_TCHECK(hp->hsrp_reserved);
if (hp->hsrp_reserved != 0) {
- printf("[reserved=%d!] ", hp->hsrp_reserved);
+ ND_PRINT((ndo, "[reserved=%d!] ", hp->hsrp_reserved));
}
- TCHECK(hp->hsrp_virtaddr);
- printf("addr=%s", ipaddr_string(&hp->hsrp_virtaddr));
+ ND_TCHECK(hp->hsrp_virtaddr);
+ ND_PRINT((ndo, "addr=%s", ipaddr_string(&hp->hsrp_virtaddr)));
if (vflag) {
- printf(" hellotime=");
+ ND_PRINT((ndo, " hellotime="));
relts_print(hp->hsrp_hellotime);
- printf(" holdtime=");
+ ND_PRINT((ndo, " holdtime="));
relts_print(hp->hsrp_holdtime);
- printf(" priority=%d", hp->hsrp_priority);
- printf(" auth=\"");
+ ND_PRINT((ndo, " priority=%d", hp->hsrp_priority));
+ ND_PRINT((ndo, " auth=\""));
if (fn_printn(hp->hsrp_authdata, sizeof(hp->hsrp_authdata),
snapend)) {
- printf("\"");
+ ND_PRINT((ndo, "\""));
goto trunc;
}
- printf("\"");
+ ND_PRINT((ndo, "\""));
}
return;
trunc:
- printf("[|hsrp]");
+ ND_PRINT((ndo, "[|hsrp]"));
}