> From: Stephen Smalley [mailto:sds@xxxxxxxxxxxxx] > > On Wed, 2009-09-02 at 09:35 -0400, Joshua Brindle wrote: > > > From: Stephen Smalley [mailto:sds@xxxxxxxxxxxxx] > > > > > > On Tue, 2009-09-01 at 23:35 -0400, Eamon Walsh wrote: > > > > The userspace AVC currently has refcounted SID's. This patch > strips > > > out > > > > the refcounting under the following justifications: > > > > > > > > 1. Managing the refcounts by calling sidput() and sidget() as > > > > appropriate is a difficult and bug-prone task for users of the > > > library. > > > > > > > > 2. The userspace AVC doesn't currently make use of the refcounts > to > > > > reclaim unused SID's unless avc_cleanup() is explicitly called. > > > > > > > > 3. The kernel itself no longer uses refcounting for it's own > SID's. > > > > > > Just to clarify on this point: Early on we had discussed > introducing > > > refcounting of kernel SIDs to enable reclaiming unused ones, but > this > > > became less important once the user/kernel interface was converted > > from > > > passing SIDs to passing security contexts. In that case we were > > > dealing > > > with a global (wrt a system) resource and kernel memory, whereas in > > the > > > userspace AVC we are only dealing with a per-object-manager SID > table > > > and the application's virtual memory. > > > > > > > So is the purpose of the patch just to remove unnecessary > complication > > in the userspace sidtab? Will this affect multithreaded applications > > that share a sidtab? > > Unnecessary complication for the userspace object managers - they no > longer have to keep SID refcounts accurate via sidget() and sidput() > calls when storing SIDs in their data structures. > > No affect on multithreaded apps; they will still work (locking is > unaffected). > > > IIRC sepostgres reimplemented its sidtab and avc because our current > one > > wasn't very friendly to multithread/multiprocess object managers. > > Looking back, I think KaiGai's reasons were: > - he didn't see benefit to the indirection of the AVC SID table since > PostgreSQL has to directly manage security contexts for persistent > labeling, > - he wanted to enable sharing of the AVC (via shared memory) and the > netlink thread among all PostgreSQL instances (processes, not just > threads). > > So I don't think this makes any difference there. > Ok, seems fair. -- 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.