Source cleanup: prototypes, varargs, POSIXification, getopts, -Wall clean.

Bugfixes: no longer stomps it's argv causing ps to change the string.

Unfortunately, Bill Fenner and I have overlapping changes here...
This commit is contained in:
peter 1996-01-19 10:22:00 +00:00
parent 751bd9fd9c
commit 694a4ce271

View File

@ -48,6 +48,16 @@
#include <string.h>
#include <syslog.h>
#include <stdlib.h>
#include <unistd.h>
#include <err.h>
#include <sys/cdefs.h>
#if __STDC__
#include <stdarg.h>
#else
#include <varargs.h>
#endif
/*
* TBD
@ -55,30 +65,12 @@
* address.
*/
char *malloc();
void exit();
long gethostid();
long random();
time_t time();
long strtol();
#ifdef lint
#define ALLIGN(ptr) (ptr ? 0 : 0)
#else
#define ALLIGN(ptr) (ptr)
#endif
#ifdef SYSV
#define signal(s,f) sigset(s,f)
#define random() rand()
#endif
void solicitor(), advertise(), pr_pack(), init();
void bzero(), initlog(), logerr(), logtrace(), logdebug(), logperror();
void age_table(), record_router(), add_route(), del_route(), rtioctl();
int support_multicast(), sendbcast(), sendmcast(), sendbcastif(), sendmcastif();
int ismulticast(), isbroadcast(), in_cksum(), is_directly_connected();
static int join();
#define ICMP_ROUTER_ADVERTISEMENT 9
#define ICMP_ROUTER_SOLICITATION 10
@ -120,8 +112,6 @@ int interfaces_size; /* Number of elements in interfaces */
#define MAXPACKET 4096 /* max packet size */
u_char packet[MAXPACKET];
/* fraser */
int debugfile;
char usage[] =
"Usage: rdisc [-s] [-v] [-f] [-a] [send_address] [receive_address]\n\
rdisc -r [-v] [-p <preference>] [-T <secs>] \n\
@ -158,11 +148,45 @@ int best_preference = 1; /* Set to record only the router(s) with the
best preference in the kernel. Not set
puts all routes in the kernel. */
/* Prototypes */
void do_fork __P((void));
int main __P((int, char **));
void timer __P((int));
void solicitor __P((struct sockaddr_in *));
void advertise __P((struct sockaddr_in *));
char * pr_type __P((int));
char * pr_name __P((struct in_addr));
void pr_pack __P((char *, int, struct sockaddr_in *));
int in_cksum __P((u_short *, int));
void finish __P((int));
int isbroadcast __P((struct sockaddr_in *));
int ismulticast __P((struct sockaddr_in *));
int sendbcast __P((int, char *, int));
int sendbcastif __P((int, char *, int, struct interface *));
int sendmcast __P((int, char *, int, struct sockaddr_in *));
int sendmcastif __P((int, char *, int, struct sockaddr_in *, struct interface *));
void init __P((void));
void initifs __P((int));
int support_multicast __P((void));
int is_directly_connected __P((struct in_addr));
struct table * find_router __P((struct in_addr));
int max_preference __P((void));
void age_table __P((int));
void record_router __P((struct in_addr, long, int));
void add_route __P((struct in_addr));
void del_route __P((struct in_addr));
void rtioctl __P((struct in_addr, int));
void initlog __P((void));
void logerr __P((char *fmt, ...));
void logtrace __P((char *fmt, ...));
void logdebug __P((char *fmt, ...));
void logperror __P((char *str));
void prusage __P((void));
int join __P((int sock, struct sockaddr_in *sin));
void finish(), catcher(), timer(), initifs();
char *pr_name();
static void prusage()
void
prusage()
{
(void) fprintf(stderr, usage);
exit(1);
@ -177,22 +201,15 @@ do_fork()
if (trace)
return;
if (pid =fork())
if ((pid = fork()))
exit(0);
for (t = 0; t < 20; t++)
if (t != s)
(void) close(t);
#ifndef SYSV
t = open("/dev/tty", 2);
if (t >= 0) {
(void) ioctl(t, TIOCNOTTY, (char *)0);
(void) close(t);
}
#else
(void) setpgrp ();
#endif
(void) setsid ();
initlog();
}
@ -201,24 +218,23 @@ do_fork()
*/
char *sendaddress, *recvaddress;
int
main(argc, argv)
char *argv[];
int argc;
char *argv[];
{
#ifndef SYSV
struct sigvec sv;
#endif
struct sigaction sa;
struct sockaddr_in from;
char **av = argv;
struct sockaddr_in *to = &whereto;
struct sockaddr_in joinaddr;
int val;
int c;
min_adv_int =( max_adv_int * 3 / 4);
lifetime = (3*max_adv_int);
argc--, av++;
while (argc > 0 && *av[0] == '-') {
while (*++av[0]) switch (*av[0]) {
while ((c = getopt(argc, argv, "dtvsrabfT:p:")) != EOF) {
switch(c) {
case 'd':
debug = 1;
break;
@ -244,39 +260,28 @@ char *argv[];
forever = 1;
break;
case 'T':
argc--, av++;
if (argc != 0) {
val = strtol(av[0], (char **)NULL, 0);
if (val < 4 || val > 1800) {
(void) fprintf(stderr,
"Bad Max Advertizement Interval\n");
exit(1);
}
max_adv_int = val;
min_adv_int =( max_adv_int * 3 / 4);
lifetime = (3*max_adv_int);
} else {
prusage();
/* NOTREACHED*/
val = strtol(optarg, (char **)NULL, 0);
if (val < 4 || val > 1800) {
(void) fprintf(stderr,
"Bad Max Advertizement Interval\n");
exit(1);
}
goto next;
max_adv_int = val;
min_adv_int =( max_adv_int * 3 / 4);
lifetime = (3*max_adv_int);
break;
case 'p':
argc--, av++;
if (argc != 0) {
val = strtol(av[0], (char **)NULL, 0);
preference = val;
} else {
prusage();
/* NOTREACHED*/
}
goto next;
val = strtol(optarg, (char **)NULL, 0);
preference = val;
break;
default:
prusage();
/* NOTREACHED*/
}
next:
argc--, av++;
}
argc -= optind;
argv += optind;
if( argc < 1) {
if (support_multicast()) {
if (responder)
@ -286,8 +291,8 @@ char *argv[];
} else
sendaddress = "255.255.255.255";
} else {
sendaddress = av[0];
argc--;
sendaddress = argv[0];
argc--; argv++;
}
if (argc < 1) {
@ -299,8 +304,8 @@ char *argv[];
} else
recvaddress = "255.255.255.255";
} else {
recvaddress = av[0];
argc--;
recvaddress = argv[0];
argc--; argv++;
}
if (argc != 0) {
(void) fprintf(stderr, "Extra paramaters\n");
@ -331,12 +336,8 @@ char *argv[];
joinaddr.sin_addr.s_addr = inet_addr(recvaddress);
if (responder) {
#ifdef SYSV
/* TBD fix this to be more random */
srand((u_int)time((time_t *)NULL));
#else
srandom((int)gethostid());
#endif
srandom((int)gethostid()+(int)time((time_t *)NULL));
}
if ((s = socket(AF_INET, SOCK_RAW, IPPROTO_ICMP)) < 0) {
@ -344,11 +345,7 @@ char *argv[];
exit(5);
}
#ifdef SYSV
setvbuf( stdout, NULL, _IOLBF, 0 );
#else
setlinebuf( stdout );
#endif
(void) signal( SIGINT, finish );
(void) signal( SIGTERM, finish );
@ -361,19 +358,16 @@ char *argv[];
}
#ifdef SYSV
(void) sigset(SIGALRM, timer);
#else
/*
* Make sure that this signal actually interrupts (rather than
* restarts) the recvfrom call below.
*/
sv.sv_handler = timer;
sv.sv_mask = 0;
sv.sv_flags = SV_INTERRUPT;
(void) sigvec(SIGALRM, &sv, (struct sigvec *)NULL);
#endif
timer(); /* start things going */
memset(&sa, 0, sizeof(sa));
sa.sa_handler = timer;
sigemptyset(&sa.sa_mask);
sa.sa_flags = 0; /* note: no SA_RESTART */
(void) sigaction(SIGALRM, &sa, (struct sigaction *)NULL);
timer(0); /* start things going */
for (;;) {
int len = sizeof (packet);
@ -395,24 +389,21 @@ char *argv[];
#define TIMER_INTERVAL 3
#define GETIFCONF_TIMER 30
static left_until_advertise;
int left_until_advertise;
/* Called every TIMER_INTERVAL */
void timer()
void timer(sig)
int sig;
{
static time;
static left_until_getifconf;
static left_until_solicit;
time += TIMER_INTERVAL;
static int left_until_getifconf;
static int left_until_solicit;
left_until_getifconf -= TIMER_INTERVAL;
left_until_advertise -= TIMER_INTERVAL;
left_until_solicit -= TIMER_INTERVAL;
if (left_until_getifconf < 0) {
initifs();
initifs(0);
left_until_getifconf = GETIFCONF_TIMER;
}
if (responder && left_until_advertise <= 0) {
@ -841,7 +832,7 @@ struct sockaddr_in *from;
advertise(&sin);
break;
}
}
} /* end switch */
}
@ -851,6 +842,7 @@ struct sockaddr_in *from;
* Checksum routine for Internet Protocol family headers (C Version)
*
*/
int
in_cksum(addr, len)
u_short *addr;
int len;
@ -897,7 +889,8 @@ int len;
* the statistics output from becomming intermingled.
*/
void
finish()
finish(sig)
int sig;
{
if (responder) {
int i;
@ -957,12 +950,14 @@ unsigned char *data;
}
#endif notdef
int
isbroadcast(sin)
struct sockaddr_in *sin;
{
return (sin->sin_addr.s_addr == INADDR_BROADCAST);
}
int
ismulticast(sin)
struct sockaddr_in *sin;
{
@ -1082,13 +1077,14 @@ init()
{
int i;
initifs();
initifs(0);
for (i = 0; i < interfaces_size; i++)
interfaces[i].preference = preference;
}
void
initifs()
initifs(sig)
int sig;
{
int sock;
struct ifconf ifc;
@ -1147,6 +1143,7 @@ initifs()
ifreq = *ifrp;
if (ioctl(sock, SIOCGIFFLAGS, (char *)&ifreq) < 0) {
logperror("initifs: ioctl (get interface flags)");
n = 0;
continue;
}
n = ifrp->ifr_addr.sa_len + sizeof(ifrp->ifr_name);
@ -1212,7 +1209,7 @@ initifs()
(void) free(buf);
}
static int
int
join(sock, sin)
int sock;
struct sockaddr_in *sin;
@ -1444,11 +1441,7 @@ add_route(addr)
{
if (debug)
logdebug("Add default route to %s\n", pr_name(addr));
#if 1
rtioctl(addr, RTM_ADD);
#else
rtioctl(addr, SIOCADDRT);
#endif
}
void
@ -1457,11 +1450,7 @@ del_route(addr)
{
if (debug)
logdebug("Delete default route to %s\n", pr_name(addr));
#if 1
rtioctl(addr, RTM_DELETE);
#else
rtioctl(addr, SIOCDELRT);
#endif
}
void
@ -1470,7 +1459,6 @@ rtioctl(addr, op)
int op;
{
int sock;
#if 1
struct {
struct rt_msghdr m_rtm;
struct sockaddr_in m_dst;
@ -1480,23 +1468,30 @@ rtioctl(addr, op)
static int seq = 0;
bzero(&m_rtmsg, sizeof(m_rtmsg));
#define rtm m_rtmsg.m_rtm
rtm.rtm_type = op;
rtm.rtm_flags = RTF_GATEWAY | RTF_UP; /* XXX more? */
rtm.rtm_version = RTM_VERSION;
rtm.rtm_seq = ++seq;
rtm.rtm_addrs = RTA_DST | RTA_GATEWAY | RTA_NETMASK;
bzero(&rtm.rtm_rmx, sizeof(rtm.rtm_rmx)); /* XXX ??? */
rtm.rtm_inits = 0;
rtm.rtm_msglen = sizeof(m_rtmsg);
m_rtmsg.m_dst.sin_len = m_rtmsg.m_gateway.sin_len =
sizeof(struct sockaddr_in);
m_rtmsg.m_netmask.sin_len = 0;
m_rtmsg.m_dst.sin_family = m_rtmsg.m_gateway.sin_family =
m_rtmsg.m_netmask.sin_family = AF_INET;
m_rtmsg.m_rtm.rtm_type = op;
m_rtmsg.m_rtm.rtm_flags = RTF_GATEWAY | RTF_UP; /* XXX more? */
m_rtmsg.m_rtm.rtm_version = RTM_VERSION;
m_rtmsg.m_rtm.rtm_seq = ++seq;
m_rtmsg.m_rtm.rtm_addrs = RTA_DST | RTA_GATEWAY | RTA_NETMASK;
/* initialise route metrics to zero.. tcp may fill these in */
bzero(&m_rtmsg.m_rtm.rtm_rmx, sizeof(m_rtmsg.m_rtm.rtm_rmx));
m_rtmsg.m_rtm.rtm_inits = 0;
m_rtmsg.m_rtm.rtm_msglen = sizeof(m_rtmsg);
m_rtmsg.m_dst.sin_len = sizeof(struct sockaddr_in);
m_rtmsg.m_dst.sin_family = AF_INET;
m_rtmsg.m_dst.sin_addr.s_addr = 0; /* default */
/* XXX: is setting a zero length right? */
m_rtmsg.m_netmask.sin_len = 0;
m_rtmsg.m_netmask.sin_family = AF_INET;
m_rtmsg.m_netmask.sin_addr.s_addr = 0; /* default */
m_rtmsg.m_gateway.sin_len = sizeof(struct sockaddr_in);
m_rtmsg.m_gateway.sin_family = AF_INET;
m_rtmsg.m_gateway.sin_addr = addr; /* gateway */
sock = socket(PF_ROUTE, SOCK_RAW, 0);
@ -1505,32 +1500,10 @@ rtioctl(addr, op)
return;
}
if (write(sock, &m_rtmsg, sizeof(m_rtmsg)) != sizeof(m_rtmsg)) {
logperror("rtioctl: write");
return;
if (!(op == RTM_ADD && errno == EEXIST))
logperror("rtioctl: write");
}
close(sock);
#else
struct rtentry rt;
struct sockaddr_in *sin;
bzero((char *)&rt, sizeof(struct rtentry));
rt.rt_dst.sa_family = AF_INET;
rt.rt_gateway.sa_family = AF_INET;
sin = (struct sockaddr_in *)ALLIGN(&rt.rt_gateway);
sin->sin_addr = addr;
rt.rt_flags = RTF_UP | RTF_GATEWAY;
sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
if (sock < 0) {
logperror("rtioctl: socket");
return;
}
if (ioctl(sock, op, (char *)&rt) < 0) {
if (!(op == SIOCADDRT && errno == EEXIST))
logperror("ioctl (add/delete route)");
}
(void) close(sock);
#endif
}
@ -1540,73 +1513,99 @@ rtioctl(addr, op)
*/
static logging = 0;
static int logging = 0;
void
initlog()
{
logging++;
openlog("in.rdiscd", LOG_PID | LOG_CONS, LOG_DAEMON);
openlog("rdisc", LOG_PID | LOG_CONS, LOG_DAEMON);
}
/* VARARGS1 */
void
logerr(fmt, a,b,c,d,e,f,g,h)
#if __STDC__
logerr(char *fmt, ...)
#else
logerr(fmt, va_alist)
char *fmt;
va_dcl
#endif
{
if (logging)
syslog(LOG_ERR, fmt, a,b,c,d,e,f,g,h);
else
(void) fprintf(stderr, fmt, a,b,c,d,e,f,g,h);
}
va_list ap;
/* VARARGS1 */
void
logtrace(fmt, a,b,c,d,e,f,g,h)
char *fmt;
{
if (logging)
syslog(LOG_INFO, fmt, a,b,c,d,e,f,g,h);
else
(void) fprintf(stdout, fmt, a,b,c,d,e,f,g,h);
}
/* VARARGS1 */
void
logdebug(fmt, a,b,c,d,e,f,g,h)
char *fmt;
{
if (logging)
syslog(LOG_DEBUG, fmt, a,b,c,d,e,f,g,h);
else
(void) fprintf(stdout, fmt, a,b,c,d,e,f,g,h);
}
#if 0
extern char *sys_errlist[];
#if __STDC__
va_start(ap, fmt);
#else
va_start(ap);
#endif
extern int errno;
if (logging)
vsyslog(LOG_ERR, fmt, ap);
else
(void) vfprintf(stderr, fmt, ap);
va_end(ap);
}
/* VARARGS1 */
void
#if __STDC__
logtrace(char *fmt, ...)
#else
logtrace(fmt, va_alist)
char *fmt;
va_dcl
#endif
{
va_list ap;
#if __STDC__
va_start(ap, fmt);
#else
va_start(ap);
#endif
if (logging)
vsyslog(LOG_INFO, fmt, ap);
else
(void) vfprintf(stdout, fmt, ap);
va_end(ap);
}
/* VARARGS1 */
void
#if __STDC__
logdebug(char *fmt, ...)
#else
logdebug(fmt, va_alist)
char *fmt;
va_dcl
#endif
{
va_list ap;
#if __STDC__
va_start(ap, fmt);
#else
va_start(ap);
#endif
if (logging)
vsyslog(LOG_DEBUG, fmt, ap);
else
(void) vfprintf(stdout, fmt, ap);
va_end(ap);
}
void
logperror(str)
char *str;
{
if (logging)
syslog(LOG_ERR, "%s: %s\n", str, sys_errlist[errno]);
syslog(LOG_ERR, "%s: %m", str);
else
(void) fprintf(stderr, "%s: %s\n", str, sys_errlist[errno]);
(void) warn("%s", str);
}
#ifdef SYSV
void
bzero(cp, len)
char *cp;
int len;
{
while (--len>=0)
*cp++ = 0;
}
#endif