Joshua Brindle wrote:
KaiGai Kohei wrote:
In addition, I found two more potential matter in this code.
Sorry, I also found both of them derived from my code misreading. :(
The first one is lack of checks for permissions via attribute.
When a child domain has an attribute which does not applied
to the parent one, the child can have wider permissions that
its parent.
I think any attribute attached to child domain also have to
be attached to the parent domain.
(I guess it derived from legacy attribute implementation.)
Hierarchy.c:409, expand_avtab will expand all attribute usage into the
avtab. We don't care about attribute usage, only about net permissions
granted.
I understood. The expand_avtab_node() callback indeed expand all
attributes before hierarchy checks.
BTW, is it really needed to expand attributes to check hierarchy
relationship?
I think that comparison for attribute ebitmaps can detect hierarchy
violation between parent and children. In other word, this constraint
can be rewritten as "as attribute of child type has to be attached to
the parent type".
It is also useful to detect privileged attribute like mcssetcats.
The later one is dependencies to the state of boolean.
Hierarchy constraint allows a child domain to have
permissions which are enabled for the parent, only if
specific boolean is turned on. It potentially makes a
situation that child domain has wider permissions.
I think it is difficult to check in the policy toolchain, so
checks on an avc entry creation is better way.
We don't consider the state of booleans when doing analysis of the
policy. The idea was that the avtab is the maximum permissions allowed
and we always test on the maximum permissions. Whether a boolean may
reduce the parents permissions without doing so to the child I think is
a non-issue. Do you have an example of why this might be detrimental?
It was also my code misreading. Please forget it.
I seemed to me check_avtab_hierarchy_callback() compared unconditional
permissions and conditional one, but this callback is invoked with
NULL of opt_cond_list for unconditional one.
I confirmed the following policy makes hierarchy violation.
type smbd_t.user;
allow smbd_t.user user_home_t : file { getattr read };
[root@fedora9 ~]# make -f /usr/share/selinux/devel/Makefile
Compiling targeted foo module
/usr/bin/checkmodule: loading policy configuration from tmp/foo.tmp
/usr/bin/checkmodule: policy configuration loaded
/usr/bin/checkmodule: writing binary representation (version 8) to tmp/foo.mod
Creating targeted foo.pp policy package
rm tmp/foo.mod.fc tmp/foo.mod
[root@fedora9 ~]# semodule -i foo.pp
libsepol.check_avtab_hierarchy_callback: hierarchy violation between types smbd_t.user and user_home_t : file { read getattr }
libsepol.hierarchy_check_constraints: 1 total errors found during hierarchy check
libsemanage.semanage_expand_sandbox: Expand module failed
semodule: Failed!
Thanks,
--
OSS Platform Development Division, NEC
KaiGai Kohei <kaigai@xxxxxxxxxxxxx>
--
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.