1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-18 15:30:21 +00:00
Mirror of the FreeBSD src repository https://git.FreeBSD.org/src.git .
Go to file
Poul-Henning Kamp 9c71cb4bef Even if the permissions deny it, a process should be allowed to
access its controlling terminal.

In essense, history dictates that any process is allowed to open
/dev/tty for RW, irrespective of credential, because by definition
it is it's own controlling terminal.

Before DEVFS we relied on a hacky half-device thing (kern/tty_tty.c)
which did the magic deep down at device level, which at best was
disgusting from an architectural point of view.

My first shot at this was to use the cloning mechanism to simply
give people the right tty when they ask for /dev/tty, that's why
you get this, slightly counter intuitive result:

        syv# ls -l /dev/tty `tty`
        crw--w----  1 u1  tty    5,   0 Jan 13 22:14 /dev/tty
        crw--w----  1 u1  tty    5,   0 Jan 13 22:14 /dev/ttyp0

Trouble is, when user u1 su(1)'s to user u2, he cannot open
/dev/ttyp0 anymore because he doesn't have permission to do so.

The above fix allows him to do that.

The interesting side effect is that one was previously only able
to access the controlling tty by indirection:
        date > /dev/tty
but not by name:
        date > `tty`

This is now possible, and that feels a lot more like DTRT.

PR:             46635
MFC candidate:  could be.
2003-01-13 22:20:36 +00:00
bin Make the "tarcp" example more direct. 2003-01-10 17:37:23 +00:00
contrib Bow to the whining masses and change a union back into void *. Retain 2003-01-13 00:33:17 +00:00
crypto The previous commit contained a stupid mistake: ctxt->pam_[cp]sock was 2002-12-21 15:09:58 +00:00
etc Fix the named script to find the correct pid file for the 2003-01-12 04:53:54 +00:00
games s/Kank/Kang/ (the klingon) 2003-01-04 17:08:23 +00:00
gnu Reformat. 2003-01-04 17:51:59 +00:00
include Add prototypes for the non-standard _unlocked functions. 2003-01-13 08:41:47 +00:00
kerberos5 Update version numbers after import of Heimdal 0.5.1. 2002-11-24 21:00:51 +00:00
kerberosIV update version numbers to (consistenly): 2002-10-23 06:12:21 +00:00
lib Mention the oddities and requirements for mount operations executed by 2003-01-13 19:42:21 +00:00
libexec We have a usable 'LOGIN_NAME_MAX' now. 2003-01-06 04:42:20 +00:00
release List the Davicom 9009 as supported. 2003-01-13 20:02:40 +00:00
sbin really, this time for sure. Fix formatting in usage(). 2003-01-13 19:58:05 +00:00
secure ia64 and sparc64 both have libc_r now. 2003-01-09 08:36:05 +00:00
share Add check for AIO support before starting up. 2003-01-13 05:34:42 +00:00
sys Even if the permissions deny it, a process should be allowed to 2003-01-13 22:20:36 +00:00
tools Fix a useless use of cat. Save a process today. 2003-01-09 19:16:09 +00:00
usr.bin Bow to the whining masses and change a union back into void *. Retain 2003-01-13 00:33:17 +00:00
usr.sbin If you don't create a /usr filesystem, / will need 200MB. 2003-01-13 21:57:07 +00:00
COPYRIGHT
MAINTAINERS Remove request for i386 boot[012] review. I didn't have time recently to 2002-12-17 21:14:45 +00:00
Makefile Minor typo fixes and whitespace cleanups. 2002-12-30 16:48:35 +00:00
Makefile.inc1 Move elf2aout back to /usr/bin -- it is a general development tool, not 2002-12-30 10:01:26 +00:00
Makefile.upgrade
README Fix broken handbook links. 2002-07-21 16:45:30 +00:00
UPDATING Correct typos, mostly s/ a / an / where appropriate. Some whitespace cleanup, 2003-01-01 18:49:04 +00:00

This is the top level of the FreeBSD source directory.  This file
was last revised on:
$FreeBSD$

For copyright information, please see the file COPYRIGHT in this
directory (additional copyright information also exists for some
sources in this tree - please see the specific source directories for
more information).

The Makefile in this directory supports a number of targets for
building components (or all) of the FreeBSD source tree, the most
commonly used one being ``world'', which rebuilds and installs
everything in the FreeBSD system from the source tree except the
kernel, the kernel-modules and the contents of /etc.  The
``buildkernel'' and ``installkernel'' targets build and install
the kernel and the modules (see below).  Please see the top of
the Makefile in this directory for more information on the
standard build targets and compile-time flags.

Building a kernel is a somewhat more involved process, documentation
for which can be found at:
   http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html
And in the config(8) man page.
Note: If you want to build and install the kernel with the
``buildkernel'' and ``installkernel'' targets, you might need to build
world before.  More information is available in the handbook.

The sample kernel configuration files reside in the sys/<arch>/conf
sub-directory (assuming that you've installed the kernel sources), the
file named GENERIC being the one used to build your initial installation
kernel.  The file NOTES contains entries and documentation for all possible
devices, not just those commonly used.  It is the successor of the ancient
LINT file, but in contrast to LINT, it is not buildable as a kernel but a
pure reference and documentation file.


Source Roadmap:
---------------
bin		System/user commands.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

games		Amusements.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

kerberosIV	KerberosIV (eBones) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

sys		Kernel sources.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.


For information on synchronizing your source tree with one or more of
the FreeBSD Project's development branches, please see:

  http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/synching.html