Linux solved the problem by introducing a new flag for {msg,shm,sem}ctl(3)
interfaces (IPC_64), which if set tells the kernel that user supplies
new version of the structure. The kernel itself internally keeps all
relevant information already in IPC_64 format, doing conversion before
returning it to user if IPC_64 isn't set. I think that for portability
reasons we should at least consider the same or similar route.

-Maxim


On Mon, Oct 14, 2002 at 01:27:57PM -0400, Robert Watson wrote:
> Yeah, this is a Known Problem, and it's quite unfortunate, actually.  I
> looked at trying to solve it -- changing the types respectively to uid_t,
> gid_t, and mode_t, but it involved a lot of ABI munging because the
> structures are shared between the userland interface and the kernel
> implementation.  The result is that any change in the kernel structure
> really requires you to break out the user structures from the kernel
> structure, which requires a lot of work.  Also, ipc_perm is shared between
> all three SysVIPC services, and to compound things, there are already
> ofoo() interfaces for older versions of the structures.  My belief is that
> seperating the user and kernel structures is really necessary -- making a
> kipc_perm, etc, so we can better support fine-grained locking and
> extensible security.  However, someone has to do the grunt work, and last
> time I tried, I spent several days and only made a bit of progress.  If
> you want to give a first pass at breaking out the user and kernel
> structures and send a patch, I'll be happy to work with you to get it
> integrated.  I think the steps are:
> 
> (1) Divorce user and kernel structures for all of the SysVIPC interfaces,
>     and provide functions to map between them as necessary.
> 
> (2) Remove the original compatibility interfaces left over from eons ago
>     (and figure out how many eons ago so we know what ABIs we're finally
>     removing).
> 
> (3) Define new userland versions of necessary structures and create a new
>     set of ofoo() and foo() interfaces based on the change.
> 
> (4) Go back through and dribble the kernel structures with new toys, such
>     as 'struct label', etc.
> 
> Robert N M Watson             FreeBSD Core Team, TrustedBSD Projects
> [EMAIL PROTECTED]      Network Associates Laboratories
> 
> On Mon, 14 Oct 2002, Vladimir B. Grebenschikov,Moscow,408-7227,123-4567,Some-info 
>wrote:
> 
> > 
> > Hi
> > 
> > I have found that SysVIPC functions uses structure with short uid/gid types.
> > 
> > What is valid solution ?
> > 
> > Change types to uid_t/gid_t (but this will broke binary compatibility)
> > Change syscalls to old_* and add new with "right" structures,
> > or something else ?
> > 
> > struct ipc_perm {
> >     ushort  cuid;   /* creator user id */
> >     ushort  cgid;   /* creator group id */
> >     ushort  uid;    /* user id */
> >     ushort  gid;    /* group id */
> >     ushort  mode;   /* r/w permission */
> >     ushort  seq;    /* sequence # (to generate unique msg/sem/shm id) */
> >     key_t   key;    /* user specified msg/sem/shm key */
> > };
> > 
> > --
> > Vladimir B. Grebenschikov
> > [EMAIL PROTECTED], SWsoft, Inc.
> > 
> > To Unsubscribe: send mail to [EMAIL PROTECTED]
> > with "unsubscribe freebsd-arch" in the body of the message
> > 
> 
> 
> To Unsubscribe: send mail to [EMAIL PROTECTED]
> with "unsubscribe freebsd-current" in the body of the message

To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-current" in the body of the message
  • short uid/gid Vladimir B. Grebenschikov,Moscow,408-7227,123-4567,Some-info

Reply via email to