Fix most of the warnings given by WARNS=2.

This commit is contained in:
David Malone 2001-06-24 09:20:07 +00:00
parent e2d53d7c4a
commit b585f768e1
3 changed files with 114 additions and 105 deletions

View File

@ -52,8 +52,21 @@
#include "inetd.h"
extern int debug;
extern struct servtab *servtab;
void chargen_dg __P((int, struct servtab *));
void chargen_stream __P((int, struct servtab *));
void daytime_dg __P((int, struct servtab *));
void daytime_stream __P((int, struct servtab *));
void discard_dg __P((int, struct servtab *));
void discard_stream __P((int, struct servtab *));
void echo_dg __P((int, struct servtab *));
void echo_stream __P((int, struct servtab *));
static int getline __P((int, char *, int));
void iderror __P((int, int, int, const char *));
void ident_stream __P((int, struct servtab *));
void initring __P((void));
unsigned long machtime __P((void));
void machtime_dg __P((int, struct servtab *));
void machtime_stream __P((int, struct servtab *));
char ring[128];
char *endring;
@ -80,11 +93,11 @@ struct biltin biltins[] = {
{ "chargen", SOCK_STREAM, 1, -1, chargen_stream },
{ "chargen", SOCK_DGRAM, 0, 1, chargen_dg },
{ "tcpmux", SOCK_STREAM, 1, -1, (void (*)())tcpmux },
{ "tcpmux", SOCK_STREAM, 1, -1, (bi_fn_t *)tcpmux },
{ "auth", SOCK_STREAM, 1, -1, ident_stream },
{ NULL }
{ NULL, 0, 0, 0, NULL }
};
/*
@ -187,11 +200,11 @@ daytime_dg(s, sep) /* Return human-readable time of day */
struct servtab *sep;
{
char buffer[256];
time_t clock;
time_t now;
struct sockaddr_storage ss;
socklen_t size;
clock = time((time_t *) 0);
now = time((time_t *) 0);
size = sizeof(ss);
if (recvfrom(s, buffer, sizeof(buffer), 0,
@ -201,7 +214,7 @@ daytime_dg(s, sep) /* Return human-readable time of day */
if (check_loop((struct sockaddr *)&ss, sep))
return;
(void) sprintf(buffer, "%.24s\r\n", ctime(&clock));
(void) sprintf(buffer, "%.24s\r\n", ctime(&now));
(void) sendto(s, buffer, strlen(buffer), 0,
(struct sockaddr *)&ss, size);
}
@ -213,11 +226,11 @@ daytime_stream(s, sep) /* Return human-readable time of day */
struct servtab *sep;
{
char buffer[256];
time_t clock;
time_t now;
clock = time((time_t *) 0);
now = time((time_t *) 0);
(void) sprintf(buffer, "%.24s\r\n", ctime(&clock));
(void) sprintf(buffer, "%.24s\r\n", ctime(&now));
(void) send(s, buffer, strlen(buffer), MSG_EOF);
}
@ -316,7 +329,7 @@ echo_stream(s, sep) /* Echo service -- echo data back */
void
iderror(lport, fport, s, er) /* Generic ident_stream error-sending func */
int lport, fport, s;
char *er;
const char *er;
{
char *p;
@ -339,7 +352,7 @@ ident_stream(s, sep) /* Ident service (AKA "auth") */
{
struct utsname un;
struct stat sb;
struct sockaddr_in sin[2];
struct sockaddr_in sin4[2];
#ifdef INET6
struct sockaddr_in6 sin6[2];
#endif
@ -377,7 +390,7 @@ ident_stream(s, sep) /* Ident service (AKA "auth") */
if (argc) {
int sec, usec;
size_t i;
u_int32_t random;
u_int32_t rnd32;
while ((c = getopt(argc, sep->se_argv, "d:fFgino:rt:")) != -1)
switch (c) {
@ -394,9 +407,9 @@ ident_stream(s, sep) /* Ident service (AKA "auth") */
break;
case 'g':
gflag = 1;
random = 0; /* Shush, compiler. */
rnd32 = 0; /* Shush, compiler. */
/*
* The number of bits in "random" divided
* The number of bits in "rnd32" divided
* by the number of bits needed per iteration
* gives a more optimal way to reload the
* random number only when necessary.
@ -409,9 +422,9 @@ ident_stream(s, sep) /* Ident service (AKA "auth") */
"0123456789"
"abcdefghijklmnopqrstuvwxyz";
if (i % 6 == 0)
random = arc4random();
idbuf[i] = base36[random % 36];
random /= 36;
rnd32 = arc4random();
idbuf[i] = base36[rnd32 % 36];
rnd32 /= 36;
}
idbuf[i] = '\0';
break;
@ -483,7 +496,7 @@ ident_stream(s, sep) /* Ident service (AKA "auth") */
iderror(0, 0, s, ID_UNKNOWN);
if (ioctl(s, FIONREAD, &onreadlen) == -1)
iderror(0, 0, s, ID_UNKNOWN);
if (onreadlen > bufsiz)
if ((size_t)onreadlen > bufsiz)
onreadlen = bufsiz;
ssize = read(s, &buf[size], (size_t)onreadlen);
if (ssize == -1)
@ -533,12 +546,12 @@ ident_stream(s, sep) /* Ident service (AKA "auth") */
size = sizeof(uc);
switch (ss[0].ss_family) {
case AF_INET:
sin[0] = *(struct sockaddr_in *)&ss[0];
sin[0].sin_port = htons(lport);
sin[1] = *(struct sockaddr_in *)&ss[1];
sin[1].sin_port = htons(fport);
if (sysctlbyname("net.inet.tcp.getcred", &uc, &size, sin,
sizeof(sin)) == -1)
sin4[0] = *(struct sockaddr_in *)&ss[0];
sin4[0].sin_port = htons(lport);
sin4[1] = *(struct sockaddr_in *)&ss[1];
sin4[1].sin_port = htons(fport);
if (sysctlbyname("net.inet.tcp.getcred", &uc, &size, sin4,
sizeof(sin4)) == -1)
getcredfail = errno;
break;
#ifdef INET6

View File

@ -204,6 +204,31 @@ static const char rcsid[] =
#define SIGBLOCK (sigmask(SIGCHLD)|sigmask(SIGHUP)|sigmask(SIGALRM))
void close_sep __P((struct servtab *));
void flag_signal __P((int));
void flag_config __P((int));
void config __P((void));
int cpmip __P((const struct servtab *, int));
void endconfig __P((void));
struct servtab *enter __P((struct servtab *));
void freeconfig __P((struct servtab *));
struct servtab *getconfigent __P((void));
int matchservent __P((const char *, const char *, const char *));
char *nextline __P((FILE *));
void addchild __P((struct servtab *, int));
void flag_reapchild __P((int));
void reapchild __P((void));
void enable __P((struct servtab *));
void disable __P((struct servtab *));
void flag_retry __P((int));
void retry __P((void));
int setconfig __P((void));
void setup __P((struct servtab *));
#ifdef IPSEC
void ipsecsetup __P((struct servtab *));
#endif
void unregisterrpc __P((register struct servtab *sep));
int allow_severity;
int deny_severity;
int wrap_ex = 0;
@ -239,8 +264,8 @@ struct servtab *servtab;
extern struct biltin biltins[];
#define NUMINT (sizeof(intab) / sizeof(struct inent))
char *CONFIG = _PATH_INETDCONF;
char *pid_file = _PATH_INETDPID;
const char *CONFIG = _PATH_INETDCONF;
const char *pid_file = _PATH_INETDPID;
#ifdef OLD_SETPROCTITLE
char **Argv;
@ -249,7 +274,7 @@ char *LastArg;
int
getvalue(arg, value, whine)
char *arg, *whine;
const char *arg, *whine;
int *value;
{
int tmp;
@ -294,7 +319,7 @@ main(argc, argv, envp)
#define peermax p_un.peer_max
int i;
struct addrinfo hints, *res;
char *servname;
const char *servname;
int error;
@ -654,7 +679,7 @@ main(argc, argv, envp)
* Call tcpmux to find the real service to exec.
*/
if (sep->se_bi &&
sep->se_bi->bi_fn == (void (*)()) tcpmux) {
sep->se_bi->bi_fn == (bi_fn_t *) tcpmux) {
sep = tcpmux(ctrl);
if (sep == NULL) {
close(ctrl);
@ -791,8 +816,9 @@ main(argc, argv, envp)
* Add a signal flag to the signal flag queue for later handling
*/
void flag_signal(c)
int c;
void
flag_signal(c)
int c;
{
char ch = c;
@ -873,7 +899,8 @@ flag_config(signo)
flag_signal('H');
}
void config()
void
config()
{
struct servtab *sep, *new, **sepp;
long omask;
@ -1070,7 +1097,7 @@ void
unregisterrpc(sep)
struct servtab *sep;
{
int i;
u_int i;
struct servtab *sepp;
long omask;
@ -1198,7 +1225,7 @@ setsockopt(fd, SOL_SOCKET, opt, (char *)&on, sizeof (on))
umask(mask);
}
if (sep->se_rpc) {
int i;
u_int i;
socklen_t len = sep->se_ctrladdr_size;
if (sep->se_family != AF_INET) {
@ -1263,8 +1290,9 @@ ipsecsetup(sep)
}
if (!sep->se_policy || sep->se_policy[0] == '\0') {
policy_in = "in entrust";
policy_out = "out entrust";
static char def_in[] = "in entrust", def_out[] = "out entrust";
policy_in = def_in;
policy_out = def_out;
} else {
if (!strncmp("in", sep->se_policy, 2))
policy_in = sep->se_policy;
@ -1327,7 +1355,7 @@ close_sep(sep)
int
matchservent(name1, name2, proto)
char *name1, *name2, *proto;
const char *name1, *name2, *proto;
{
char **alias, *p;
struct servent *se;
@ -1931,10 +1959,12 @@ nextline(fd)
char *
newstr(cp)
char *cp;
const char *cp;
{
if ((cp = strdup(cp ? cp : "")))
return (cp);
char *cr;
if ((cr = strdup(cp != NULL ? cp : "")))
return (cr);
syslog(LOG_ERR, "strdup: %m");
exit(EX_OSERR);
}
@ -1942,7 +1972,7 @@ newstr(cp)
#ifdef OLD_SETPROCTITLE
void
inetd_setproctitle(a, s)
char *a;
const char *a;
int s;
{
int size;
@ -1966,7 +1996,7 @@ inetd_setproctitle(a, s)
#else
void
inetd_setproctitle(a, s)
char *a;
const char *a;
int s;
{
socklen_t size;
@ -1985,13 +2015,10 @@ inetd_setproctitle(a, s)
#endif
/*
* Internet services provided internally by inetd:
*/
int check_loop(sa, sep)
struct sockaddr *sa;
struct servtab *sep;
int
check_loop(sa, sep)
const struct sockaddr *sa;
const struct servtab *sep;
{
struct servtab *se2;
char pname[INET6_ADDRSTRLEN];
@ -2002,13 +2029,13 @@ int check_loop(sa, sep)
switch (se2->se_family) {
case AF_INET:
if (((struct sockaddr_in *)sa)->sin_port ==
if (((const struct sockaddr_in *)sa)->sin_port ==
se2->se_ctrladdr4.sin_port)
goto isloop;
continue;
#ifdef INET6
case AF_INET6:
if (((struct sockaddr_in *)sa)->sin_port ==
if (((const struct sockaddr_in *)sa)->sin_port ==
se2->se_ctrladdr4.sin_port)
goto isloop;
continue;
@ -2034,8 +2061,8 @@ int check_loop(sa, sep)
*/
void
print_service(action, sep)
char *action;
struct servtab *sep;
const char *action;
const struct servtab *sep;
{
fprintf(stderr,
"%s: %s proto=%s accept=%d max=%d user=%s group=%s"
@ -2086,7 +2113,7 @@ CHash CHashAry[CPMHSIZE];
int
cpmip(sep, ctrl)
struct servtab *sep;
const struct servtab *sep;
int ctrl;
{
struct sockaddr_storage rss;
@ -2106,22 +2133,22 @@ cpmip(sep, ctrl)
int cnt = 0;
CHash *chBest = NULL;
unsigned int ticks = t / CHTGRAN;
struct sockaddr_in *sin;
struct sockaddr_in *sin4;
#ifdef INET6
struct sockaddr_in6 *sin6;
#endif
sin = (struct sockaddr_in *)&rss;
sin4 = (struct sockaddr_in *)&rss;
#ifdef INET6
sin6 = (struct sockaddr_in6 *)&rss;
#endif
{
char *p;
int i, addrlen;
int addrlen;
switch (rss.ss_family) {
case AF_INET:
p = (char *)&sin->sin_addr;
p = (char *)&sin4->sin_addr;
addrlen = sizeof(struct in_addr);
break;
#ifdef INET6
@ -2145,7 +2172,7 @@ cpmip(sep, ctrl)
if (rss.ss_family == AF_INET &&
ch->ch_Family == AF_INET &&
sin->sin_addr.s_addr == ch->ch_Addr4.s_addr &&
sin4->sin_addr.s_addr == ch->ch_Addr4.s_addr &&
ch->ch_Service && strcmp(sep->se_service,
ch->ch_Service) == 0) {
chBest = ch;
@ -2169,11 +2196,11 @@ cpmip(sep, ctrl)
}
if ((rss.ss_family == AF_INET &&
(chBest->ch_Family != AF_INET ||
sin->sin_addr.s_addr != chBest->ch_Addr4.s_addr)) ||
sin4->sin_addr.s_addr != chBest->ch_Addr4.s_addr)) ||
chBest->ch_Service == NULL ||
strcmp(sep->se_service, chBest->ch_Service) != 0) {
chBest->ch_Family = sin->sin_family;
chBest->ch_Addr4 = sin->sin_addr;
chBest->ch_Family = sin4->sin_family;
chBest->ch_Addr4 = sin4->sin_addr;
if (chBest->ch_Service)
free(chBest->ch_Service);
chBest->ch_Service = strdup(sep->se_service);

View File

@ -110,55 +110,24 @@ struct servtab {
#define se_nomapped se_flags.se_nomapped
#define se_reset se_flags.se_reset
void chargen_dg __P((int, struct servtab *));
void chargen_stream __P((int, struct servtab *));
void close_sep __P((struct servtab *));
void flag_signal __P((int));
void flag_config __P((int));
void config __P((void));
void daytime_dg __P((int, struct servtab *));
void daytime_stream __P((int, struct servtab *));
void discard_dg __P((int, struct servtab *));
void discard_stream __P((int, struct servtab *));
void echo_dg __P((int, struct servtab *));
void echo_stream __P((int, struct servtab *));
void endconfig __P((void));
struct servtab *enter __P((struct servtab *));
void freeconfig __P((struct servtab *));
struct servtab *getconfigent __P((void));
void iderror __P((int, int, int, char *));
void ident_stream __P((int, struct servtab *));
void machtime_dg __P((int, struct servtab *));
void machtime_stream __P((int, struct servtab *));
int matchservent __P((char *, char *, char *));
char *newstr __P((char *));
char *nextline __P((FILE *));
void print_service __P((char *, struct servtab *));
void addchild __P((struct servtab *, int));
void flag_reapchild __P((int));
void reapchild __P((void));
void enable __P((struct servtab *));
void disable __P((struct servtab *));
void flag_retry __P((int));
void retry __P((void));
int setconfig __P((void));
void setup __P((struct servtab *));
#ifdef IPSEC
void ipsecsetup __P((struct servtab *));
#endif
int check_loop __P((const struct sockaddr *, const struct servtab *sep));
int getvalue __P((const char *, int *, const char *));
char *newstr __P((const char *));
void inetd_setproctitle __P((const char *, int));
void print_service __P((const char *, const struct servtab *));
char *sskip __P((char **));
char *skip __P((char **));
struct servtab *tcpmux __P((int));
int cpmip __P((struct servtab *, int));
void inetd_setproctitle __P((char *, int));
int check_loop __P((struct sockaddr *, struct servtab *sep));
void unregisterrpc __P((register struct servtab *sep));
extern int debug;
extern struct servtab *servtab;
typedef void (bi_fn_t) __P((int, struct servtab *));
struct biltin {
char *bi_service; /* internally provided service name */
const char *bi_service; /* internally provided service name */
int bi_socktype; /* type of socket supported */
short bi_fork; /* 1 if should fork before call */
int bi_maxchild; /* max number of children, -1=default */
void (*bi_fn)(); /* function which performs it */
bi_fn_t *bi_fn; /* function which performs it */
};