summaryrefslogtreecommitdiff
path: root/usr.sbin/rarpd/rarpd.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/rarpd/rarpd.c')
-rw-r--r--usr.sbin/rarpd/rarpd.c51
1 files changed, 40 insertions, 11 deletions
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 */
}