Hello. Casey Schaufler wrote:TOMOYO Linux has own (non-POSIX) capability that can support 65536 capabilities if there *were* a separate capability for each "if" in the kernel. http://svn.sourceforge.jp/cgi-bin/viewcvs.cgi/trunk/2.1.x/tomoyo-lsm/patches/tomoyo-ca... The reason I don't use POSIX capability is that the maximum types are limited to bitwidth of a variable (i.e. currently 32, or are we going to extend it to 64). This leads to abuse of CAP_SYS_ADMIN capability. In other words, it makes fine-grained privilege division impossible. Since security_capable() cannot receive fine-grained values, TOMOYO can't do fine-grained privilege division. I wish if capability machanism has mapping layer like: #define CAP_DIVIDED_FOO1 0 #define CAP_DIVIDED_FOO2 1 #define CAP_DIVIDED_FOO3 2 ... #define CAP_DIVIDED_BAR1 100 #define CAP_DIVIDED_BAR2 101 #define CAP_DIVIDED_BAR3 102 const int cap_divided_to_grouped(int cap_divided) { static const int cap_mapping_array[] = { /* [divided index value] = POSIX compatible index value (i.e. 0-31) */ [CAP_DIVIDED_FOO1] = 0, [CAP_DIVIDED_FOO2] = 0, [CAP_DIVIDED_FOO3] = 0, [CAP_DIVIDED_BAR1] = 1, [CAP_DIVIDED_BAR2] = 1, [CAP_DIVIDED_BAR3] = 1, }; return cap_mapping_array[cap_divided]; } int capable(int cap_divided) { return security_capable(cap_divided); } int security_capable(int cap_divided) { /* Allow LSM to decide based on fine-grained capability index. */ return LSM_implementation_specific_capability_check(cap_divided_to_grouped(cap_divided)); } int function_foo(void) { if (!capable(CAP_DIVIDED_FOO1)) return -EPERM; return 0; } int function_bar(void) { if (!capable(CAP_DIVIDED_BAR2)) return -EPERM; return 0; } Thanks. -
| Greg Kroah-Hartman | [PATCH 002/196] Chinese: rephrase English introduction in HOWTO |
| Kok, Auke | Re: Linux 2.6.21-rc1 |
| Greg KH | Re: Dual-Licensing Linux Kernel with GPL V2 and GPL V3 |
| Jeff Garzik | Re: [Patch v2] Make PCI extended config space (MMCONFIG) a driver opt-in |
git: | |
| David Miller | [GIT]: Networking |
| Gerrit Renker | [PATCH 15/37] dccp: Set per-connection CCIDs via socket options |
| Jarek Poplawski | [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock(). |
| Eric Dumazet | [PATCH] net: remove superfluous call to synchronize_net() |
