summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libexec/rpc.rwalld/rwalld.c37
1 files changed, 15 insertions, 22 deletions
diff --git a/libexec/rpc.rwalld/rwalld.c b/libexec/rpc.rwalld/rwalld.c
index 6d145b8a717..77b84ba8912 100644
--- a/libexec/rpc.rwalld/rwalld.c
+++ b/libexec/rpc.rwalld/rwalld.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rwalld.c,v 1.6 2002/02/16 21:27:31 millert Exp $ */
+/* $OpenBSD: rwalld.c,v 1.7 2002/06/28 01:04:15 deraadt Exp $ */
/*
* Copyright (c) 1993 Christopher G. Demetriou
@@ -30,7 +30,7 @@
*/
#ifndef lint
-static char rcsid[] = "$OpenBSD: rwalld.c,v 1.6 2002/02/16 21:27:31 millert Exp $";
+static char rcsid[] = "$OpenBSD: rwalld.c,v 1.7 2002/06/28 01:04:15 deraadt Exp $";
#endif /* not lint */
#include <sys/types.h>
@@ -58,30 +58,26 @@ void wallprog_1();
int from_inetd = 1;
void
-cleanup()
+cleanup(int signo)
{
(void) pmap_unset(WALLPROG, WALLVERS); /* XXX signal race */
_exit(0);
}
int
-main(argc, argv)
- int argc;
- char *argv[];
+main(int argc, char *argv[])
{
- SVCXPRT *transp;
- int sock = 0;
- int proto = 0;
+ int sock = 0, proto = 0, fromlen;
struct sockaddr_in from;
- int fromlen;
+ SVCXPRT *transp;
if (geteuid() == 0) {
struct passwd *pep = getpwnam("nobody");
+
if (pep) {
seteuid(pep->pw_uid);
setuid(pep->pw_uid);
- }
- else {
+ } else {
seteuid(getuid());
setuid(getuid());
}
@@ -115,7 +111,8 @@ main(argc, argv)
exit(1);
}
if (!svc_register(transp, WALLPROG, WALLVERS, wallprog_1, proto)) {
- syslog(LOG_ERR, "unable to register (WALLPROG, WALLVERS, %s).", proto?"udp":"(inetd)");
+ syslog(LOG_ERR, "unable to register (WALLPROG, WALLVERS, %s).",
+ proto ? "udp" : "(inetd)");
exit(1);
}
@@ -126,9 +123,7 @@ main(argc, argv)
}
void *
-wallproc_wall_1_svc(s, rqstp )
- char **s;
- struct svc_req *rqstp;
+wallproc_wall_1_svc(char **s, struct svc_req *rqstp)
{
FILE *pfp;
@@ -142,16 +137,14 @@ wallproc_wall_1_svc(s, rqstp )
}
void
-wallprog_1(rqstp, transp)
- struct svc_req *rqstp;
- SVCXPRT *transp;
+wallprog_1(struct svc_req *rqstp, SVCXPRT *transp)
{
+ char *(*local)(char **, struct svc_req *);
+ xdrproc_t xdr_argument, xdr_result;
union {
char *wallproc_wall_1_arg;
} argument;
char *result;
- xdrproc_t xdr_argument, xdr_result;
- char *(*local)(char **, struct svc_req *);
switch (rqstp->rq_proc) {
case NULLPROC:
@@ -162,7 +155,7 @@ wallprog_1(rqstp, transp)
xdr_argument = (xdrproc_t)xdr_wrapstring;
xdr_result = (xdrproc_t)xdr_void;
local = (char *(*)(char **, struct svc_req *))
- wallproc_wall_1_svc;
+ wallproc_wall_1_svc;
break;
default: