From owner-freebsd-bugs Tue Aug 24 19:51:18 1999 Delivered-To: freebsd-bugs@freebsd.org Received: from freefall.freebsd.org (freefall.FreeBSD.ORG [204.216.27.21]) by hub.freebsd.org (Postfix) with ESMTP id 1C5101504D for ; Tue, 24 Aug 1999 19:51:09 -0700 (PDT) (envelope-from gnats@FreeBSD.org) Received: (from gnats@localhost) by freefall.freebsd.org (8.9.3/8.9.2) id TAA59226; Tue, 24 Aug 1999 19:50:02 -0700 (PDT) (envelope-from gnats@FreeBSD.org) Received: from po4.wam.umd.edu (po4.wam.umd.edu [128.8.10.166]) by hub.freebsd.org (Postfix) with ESMTP id A429115193 for ; Tue, 24 Aug 1999 19:45:12 -0700 (PDT) (envelope-from howardjp@wam.umd.edu) Received: from rac9.wam.umd.edu (root@rac9.wam.umd.edu [128.8.10.149]) by po4.wam.umd.edu (8.9.3/8.9.3) with ESMTP id WAA08767 for ; Tue, 24 Aug 1999 22:42:17 -0400 (EDT) Received: from rac9.wam.umd.edu (sendmail@localhost [127.0.0.1]) by rac9.wam.umd.edu (8.9.3/8.9.3) with SMTP id WAA07678 for ; Tue, 24 Aug 1999 22:42:17 -0400 (EDT) Received: (from howardjp@localhost) by rac9.wam.umd.edu (8.9.3/8.9.3) id WAA07674 for FreeBSD-gnats-submit@freebsd.org; Tue, 24 Aug 1999 22:42:16 -0400 (EDT) Message-Id: <199908250242.WAA07674@rac9.wam.umd.edu> Date: Tue, 24 Aug 1999 22:42:16 -0400 (EDT) From: James Howard Reply-To: howardjp@wam.umd.edu To: FreeBSD-gnats-submit@freebsd.org X-Send-Pr-Version: 3.2 Subject: bin/13365: Patch to mkfifo(1) for Unix 98 compliance Sender: owner-freebsd-bugs@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.org >Number: 13365 >Category: bin >Synopsis: Patch to mkfifo(1) for Unix 98 compliance >Confidential: no >Severity: non-critical >Priority: low >Responsible: freebsd-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: change-request >Submitter-Id: current-users >Arrival-Date: Tue Aug 24 19:50:01 PDT 1999 >Closed-Date: >Last-Modified: >Originator: James Howard >Release: FreeBSD 3.2-STABLE i386 >Organization: University of Maryland >Environment: FreeBSD byzantine 3.2-STABLE FreeBSD 3.2-STABLE #5: Sat Aug 7 23:43:54 GMT 1999 root@byzantine:/usr/src/sys/compile/BYZANTINE i386 >Description: Unix 98 requires that mkfifo(1) take an argument -m. If this argument is given, it is followed by a string which specifies the mode which the FIFO will be set to. The behaviour is identical to the -m argument to mkdir(1). Consquently, the changes to mkfifo were derived from mkdir. Apply the diff below to /usr/src/usr.bin/mkfifo to update mkfifo.c and mkfifo.1. >How-To-Repeat: mkfifo -m gives an illegal option error >Fix: diff -c /usr/src/usr.bin/mkfifo/mkfifo.1 /usr/local/src/mkfifo/mkfifo.1 *** /usr/src/usr.bin/mkfifo/mkfifo.1 Sun Apr 27 08:45:45 1997 --- /usr/local/src/mkfifo/mkfifo.1 Tue Aug 24 18:53:24 1999 *************** *** 43,48 **** --- 43,49 ---- .Nd make fifos .Sh SYNOPSIS .Nm + .Op Fl m Ar mode .Ar fifo_name ... .Sh DESCRIPTION The *************** *** 54,59 **** --- 55,77 ---- The .Nm command requires write permission in the parent directory. + .Pp + The options are as follows + .Pp + .Bl -tag -width indent + .It Fl m + Set the file permission bits of the final created directory to + the specified mode. + The mode argument can be in any of the formats specified to the + .Xr chmod 1 + command. + If a symbolic mode is specified, the operation characters + .Dq + + and + .Dq - + are interpreted relative to an initial mode of + .Dq a=rwx . + .El .Pp The .Nm diff -c /usr/src/usr.bin/mkfifo/mkfifo.c /usr/local/src/mkfifo/mkfifo.c *** /usr/src/usr.bin/mkfifo/mkfifo.c Thu Jul 24 07:02:55 1997 --- /usr/local/src/mkfifo/mkfifo.c Tue Aug 24 19:11:30 1999 *************** *** 50,55 **** --- 50,56 ---- #include #include + #include #include #include *************** *** 61,70 **** char *argv[]; { extern int optind; ! int ch, exitval; ! while ((ch = getopt(argc, argv, "")) != -1) switch(ch) { case '?': default: usage(); --- 62,77 ---- char *argv[]; { extern int optind; ! int ch, exitval, omode, success; ! mode_t *set = (mode_t *)NULL; ! char *mode; ! mode = NULL; ! while ((ch = getopt(argc, argv, "m:")) != -1) switch(ch) { + case 'm': + mode = optarg; + break; case '?': default: usage(); *************** *** 74,84 **** if (argv[0] == NULL) usage(); ! for (exitval = 0; *argv != NULL; ++argv) ! if (mkfifo(*argv, S_IRWXU | S_IRWXG | S_IRWXO) < 0) { warn("%s", *argv); ! exitval = 1; } exit(exitval); } --- 81,116 ---- if (argv[0] == NULL) usage(); ! if (mode == NULL) { ! omode = S_IRWXU | S_IRWXG | S_IRWXO; ! } else { ! if ((set = setmode(mode)) == NULL) ! errx(1, "invalid file mode: %s", mode); ! omode = getmode(set, S_IRWXU | S_IRWXG | S_IRWXO); ! free(set); ! } ! ! for (exitval = 0; *argv != NULL; ++argv) { ! success = 1; ! if (mkfifo(*argv, omode) < 0) { warn("%s", *argv); ! success = 0; } + if (!success) + exitval = 1; + /* + * The mkdir() and umask() calls both honor only the low + * nine bits, so if you try to set a mode including the + * sticky, setuid, setgid bits you lose them. Don't do + * this unless the user has specifically requested a mode, + * as chmod will (obviously) ignore the umask. + */ + if (success && mode != NULL && chmod(*argv, omode) == -1) { + warn("%s", *argv); + exitval = 1; + } + } + exit(exitval); } >Release-Note: >Audit-Trail: >Unformatted: To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-bugs" in the body of the message