On Wed, 2010-05-19 at 19:03 +0500, Shaz wrote: > >> What if there is a difference of policy versions between the host and > >> target :) Even difference of selinux libs? > > > > Can you run the following on the target system: > > $ cat /selinux/policyvers > > > > And the following on the build host: > > $ checkpolicy -V > > > > The first command shows you the highest policy version that can be > > understood by your kernel. The kernel can also understand any lower > > version, down to the first version ever supported by Linux 2.6.0 > > (version 15), as it provides full backward compatibility. > > > > The second command shows you the policy version range that can be read > > or written by your libraries and policy compiler. > > > > Any policy version supported by the libraries on the target should also > > be loadable on the target, even if the kernel only supports an older > > version. This is because the libraries will automatically downgrade the > > policy file to the version supported by the kernel at policy load time > > if necessary. However, given the option, I would directly generate a > > policy version that can be loaded by your kernel without requiring such > > runtime downgrading in order to eliminate a potential cause of failure > > at runtime and an extra in-memory copy of the policy during the > > downgrade process. > > > > If checkpolicy on the build host supports a newer version of policy than > > the kernel on the target, then you can just force it to generate an > > older version. To specify an older version, you use the -c option to > > checkpolicy, which is automatically used if you specify an > > OUTPUT_POLICY= setting in build.conf for a monolithic policy build. For > > modular builds, you can specify a policy-version > > in /etc/selinux/semanage.conf to force generation of an older policy > > version, or you can run checkpolicy by hand to later convert the policy, > > e.g. > > checkpolicy -M -c 20 -b policy.24 -o policy.20 > > will take a policy.24 file and downgrade it to a policy.20 file for you. > > > > If checkpolicy on the build host supports an older version of policy > > than the kernel on the target, then you have two options: > > 1) Just generate the older policy version - the target will still be > > able to load it due to the backward compatibility. This is fine as long > > as you don't actually need any of the features introduced in the newer > > policy version. -or- > > 2) Install a private copy of a newer version of the selinux userspace on > > the build host (not overwriting the ones the build host normally uses, > > but e.g. under some other path; we sometimes do this via make > > DESTDIR=/path), and use that private copy to build the policy for the > > target. That just requires setting up your LD_LIBRARY_PATH, PATH, and > > similar variables when building policy for the target. Then you can > > generate newer policy versions on the build host for the target without > > affecting anything else on the build host. > > Very useful information. I have another question ... will a module > built on build host with one version of policy compatible to load with > another policy version running on the target? Policy modules have their own versioning; you can see what module versions are supported by your libraries and policy compiler via checkmodule -V on both the build host and the target host. If checkmodule on the build host supports a newer version of modules than the libraries on the target host, then (just like the corresponding case for kernel policy versions) you'd need to generate the older module version for the target system. While that should be supported already by the libraries, I don't think we have a build.conf or a semanage.conf setting today that would specify the output module version, and checkmodule doesn't appear to support the -c switch. So someone would have to code up the support for doing that. In the interim, I think your only option for this case is to install a private copy of the same selinux userspace as the target on the build host and use that to compile your modules so that the versions will be compatible. If checkmodule on the build host supports an older version of modules than the libraries on the target host, you have two options as with the corresponding case for kernel policy versions. You can just generate the older module version and use that on the target system (at a possible cost in newer features in the newer module format), or you can install a private copy of the selinux userspace from the target on the build host and use that to generate the newer module version. > > It depends on how divergent your userspace environment, size > > requirements, and goals are from the ones used for refpolicy. > > Nakamura et al found it difficult to prune refpolicy for their embedded > > SELinux work. > > Can we have policy modules, interfaces and booleans without reference policy? Booleans are a policy primitive directly supported by the kernel. Modules are an abstraction supported by the policy toolchain (selinux userspace). Interfaces are an abstraction supported by the refpolicy, but they are implemented just via m4 macros. So you can certainly use booleans and modules apart from refpolicy, and whatever policy you create is free to define and use macros for convenience (hence interfaces). Reference policy is just a specific policy configuration and associated build infrastructure. -- Stephen Smalley National Security Agency -- This message was distributed to subscribers of the selinux mailing list. If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with the words "unsubscribe selinux" without quotes as the message.