aboutsummaryrefslogtreecommitdiff
path: root/contrib/tcpdump/print-telnet.c
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/tcpdump/print-telnet.c')
-rw-r--r--contrib/tcpdump/print-telnet.c81
1 files changed, 32 insertions, 49 deletions
diff --git a/contrib/tcpdump/print-telnet.c b/contrib/tcpdump/print-telnet.c
index 10fad9fef7f6..ea7464f0dc4d 100644
--- a/contrib/tcpdump/print-telnet.c
+++ b/contrib/tcpdump/print-telnet.c
@@ -1,4 +1,4 @@
-/* $NetBSD: print-telnet.c,v 1.2 1999/10/11 12:40:12 sjg Exp $ */
+/* $NetBSD: print-telnet.c,v 1.2 1999/10/11 12:40:12 sjg Exp $ */
/*-
* Copyright (c) 1997, 1998 The NetBSD Foundation, Inc.
@@ -48,21 +48,18 @@
/* \summary: Telnet option printer */
#ifdef HAVE_CONFIG_H
-#include "config.h"
+#include <config.h>
#endif
-#include <netdissect-stdinc.h>
+#include "netdissect-stdinc.h"
#include <stdio.h>
#include "netdissect.h"
+#include "extract.h"
-static const char tstr[] = " [|telnet]";
-#define TELCMDS
-#define TELOPTS
-
-/* NetBSD: telnet.h,v 1.9 2001/06/11 01:50:50 wiz Exp */
+/* NetBSD: telnet.h,v 1.9 2001/06/11 01:50:50 wiz Exp */
/*
* Definitions for the TELNET protocol.
@@ -90,15 +87,11 @@ static const char tstr[] = " [|telnet]";
#define SYNCH 242 /* for telfunc calls */
-#ifdef TELCMDS
static const char *telcmds[] = {
"EOF", "SUSP", "ABORT", "EOR",
"SE", "NOP", "DMARK", "BRK", "IP", "AO", "AYT", "EC",
"EL", "GA", "SB", "WILL", "WONT", "DO", "DONT", "IAC", 0,
};
-#else
-extern char *telcmds[];
-#endif
#define TELCMD_FIRST xEOF
#define TELCMD_LAST IAC
@@ -115,8 +108,8 @@ extern char *telcmds[];
#define TELOPT_STATUS 5 /* give status */
#define TELOPT_TM 6 /* timing mark */
#define TELOPT_RCTE 7 /* remote controlled transmission and echo */
-#define TELOPT_NAOL 8 /* negotiate about output line width */
-#define TELOPT_NAOP 9 /* negotiate about output page size */
+#define TELOPT_NAOL 8 /* negotiate about output line width */
+#define TELOPT_NAOP 9 /* negotiate about output page size */
#define TELOPT_NAOCRD 10 /* negotiate about CR disposition */
#define TELOPT_NAOHTS 11 /* negotiate about horizontal tabstops */
#define TELOPT_NAOHTD 12 /* negotiate about horizontal tab disposition */
@@ -151,7 +144,6 @@ extern char *telcmds[];
#define NTELOPTS (1+TELOPT_NEW_ENVIRON)
-#ifdef TELOPTS
static const char *telopts[NTELOPTS+1] = {
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD", "NAME",
"STATUS", "TIMING MARK", "RCTE", "NAOL", "NAOP",
@@ -169,7 +161,6 @@ static const char *telopts[NTELOPTS+1] = {
#define TELOPT_LAST TELOPT_NEW_ENVIRON
#define TELOPT_OK(x) ((unsigned int)(x) <= TELOPT_LAST)
#define TELOPT(x) telopts[(x)-TELOPT_FIRST]
-#endif
/* sub-option qualifiers */
#define TELQUAL_IS 0 /* option is... */
@@ -396,8 +387,8 @@ telnet_parse(netdissect_options *ndo, const u_char *sp, u_int length, int print)
do { \
if (length < 1) \
goto pktend; \
- ND_TCHECK(*sp); \
- c = *sp++; \
+ c = GET_U_1(sp); \
+ sp++; \
length--; \
} while (0)
@@ -409,7 +400,7 @@ telnet_parse(netdissect_options *ndo, const u_char *sp, u_int length, int print)
FETCH(c, sp, length);
if (c == IAC) { /* <IAC><IAC>! */
if (print)
- ND_PRINT((ndo, "IAC IAC"));
+ ND_PRINT("IAC IAC");
goto done;
}
@@ -427,23 +418,21 @@ telnet_parse(netdissect_options *ndo, const u_char *sp, u_int length, int print)
FETCH(x, sp, length);
if (x >= 0 && x < NTELOPTS) {
if (print)
- ND_PRINT((ndo, "%s %s", telcmds[i], telopts[x]));
+ ND_PRINT("%s %s", telcmds[i], telopts[x]);
} else {
if (print)
- ND_PRINT((ndo, "%s %#x", telcmds[i], x));
+ ND_PRINT("%s %#x", telcmds[i], x);
}
if (c != SB)
break;
/* IAC SB .... IAC SE */
p = sp;
while (length > (u_int)(p + 1 - sp)) {
- ND_TCHECK2(*p, 2);
- if (p[0] == IAC && p[1] == SE)
+ if (GET_U_1(p) == IAC && GET_U_1(p + 1) == SE)
break;
p++;
}
- ND_TCHECK(*p);
- if (*p != IAC)
+ if (GET_U_1(p) != IAC)
goto pktend;
switch (x) {
@@ -452,54 +441,52 @@ telnet_parse(netdissect_options *ndo, const u_char *sp, u_int length, int print)
break;
FETCH(c, sp, length);
if (print)
- ND_PRINT((ndo, " %s", STR_OR_ID(c, authcmd)));
+ ND_PRINT(" %s", STR_OR_ID(c, authcmd));
if (p <= sp)
break;
FETCH(c, sp, length);
if (print)
- ND_PRINT((ndo, " %s", STR_OR_ID(c, authtype)));
+ ND_PRINT(" %s", STR_OR_ID(c, authtype));
break;
case TELOPT_ENCRYPT:
if (p <= sp)
break;
FETCH(c, sp, length);
if (print)
- ND_PRINT((ndo, " %s", STR_OR_ID(c, enccmd)));
+ ND_PRINT(" %s", STR_OR_ID(c, enccmd));
if (p <= sp)
break;
FETCH(c, sp, length);
if (print)
- ND_PRINT((ndo, " %s", STR_OR_ID(c, enctype)));
+ ND_PRINT(" %s", STR_OR_ID(c, enctype));
break;
default:
if (p <= sp)
break;
FETCH(c, sp, length);
if (print)
- ND_PRINT((ndo, " %s", STR_OR_ID(c, cmds)));
+ ND_PRINT(" %s", STR_OR_ID(c, cmds));
break;
}
while (p > sp) {
FETCH(x, sp, length);
if (print)
- ND_PRINT((ndo, " %#x", x));
+ ND_PRINT(" %#x", x);
}
/* terminating IAC SE */
if (print)
- ND_PRINT((ndo, " SE"));
+ ND_PRINT(" SE");
sp += 2;
break;
default:
if (print)
- ND_PRINT((ndo, "%s", telcmds[i]));
+ ND_PRINT("%s", telcmds[i]);
goto done;
}
done:
- return sp - osp;
+ return (int)(sp - osp);
-trunc:
- ND_PRINT((ndo, "%s", tstr));
pktend:
return -1;
#undef FETCH
@@ -512,10 +499,10 @@ telnet_print(netdissect_options *ndo, const u_char *sp, u_int length)
const u_char *osp;
int l;
+ ndo->ndo_protocol = "telnet";
osp = sp;
- ND_TCHECK(*sp);
- while (length > 0 && *sp == IAC) {
+ while (length > 0 && GET_U_1(sp) == IAC) {
/*
* Parse the Telnet command without printing it,
* to determine its length.
@@ -529,29 +516,25 @@ telnet_print(netdissect_options *ndo, const u_char *sp, u_int length)
*/
if (ndo->ndo_Xflag && 2 < ndo->ndo_vflag) {
if (first)
- ND_PRINT((ndo, "\nTelnet:"));
- hex_print_with_offset(ndo, "\n", sp, l, sp - osp);
+ ND_PRINT("\nTelnet:");
+ hex_print_with_offset(ndo, "\n", sp, l, (u_int)(sp - osp));
if (l > 8)
- ND_PRINT((ndo, "\n\t\t\t\t"));
+ ND_PRINT("\n\t\t\t\t");
else
- ND_PRINT((ndo, "%*s\t", (8 - l) * 3, ""));
+ ND_PRINT("%*s\t", (8 - l) * 3, "");
} else
- ND_PRINT((ndo, "%s", (first) ? " [telnet " : ", "));
+ ND_PRINT("%s", (first) ? " [telnet " : ", ");
(void)telnet_parse(ndo, sp, length, 1);
first = 0;
sp += l;
length -= l;
- ND_TCHECK(*sp);
}
if (!first) {
if (ndo->ndo_Xflag && 2 < ndo->ndo_vflag)
- ND_PRINT((ndo, "\n"));
+ ND_PRINT("\n");
else
- ND_PRINT((ndo, "]"));
+ ND_PRINT("]");
}
- return;
-trunc:
- ND_PRINT((ndo, "%s", tstr));
}