summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/rarpd/pathnames.h31
-rw-r--r--usr.sbin/rarpd/rarpd.88
-rw-r--r--usr.sbin/rarpd/rarpd.c51
3 files changed, 76 insertions, 14 deletions
diff --git a/usr.sbin/rarpd/pathnames.h b/usr.sbin/rarpd/pathnames.h
new file mode 100644
index 00000000000..1f3e93a3c3c
--- /dev/null
+++ b/usr.sbin/rarpd/pathnames.h
@@ -0,0 +1,31 @@
+/* $NetBSD: pathnames.h,v 1.1 1998/04/23 02:48:33 mrg Exp $ */
+
+/*
+ * Copyright (c) 1998 Matthew R. Green
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. The name of the author may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+ #define _PATH_RARPDPID "/var/run/rarpd.pid"
diff --git a/usr.sbin/rarpd/rarpd.8 b/usr.sbin/rarpd/rarpd.8
index 37f2e39a437..e79b76bcb7e 100644
--- a/usr.sbin/rarpd/rarpd.8
+++ b/usr.sbin/rarpd/rarpd.8
@@ -1,4 +1,4 @@
-.\"
+.\" $NetBSD: rarpd.8,v 1.7 1998/04/15 15:06:06 mrg Exp $
.\" Copyright (c) 1988-1990 The Regents of the University of California.
.\" All rights reserved.
.\"
@@ -17,7 +17,7 @@
.\" THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
.\" WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
.\" MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
-.\" @(#) $Id: rarpd.8,v 1.2 1996/12/10 18:24:54 deraadt Exp $
+.\" @(#) $Id: rarpd.8,v 1.3 1998/04/25 06:29:52 deraadt Exp $
.\"
.Dd October 26, 1990
.Dt RARPD 8
@@ -26,7 +26,7 @@
.Nd Reverse ARP Daemon
.Sh SYNOPSIS
.Nm rarpd
-.Op Fl adf
+.Op Fl adfl
.Op Ar interface
.Sh DESCRIPTION
.Nm Rarpd
@@ -70,6 +70,8 @@ This option implies the
option.
.It Fl f
Run in the foreground.
+.It Fl l
+Log all requests to syslog.
.El
.Sh FILES
.Bl -tag -width Pa -compact
diff --git a/usr.sbin/rarpd/rarpd.c b/usr.sbin/rarpd/rarpd.c
index 7d0c71762c7..10762b31a08 100644
--- a/usr.sbin/rarpd/rarpd.c
+++ b/usr.sbin/rarpd/rarpd.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: rarpd.c,v 1.17 1998/03/23 04:18:41 deraadt Exp $ */
-/* $NetBSD: rarpd.c,v 1.12 1996/03/21 18:28:23 jtc Exp $ */
+/* $OpenBSD: rarpd.c,v 1.18 1998/04/25 06:29:53 deraadt Exp $ */
+/* $NetBSD: rarpd.c,v 1.25 1998/04/23 02:48:33 mrg Exp $ */
/*
* Copyright (c) 1990 The Regents of the University of California.
@@ -28,15 +28,15 @@ char copyright[] =
#endif /* not lint */
#ifndef lint
-static char rcsid[] = "$OpenBSD: rarpd.c,v 1.17 1998/03/23 04:18:41 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: rarpd.c,v 1.18 1998/04/25 06:29:53 deraadt Exp $";
#endif
/*
* rarpd - Reverse ARP Daemon
*
- * Usage: rarpd -a [ -d -f ]
- * rarpd [ -d -f ] interface
+ * Usage: rarpd -a [ -d ] [ -f ] [ -l ]
+ * rarpd [ -d ] [ -f ] [ -l ] interface
*/
#include <stdio.h>
@@ -60,6 +60,8 @@ static char rcsid[] = "$OpenBSD: rarpd.c,v 1.17 1998/03/23 04:18:41 deraadt Exp
#include <arpa/inet.h>
#include <dirent.h>
+#include "pathnames.h"
+
#define FATAL 1 /* fatal error occurred */
#define NONFATAL 0 /* non fatal error occurred */
@@ -88,7 +90,8 @@ void lookup_eaddr __P((char *, u_char *));
void lookup_ipaddr __P((char *, u_int32_t *, u_int32_t *));
void usage __P((void));
void rarp_process __P((struct if_info *, u_char *));
-void rarp_reply __P((struct if_info *, struct ether_header *, u_int32_t));
+void rarp_reply __P((struct if_info *, struct ether_header *, u_int32_t,
+ struct hostent *));
void update_arptab __P((u_char *, u_int32_t));
void err __P((int, const char *,...));
void debug __P((const char *,...));
@@ -101,6 +104,7 @@ int rarp_bootable __P((u_int32_t));
int aflag = 0; /* listen on "all" interfaces */
int dflag = 0; /* print debugging messages */
int fflag = 0; /* don't fork */
+int lflag = 0; /* log all replies */
int
main(argc, argv)
@@ -117,7 +121,7 @@ main(argc, argv)
openlog(__progname, LOG_PID | LOG_CONS, LOG_DAEMON);
opterr = 0;
- while ((op = getopt(argc, argv, "adf")) != -1) {
+ while ((op = getopt(argc, argv, "adfl")) != -1) {
switch (op) {
case 'a':
++aflag;
@@ -131,6 +135,10 @@ main(argc, argv)
++fflag;
break;
+ case 'l':
+ ++lflag;
+ break;
+
default:
usage();
/* NOTREACHED */
@@ -147,6 +155,8 @@ main(argc, argv)
init_one(ifname);
if ((!fflag) && (!dflag)) {
+ FILE *fp;
+
pid = fork();
if (pid > 0)
/* Parent exits, leaving child in background. */
@@ -156,6 +166,13 @@ main(argc, argv)
err(FATAL, "cannot fork");
/* NOTREACHED */
}
+
+ /* write pid file */
+ if ((fp = fopen(_PATH_RARPDPID, "w")) != NULL) {
+ fprintf(fp, "%u\n", getpid());
+ (void)fclose(fp);
+ }
+
/* Fade into the background */
f = open("/dev/tty", O_RDWR);
if (f >= 0) {
@@ -459,7 +476,7 @@ rarp_loop()
fd = ii->ii_fd;
if (!FD_ISSET(fd, lfdsp))
continue;
- again:
+ again:
cc = read(fd, (char *) buf, bufsize);
/* Don't choke when we get ptraced */
if (cc < 0 && errno == EINTR)
@@ -593,7 +610,7 @@ rarp_process(ii, pkt)
#ifdef REQUIRE_TFTPBOOT
if (rarp_bootable(htonl(target_ipaddr)))
#endif
- rarp_reply(ii, ep, target_ipaddr);
+ rarp_reply(ii, ep, target_ipaddr, hp);
}
/*
* Lookup the ethernet address of the interface attached to the BPF
@@ -686,6 +703,7 @@ lookup_ipaddr(ifname, addrp, netmaskp)
*addrp = ((struct sockaddr_in *) & ifr.ifr_addr)->sin_addr.s_addr;
if (ioctl(fd, SIOCGIFNETMASK, (char *) &ifr) < 0) {
perror("SIOCGIFNETMASK");
+ unlink(_PATH_RARPDPID);
exit(1);
}
*netmaskp = ((struct sockaddr_in *) & ifr.ifr_addr)->sin_addr.s_addr;
@@ -773,10 +791,11 @@ update_arptab(ep, ipaddr)
* ARP request.
*/
void
-rarp_reply(ii, ep, ipaddr)
+rarp_reply(ii, ep, ipaddr, hp)
struct if_info *ii;
struct ether_header *ep;
u_int32_t ipaddr;
+ struct hostent *hp;
{
int n;
struct ether_arp *ap = (struct ether_arp *) (ep + 1);
@@ -798,6 +817,14 @@ rarp_reply(ii, ep, ipaddr)
/* Target hardware is unchanged. */
memcpy((char *) ap->arp_spa, (char *) &ii->ii_ipaddr, 4);
+ if (lflag) {
+ struct ether_addr ea;
+
+ memcpy(&ea.ether_addr_octet, &ap->arp_sha, 6);
+ syslog(LOG_INFO, "%s asked; %s replied", hp->h_name,
+ ether_ntoa(&ea));
+ }
+
len = sizeof(*ep) + sizeof(*ap);
n = write(ii->ii_fd, (char *) ep, len);
if (n != len) {
@@ -854,8 +881,10 @@ va_dcl
}
vsyslog(LOG_ERR, fmt, ap);
va_end(ap);
- if (fatal)
+ if (fatal) {
+ unlink(_PATH_RARPDPID);
exit(1);
+ }
/* NOTREACHED */
}