There are two components to the policy, the binary tree and the source
tree. The binary tree comes from the
selinux-policy-<policyname>
package and supplies the binary policy file. Alternately, the binary
policy can be built from source when the
selinux-policy-<policyname>-sources
package is installed. For Red Hat Enterprise Linux 4 the
<policyname> is targeted. Directory conventions
for this guide are explained in Section 3 Conventions for SELinux Directories and Files.
/etc/selinux/targeted/ — this is the root folder
for the targeted policy, and contains both the binary and source
trees.
/etc/selinux/targeted/policy/ — the binary policy file
policy.<XY> is here. In
this guide, the variable $SELINUX_POLICY/ is used for this directory.
/etc/selinux/targeted/src/policy/ — this is the location of
the policy source tree. For details about these sub-directories, read
Section 3.2 Files and Directories of the Targeted Policy. In this guide, the
variable $SELINUX_SRC/ is used for this directory.
/etc/selinux/targeted/contexts/ — location of the
security context information and configuration files, which are used
during runtime by various applications. This directory contains:
*_context* and
default_type — various contexts used by
applications, such as the userhelper_context
used by userhelper.
files/* — the file
file_contexts contains the default contexts
for the whole file system. This is what
restorecon references when relabeling. The
file media contains the default contexts for
media devices such as the CD-ROM and floppy disk.
users/* — in the targeted policy,
only the file root is in this directory.
These files are used for determining context on login, which is
system_r:unconfined_t for root.
booleans — this is where the runtime
Booleans are configured. This is the canonical configuration file
when Boolean values are changed.
To help applications that need the various SELinux paths,
libselinux has a number of functions that return the
paths to the different configuration files and directories. This keeps
applications from having to hard code the paths, especially since the active
policy location is dependent on the setting in
/etc/selinux/config. The list of functions is
available from the manual page which you can view with the command
man 3 selinux_binary_policy_path.