summaryrefslogtreecommitdiff
path: root/usr.sbin/mopd/mopprobe/mopprobe.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/mopd/mopprobe/mopprobe.c')
-rw-r--r--usr.sbin/mopd/mopprobe/mopprobe.c148
1 files changed, 94 insertions, 54 deletions
diff --git a/usr.sbin/mopd/mopprobe/mopprobe.c b/usr.sbin/mopd/mopprobe/mopprobe.c
index 258791726c5..ae3b6430705 100644
--- a/usr.sbin/mopd/mopprobe/mopprobe.c
+++ b/usr.sbin/mopd/mopprobe/mopprobe.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mopprobe.c,v 1.4 1998/03/19 07:39:44 deraadt Exp $ */
+/* $OpenBSD: mopprobe.c,v 1.5 1999/03/27 14:31:22 maja Exp $ */
/*
* Copyright (c) 1993-96 Mats O Jansson. All rights reserved.
@@ -30,14 +30,14 @@
*/
#ifndef LINT
-static char rcsid[] = "$OpenBSD: mopprobe.c,v 1.4 1998/03/19 07:39:44 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: mopprobe.c,v 1.5 1999/03/27 14:31:22 maja Exp $";
#endif
/*
* mopprobe - MOP Probe Utility
*
- * Usage: mopprobe -a [ -3 | -4 ]
- * mopprobe [ -3 | -4 ] interface
+ * Usage: mopprobe -a [ -3 | -4 ] [-v] [-o]
+ * mopprobe [ -3 | -4 ] [-v] [-o] interface
*/
#include "os.h"
@@ -66,13 +66,19 @@ void Usage __P((void));
void mopProcess __P((struct if_info *, u_char *));
#endif
+struct once {
+ u_char eaddr[6]; /* Ethernet addr */
+ struct once *next; /* Next one */
+};
+
int AllFlag = 0; /* listen on "all" interfaces */
-int DebugFlag = 0; /* print debugging messages */
int Not3Flag = 0; /* Not MOP V3 messages */
int Not4Flag = 0; /* Not MOP V4 messages */
-int oflag = 0; /* print only once */
+int VerboseFlag = 0; /* Print All Announces */
+int OnceFlag = 0; /* print only once */
int promisc = 1; /* Need promisc mode */
char *Program;
+struct once *root = NULL;
int
main(argc, argv)
@@ -95,7 +101,7 @@ main(argc, argv)
openlog(Program, LOG_PID | LOG_CONS, LOG_DAEMON);
opterr = 0;
- while ((op = getopt(argc, argv, "ado")) != -1) {
+ while ((op = getopt(argc, argv, "34aov")) != -1) {
switch (op) {
case '3':
Not3Flag++;
@@ -106,13 +112,12 @@ main(argc, argv)
case 'a':
AllFlag++;
break;
- case 'd':
- DebugFlag++;
- break;
case 'o':
- oflag++;
+ OnceFlag++;
+ break;
+ case 'v':
+ VerboseFlag++;
break;
-
default:
Usage();
/* NOTREACHED */
@@ -136,8 +141,8 @@ main(argc, argv)
void
Usage()
{
- (void) fprintf(stderr, "usage: %s -a [ -3 | -4 ]\n",Program);
- (void) fprintf(stderr, " %s [ -3 | -4 ] interface\n",Program);
+ (void) fprintf(stderr, "usage: %s -a [ -3 | -4 ] [-v] [-o]\n",Program);
+ (void) fprintf(stderr, " %s [ -3 | -4 ] [-v] [-o] interface\n",Program);
exit(1);
}
@@ -149,33 +154,27 @@ mopProcess(ii, pkt)
struct if_info *ii;
u_char *pkt;
{
- u_char *dst, *src, *p, mopcode, tmpc, ilen;
- u_short *ptype, moplen, tmps, itype, len;
- int index, i, device, trans;
-
- dst = pkt;
- src = pkt+6;
- ptype = (u_short *)(pkt+12);
- index = 0;
+ u_char *dst, *src, mopcode, tmpc, device, ilen;
+ u_short ptype, moplen = 0, tmps, itype;
+ int index, trans, len, i, hwa = 0;
+ struct once *o = NULL;
- if (*ptype < 1600) {
- len = *ptype;
- trans = TRANS_8023;
- ptype = (u_short *)(pkt+20);
- p = pkt+22;
- if (Not4Flag) return;
- } else {
- len = 0;
- trans = TRANS_ETHER;
- p = pkt+14;
- if (Not3Flag) return;
- }
-
- /* Ignore our own messages */
+ /* We don't known with transport, Guess! */
+
+ trans = mopGetTrans(pkt, 0);
- if (mopCmpEAddr(ii->eaddr,src) == 0) {
+ /* Ok, return if we don't wan't this message */
+
+ if ((trans == TRANS_ETHER) && Not3Flag) return;
+ if ((trans == TRANS_8023) && Not4Flag) return;
+
+ index = 0;
+ mopGetHeader(pkt, &index, &dst, &src, &ptype, &len, trans);
+
+ /* Ignore our own transmissions */
+
+ if (mopCmpEAddr(ii->eaddr,src) == 0)
return;
- }
/* Just check multicast */
@@ -183,14 +182,33 @@ mopProcess(ii, pkt)
return;
}
- switch (trans) {
- case TRANS_8023:
- moplen = len;
+ switch(ptype) {
+ case MOP_K_PROTO_RC:
break;
default:
- moplen = mopGetShort(pkt,&index);
+ return;
+ }
+
+ if (OnceFlag) {
+ o = root;
+ while (o != NULL) {
+ if (mopCmpEAddr(o->eaddr,src) == 0)
+ return;
+ o = o->next;
+ }
+ o = (struct once *)malloc(sizeof(*o));
+ o->eaddr[0] = src[0];
+ o->eaddr[1] = src[1];
+ o->eaddr[2] = src[2];
+ o->eaddr[3] = src[3];
+ o->eaddr[4] = src[4];
+ o->eaddr[5] = src[5];
+ o->next = root;
+ root = o;
}
- mopcode = mopGetChar(p,&index);
+
+ moplen = mopGetLength(pkt, trans);
+ mopcode = mopGetChar(pkt,&index);
/* Just process System Information */
@@ -198,21 +216,30 @@ mopProcess(ii, pkt)
return;
}
- tmpc = mopGetChar(pkt,&index); /* Reserved */
- tmps = mopGetShort(pkt,&index); /* Receipt # */
+ tmpc = mopGetChar(pkt,&index); /* Reserved */
+ tmps = mopGetShort(pkt,&index); /* Receipt # */
+
+ device = 0;
- device = 0; /* Unknown Device */
-
- itype = mopGetShort(pkt,&index);
+ switch(trans) {
+ case TRANS_ETHER:
+ moplen = moplen + 16;
+ break;
+ case TRANS_8023:
+ moplen = moplen + 14;
+ break;
+ }
- while (index < (int)(moplen + 2)) {
- ilen = mopGetChar(pkt,&index);
+ itype = mopGetShort(pkt,&index);
+
+ while (index < (int)(moplen)) {
+ ilen = mopGetChar(pkt,&index);
switch (itype) {
case 0:
tmpc = mopGetChar(pkt,&index);
index = index + tmpc;
break;
- case MOP_K_INFO_VER:
+ case MOP_K_INFO_VER:
index = index + 3;
break;
case MOP_K_INFO_MFCT:
@@ -231,6 +258,7 @@ mopProcess(ii, pkt)
index = index + 2;
break;
case MOP_K_INFO_HWA:
+ hwa = index;
index = index + 6;
break;
case MOP_K_INFO_TIME:
@@ -238,6 +266,19 @@ mopProcess(ii, pkt)
break;
case MOP_K_INFO_SOFD:
device = mopGetChar(pkt,&index);
+ if (VerboseFlag &&
+ (device != NMA_C_SOFD_LCS) && /* DECserver 100 */
+ (device != NMA_C_SOFD_DS2) && /* DECserver 200 */
+ (device != NMA_C_SOFD_DP2) && /* DECserver 250 */
+ (device != NMA_C_SOFD_DS3)) /* DECserver 300 */
+ {
+ mopPrintHWA(stdout, src);
+ (void)fprintf(stdout," # ");
+ mopPrintDevice(stdout, device);
+ (void)fprintf(stdout," ");
+ mopPrintHWA(stdout, &pkt[hwa]);
+ (void)fprintf(stdout,"\n");
+ }
break;
case MOP_K_INFO_SFID:
tmpc = mopGetChar(pkt,&index);
@@ -271,8 +312,8 @@ mopProcess(ii, pkt)
index = index + 2;
break;
case 105:
- (void)fprintf(stdout,"%x:%x:%x:%x:%x:%x\t",
- src[0],src[1],src[2],src[3],src[4],src[5]);
+ mopPrintHWA(stdout, src);
+ (void)fprintf(stdout," ");
for (i = 0; i < ilen; i++) {
(void)fprintf(stdout, "%c",pkt[index+i]);
}
@@ -289,6 +330,5 @@ mopProcess(ii, pkt)
}
itype = mopGetShort(pkt,&index);
}
-
}