CAPABILITIES(7) Linux Programmer’s Manual CAPABILITIES(7)
NAME
capabilities - overview of Linux capabilities
DESCRIPTION
For the purpose of performing permission checks, traditional Unix implementations
distinguish two categories of processes: privileged processes (whose effective user
ID is 0, referred to as superuser or root), and unprivileged processes (whose
effective UID is non-zero). Privileged processes bypass all kernel permission
checks, while unprivileged processes are subject to full permission checking based
on the process’s credentials (usually: effective UID, effective GID, and supplemen-
tary group list).
Starting with kernel 2.2, Linux provides an (as yet incomplete) system of capabili-
ties, which divide the privileges traditionally associated with superuser into dis-
tinct units that can be independently enabled and disabled.
Capabilities List
As at Linux 2.4.20, the following capabilities are implemented:
CAP_CHOWN
Allow arbitrary changes to file UIDs and GIDs (see chown(2)).
CAP_DAC_OVERRIDE
Bypass file read, write, and execute permission checks. (DAC = "discre-
tionary access control".)
CAP_DAC_READ_SEARCH
Bypass file read permission checks and directory read and execute permission
checks.
CAP_FOWNER
Bypass permission checks on operations that normally require the file system
UID of the process to match the UID of the file (e.g., utime(2)), excluding
those operations covered by the CAP_DAC_OVERRIDE and CAP_DAC_READ_SEARCH;
ignore sticky bit on file deletion.
CAP_FSETID
Don’t clear set-user-ID and set-group-ID bits when a file is modified; per-
mit setting of the set-group-ID bit for a file whose GID does not match the
file system or any of the supplementary GIDs of the calling process.
CAP_IPC_LOCK
Permit memory locking (mlock(2), mlockall(2), shmctl(2)).
CAP_IPC_OWNER
Bypass permission checks for operations on System V IPC objects.
CAP_KILL
Bypass permission checks for sending signals (see kill(2)).
CAP_LEASE
(Linux 2.4 onwards) Allow file leases to be established on arbitrary files
(see fcntl(2)).
CAP_LINUX_IMMUTABLE
Allow setting of the EXT2_APPEND_FL and EXT2_IMMUTABLE_FL ext2 extended file
attributes.
CAP_MKNOD
(Linux 2.4 onwards) Allow creation of special files using mknod(2).
CAP_NET_ADMIN
Allow various network-related operations (e.g., setting privileged socket
options, enabling multicasting, interface configuration, modifying routing
tables).
CAP_NET_BIND_SERVICE
Allow binding to Internet domain reserved socket ports (port numbers less
than 1024).
CAP_NET_BROADCAST
(Unused) Allow socket broadcasting, and listening multicasts.
CAP_NET_RAW
Permit use of RAW and PACKET sockets.
CAP_SETGID
Allow arbitrary manipulations of process GIDs and supplementary GID list;
allow forged GID when passing socket credentials via Unix domain sockets.
CAP_SETPCAP
Grant or remove any capability in the caller’s permitted capability set to
or from any other process.
CAP_SETUID
Allow arbitrary manipulations of process UIDs (setuid(2), etc.); allow
forged UID when passing socket credentials via Unix domain sockets.
CAP_SYS_ADMIN
Permit a range of system administration operations including: quotactl(2),
mount(2), swapon(2), sethostname(2), setdomainname(2), IPC_SET and IPC_RMID
operations on arbitrary System V IPC objects; allow forged UID when passing
socket credentials.
CAP_SYS_BOOT
Permit calls to reboot(2).
CAP_SYS_CHROOT
Permit calls to chroot(2).
CAP_SYS_MODULE
Allow loading and unloading of kernel modules; allow modifications to capa-
bility bounding set.
CAP_SYS_NICE
Allow raising process nice value (nice(2), setpriority(2)) and changing of
the nice value for arbitrary processes; allow setting of real-time schedul-
ing policies for calling process, and setting scheduling policies and prior-
ities for arbitrary processes (sched_setscheduler(2), sched_setparam(2)).
CAP_SYS_PACCT
Permit calls to acct(2).
CAP_SYS_PTRACE
Allow arbitrary processes to be traced using ptrace(2)
CAP_SYS_RAWIO
Permit I/O port operations (iopl(2) and ioperm(2)).
CAP_SYS_RESOURCE
Permit: use of reserved space on ext2 file systems; ioctl(2) calls control-
ling ext3 journaling; disk quota limits to be overridden; resource limits to
be increased (see setrlimit(2)); RLIMIT_NPROC resource limit to be overrid-
den; msg_qbytes limit for a message queue to be raised above the limit in
/proc/sys/kernel/msgmnb (see msgop(2) and msgctl(2).
CAP_SYS_TIME
Allow modification of system clock (settimeofday(2), adjtimex(2)); allow
modification of real-time (hardware) clock
CAP_SYS_TTY_CONFIG
Permit calls to vhangup(2).
Process Capabilities
Each process has three capability sets containing zero or more of the above capa-
bilities:
Effective:
the capabilities used by the kernel to perform permission checks for the
process.
Permitted:
the capabilities that the process may assume (i.e., a limiting superset for
the the effective and inheritable sets). If a process drops a capability
from its permitted set, it can never re-acquire that capability (unless it
execs a set-UID-root program).
Inherited:
the capabilities preserved across an execve(2).
In the current implementation, a process is granted all permitted and effective
capabilities (subject to the operation of the capability bounding set described
below) when it execs a set-UID-root program, or if a process with a real UID of
zero execs a new program.
A child created via fork(2) inherits copies of its parent’s capability sets.
Using capset(2), a process may manipulate its own capability sets, or, if it has
the CAP_SETPCAP capability, those of another process.
Capability bounding set
When a program is execed, the permitted and effective capabities are ANDed with
the current value of the so-called capability bounding set, defined in the file
/proc/sys/kernel/cap-bound. This parameter can be used to place a system-wide
limit on the capabilities granted to all subsequently executed programs. (Confus-
ingly, this bit mask parameter is expressed as a signed decimal number in
/proc/sys/kernel/cap-bound.)
Only the init process may set bits in the capability bounding set; other than that,
the superuser may only clear bits in this set.
On a standard system the capability bounding set always masks out the CAP_SETPCAP
capability. To remove this restriction, modify the definition of CAP_INIT_EFF_SET
in include/linux/capability.h and rebuild the kernel.
Current and Future Implementation
A full implementation of capabilities requires:
1. that for all privileged operations, the kernel check whether the process has
the required capability in its effective set.
2. that the kernel provide system calls allowing a process’s capability sets to be
changed and retrieved.
3. file system support for attaching capabilities to an executable file, so that a
process gains those capabilities when the file is execed.
As at Linux 2.4.20, only the first two of these requirements are met.
Eventually, it should be possible to associate three capability sets with an exe-
cutable file, which, in conjunction with the capability sets of the process, will
determine the capabilities of a process after an exec:
Allowed:
this set is ANDed with the process’s inherited set to determine which inher-
ited capabilities are permitted to the process after the exec.
Forced:
the capabilities automatically permitted to the process, regardless of the
process’s inherited capabilities.
Effective:
those capabilities in the process’s new permitted set are also to be set in
the new effective set. (F(effective) would normally be either all zeroes or
all ones.)
In the meantime, since the current implementation does not support file capability
sets, during an exec:
1. All three file capability sets are initially assumed to be cleared.
2. If a set-UID-root program is being execed, or the real user ID of the process
is 0 (root) then the file allowed and forced sets are defined to be all ones
(i.e., all capabilities set).
3. If a set-UID-root program is being executed, then the file effective set is
defined to be all ones.
During an exec, the kernel calculates the new capabilities of the process using the
following algorithm:
P’(permitted) = (P(inherited) & F(allowed)) | (F(forced) & cap_bset)
P’(effective) = P’(permitted) & F(effective)
P’(inherited) = P(inherited) [i.e., unchanged]
where:
P denotes the value of a process capability set before the exec
P’ denotes the value of a capability set after the exec
F denotes a file capability set
cap_bset is the value of the capability bounding set.
NOTES
The libcap package provides a suite of routines for setting and getting process
capabilities that is more comfortable and less likely to change than the interface
provided by capset(2) and capget(2).
CONFORMING TO
No standards govern capabilities, but the Linux capability implementation is based
on the withdrawn POSIX 1003.1e draft standard.
BUGS
There is as yet no file system support allowing capabilities to be associated with
executable files.
SEE ALSO
capget(2), prctl(2)
Linux 2.4.20 2003-05-23 CAPABILITIES(7)
Generated by $Id: phpMan.php,v 4.55 2007/09/05 04:42:51 chedong Exp $ Author: Che Dong
On Apache/1.3.41 (Unix) PHP/5.2.5 mod_perl/1.30 mod_gzip/1.3.26.1a
Under GNU General Public License
2009-01-10 08:44 @38.103.63.58 CrawledBy CCBot/1.0 (+http://www.commoncrawl.org/bot.html)