1 <?xml version="1.0" encoding="ISO-8859-1"?>
2 <!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../general.ent">
8 <sect1 id="ch-system-libcap" role="wrap">
9 <?dbhtml filename="libcap.html"?>
11 <sect1info condition="script">
12 <productname>libcap</productname>
13 <productnumber>&libcap-version;</productnumber>
14 <address>&libcap-url;</address>
17 <title>Libcap-&libcap-version;</title>
19 <indexterm zone="ch-system-libcap">
20 <primary sortas="a-Libcap">Libcap</primary>
23 <sect2 role="package">
26 <para>The Libcap package implements the user-space interfaces to the POSIX
27 1003.1e capabilities available in Linux kernels. These capabilities are a
28 partitioning of the all powerful root privilege into a set of distinct
32 <segtitle>&buildtime;</segtitle>
33 <segtitle>&diskspace;</segtitle>
36 <seg>&libcap-ch6-sbu;</seg>
37 <seg>&libcap-ch6-du;</seg>
43 <sect2 role="installation">
44 <title>Installation of Libcap</title>
46 <para>Prevent a static library from being installed:</para>
48 <screen><userinput remap="pre">sed -i '/install.*STALIBNAME/d' libcap/Makefile</userinput></screen>
50 <para>Compile the package:</para>
52 <screen><userinput remap="make">make</userinput></screen>
54 <para>This package does not come with a test suite.</para>
56 <para>Install the package:</para>
58 <screen><userinput remap="install">make RAISE_SETFCAP=no lib=lib prefix=/usr install
59 chmod -v 755 /usr/lib/libcap.so</userinput></screen>
62 <title>The meaning of the make option:</title>
65 <term><parameter>RAISE_SETFCAP=no</parameter></term>
67 <para>This parameter skips trying to use <command>setcap</command>
68 on itself. This avoids an installation error if the kernel or file
69 system does not support extended capabilities.</para>
74 <term><parameter>lib=lib</parameter></term>
76 <para>This parameter installs the library in
77 <filename>$prefix/lib</filename> rather than
78 <filename>$prefix/lib64</filename> on x86_64. It has no effect on
85 <para>The shared library needs to be moved to
86 <filename class="directory">/lib</filename>, and as a result the
87 <filename class="extension">.so</filename> file in
88 <filename class="directory">/usr/lib</filename> will need to be recreated:</para>
90 <screen><userinput remap="install">mv -v /usr/lib/libcap.so.* /lib
91 ln -sfv ../../lib/$(readlink /usr/lib/libcap.so) /usr/lib/libcap.so</userinput></screen>
95 <sect2 id="contents-libcap" role="content">
96 <title>Contents of Libcap</title>
99 <segtitle>Installed programs</segtitle>
100 <segtitle>Installed library</segtitle>
103 <seg>capsh, getcap, getpcaps, and setcap</seg>
109 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
110 <?dbfo list-presentation="list"?>
111 <?dbhtml list-presentation="table"?>
113 <varlistentry id="capsh">
114 <term><command>capsh</command></term>
116 <para>A shell wrapper to explore and constrain capability support</para>
117 <indexterm zone="ch-system-libcap capsh">
118 <primary sortas="b-capsh">capsh</primary>
123 <varlistentry id="getcap">
124 <term><command>getcap</command></term>
126 <para>Examines file capabilities</para>
127 <indexterm zone="ch-system-libcap getcap">
128 <primary sortas="b-getcap">getcap</primary>
133 <varlistentry id="getpcaps">
134 <term><command>getpcaps</command></term>
136 <para>Displays the capabilities on the queried process(es)</para>
137 <indexterm zone="ch-system-libcap getpcaps">
138 <primary sortas="b-getpcaps">getpcaps</primary>
143 <varlistentry id="setcap">
144 <term><command>setcap</command></term>
146 <para>Sets file capabilities</para>
147 <indexterm zone="ch-system-libcap setcap">
148 <primary sortas="b-setcap">setcap</primary>
153 <varlistentry id="libcap">
154 <term><filename class="libraryfile">libcap</filename></term>
156 <para>Contains the library functions for manipulating POSIX 1003.1e
158 <indexterm zone="ch-system-libcap libcap">
159 <primary sortas="c-libcap">libcap</primary>