summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/lpr/lpd/lpd.c28
1 files changed, 8 insertions, 20 deletions
diff --git a/usr.sbin/lpr/lpd/lpd.c b/usr.sbin/lpr/lpd/lpd.c
index 3dde1dc8b4d..915dbe21bdc 100644
--- a/usr.sbin/lpr/lpd/lpd.c
+++ b/usr.sbin/lpr/lpd/lpd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: lpd.c,v 1.45 2007/05/01 16:32:06 stevesk Exp $ */
+/* $OpenBSD: lpd.c,v 1.46 2007/05/05 17:13:01 stevesk Exp $ */
/* $NetBSD: lpd.c,v 1.33 2002/01/21 14:42:29 wiz Exp $ */
/*
@@ -41,7 +41,7 @@ static const char copyright[] =
#if 0
static const char sccsid[] = "@(#)lpd.c 8.7 (Berkeley) 5/10/95";
#else
-static const char rcsid[] = "$OpenBSD: lpd.c,v 1.45 2007/05/01 16:32:06 stevesk Exp $";
+static const char rcsid[] = "$OpenBSD: lpd.c,v 1.46 2007/05/05 17:13:01 stevesk Exp $";
#endif
#endif /* not lint */
@@ -106,8 +106,6 @@ static const char rcsid[] = "$OpenBSD: lpd.c,v 1.45 2007/05/01 16:32:06 stevesk
#include "pathnames.h"
#include "extern.h"
-#define LPD_NOPORTCHK 0001 /* skip reserved-port check */
-
int lflag; /* log requests flag */
int rflag; /* allow 'of' for remote printers */
int sflag; /* secure (no inet) flag */
@@ -122,7 +120,7 @@ static void reapchild(int);
static void mcleanup(int);
static void doit(void);
static void startup(void);
-static void chkhost(struct sockaddr *, int);
+static void chkhost(struct sockaddr *);
static int ckqueue(char *);
static __dead void usage(void);
static int *socksetup(int, int, const char *);
@@ -142,7 +140,7 @@ main(int argc, char **argv)
struct sockaddr_storage frominet;
sigset_t mask, omask;
int lfd, i, f, funix, *finet;
- int options, check_options, maxfd;
+ int options, maxfd;
long l;
long child_max = 32; /* more than enough to hose the system */
struct servent *sp;
@@ -163,7 +161,6 @@ main(int argc, char **argv)
effective_gid = getegid();
PRIV_END; /* run as daemon for most things */
- check_options = LPD_NOPORTCHK; /* XXX - lp* not setuid root */
options = 0;
gethostname(host, sizeof(host));
@@ -222,12 +219,7 @@ main(int argc, char **argv)
if (wait_time < 30)
warnx("warning: wait time less than 30 seconds");
break;
- case 'W':
- /*
- * Allow connections coming from a non-reserved port.
- * (done by some lpr-implementations for MS-Windows)
- */
- check_options |= LPD_NOPORTCHK;
+ case 'W': /* XXX deprecate */
break;
default:
usage();
@@ -432,7 +424,7 @@ main(int argc, char **argv)
if (domain == AF_INET) {
/* for both AF_INET and AF_INET6 */
from_remote = 1;
- chkhost((struct sockaddr *)&frominet, check_options);
+ chkhost((struct sockaddr *)&frominet);
} else
from_remote = 0;
doit();
@@ -682,7 +674,7 @@ ckqueue(char *cap)
* Check to see if the from host has access to the line printer.
*/
static void
-chkhost(struct sockaddr *f, int check_opts)
+chkhost(struct sockaddr *f)
{
struct addrinfo hints, *res, *r;
FILE *hostf;
@@ -697,10 +689,6 @@ chkhost(struct sockaddr *f, int check_opts)
if (error)
fatal("Malformed from address");
- if (!(check_opts & LPD_NOPORTCHK) &&
- atoi(serv) >= IPPORT_RESERVED)
- fatal("Connect from invalid port (%s)", serv);
-
/* Need real hostname for temporary filenames */
error = getnameinfo(f, f->sa_len, host, sizeof(host), NULL, 0,
NI_NAMEREQD);
@@ -769,7 +757,7 @@ usage(void)
{
extern char *__progname;
- fprintf(stderr, "usage: %s [-dlrsW] [-b bind-address] [-n maxchild] "
+ fprintf(stderr, "usage: %s [-dlrs] [-b bind-address] [-n maxchild] "
"[-w maxwait] [port]\n", __progname);
exit(1);
}