On Tue, 2012-09-18 at 10:54 -0700, William Roberts wrote: > Actually on second thought, lets ditch the version. Either your have a > supported version or not, and if you don't have a supported version > you've done something very wrong, and can extract dmesg and use > libsepol on the host to solve your problem. I would imagine dmesg > would have "cannot load policy error" and libsepol on the host could > tell your version number. The reason for the version number suffix is so that you can have multiple versions installed simultaneously for different kernels, allowing you to install a new version for a new kernel yet still back out to the old version/old kernel if necessary. If we do drop the version suffix, do we do it only for the /data/system/sepolicy or also for /sepolicy? Requires a coordinated change across external/sepolicy and external/libselinux (and for 4.0.4, system/core since it still has the old policy loading logic directly within init). Also, do we continue to force the policy version to 24 in external/sepolicy Android.mk or let it go with whatever checkpolicy supports. We were capping it at policy.24 because that is the least common denominator for all of the AOSP kernels (going back to the emulator kernel), and because that was the latest version supported by Ubuntu 10.04 (but that doesn't matter now that there is a copy of checkpolicy in AOSP, which we might want to get updated btw). > On Tue, Sep 18, 2012 at 10:46 AM, William Roberts > <bill.c.roberts@xxxxxxxxx> wrote: > How hard is it to parse the header, is it a simple fixed with > field? > > > I could go either way on this, I like have the version number > in the file name myself. > > > On Tue, Sep 18, 2012 at 10:33 AM, Stephen Smalley > <sds@xxxxxxxxxxxxx> wrote: > On Wed, 2012-07-11 at 15:49 -0400, Stephen Smalley > wrote: > > On Wed, 2012-07-11 at 15:45 -0400, Joshua Brindle > wrote: > > > Stephen Smalley wrote: > > > > On Tue, 2012-07-10 at 20:07 -0400, Joshua > Brindle wrote: > > > >> I was looking at this: > > > >> > <https://android-review.googlesource.com/#/c/36321/4/init/init.c> > > > >> > > > >> and remembered that years ago we had a > discussion about the .policyver > > > >> filename syntax. I kind of get it for SELinux > machines where there is > > > >> managed policy and could be multiple policies > on the system but since > > > >> SEAndroid is targeting non-device managed > policies, it adds extra code > > > >> to search for the right extension and you can > tell what version the > > > >> policy is as soon as you open it, why not ditch > the suffix? > > > > > > > > First, that patch doesn't introduce the use of > the version suffix > > > > (that's in the already merged code); it just > preserves it in the new > > > > logic for reloading policy at runtime. > > > > > > I know, it just reminded me that I wanted to > mention it :) > > > > > > > > > > > I'm open to removing the use of the policy > version suffix in a follow-on > > > > patch, although that would need to be > coordinated across sepolicy and > > > > system/core. But the current code is consistent > with existing practice > > > > in Linux distributions (so follows principle of > least surprise) and it > > > > > > From what I can tell most people doing anything > with SEAndroid have never been > > > exposed to SELinux so it probably is surprising to > them that the file extension > > > would change version to version. > > > > > > > allows for different versions to be installed > simultaneously (thereby > > > > supporting booting multiple kernels). Also, we > don't have libsepol on > > > > > > I don't think this will ever be an issue on mobile > devices (and I don't think it > > > ever was an issue on real machines, more likely > that stale policies were being > > > enforced if there was some kernel or library > change) > > > > > > > the device so we cannot in fact determine the > version when we open it > > > > there presently. So I'm not convinced we should > remove the suffix. > > > > > > We don't need libsepol, just read the first few > bytes, a la file. > > > > We need libsepol at least if we want to support > automatic downgrading of > > the policy to a version supported by the kernel. So > unless we think we > > can guarantee that Android userspace + kernel are > always updated in > > lock-step and one will never want to support > multiple kernels, it seems > > a bit inflexible to drop the versioning. > > > So this issue has come up again in the context of > implementing device > admin APIs and a sample device admin app. The device > admin API > implementation in the system_server needs to know how > to name the file > it creates under /data/system for the kernel policy, > but it has no way > to determine the actual policy version of the supplied > policy. So it > doesn't know what suffix to use. Options: > - Get rid of the version suffix altogether, or at > least for the sepolicy > file under /data/system. > - Have the system_server parse the header of the > policy image to > determine the policy version, and use that as the > suffix. > > Thoughts? > > -- > Stephen Smalley > National Security Agency > > > > > > > -- > Respectfully, > > William C Roberts > > > > > > > > -- > Respectfully, > > William C Roberts > > > -- 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.