On Wed, 16 Oct 2002, Terry Lambert wrote:

> Robert Watson wrote:
> > I'm not convinced there's any value to providing the backward
> > compatibility that has to be asked for: the only benefit to the current
> > short-based API is that it allow serious security holes while not
> > following the standard API offered by other platforms (except Linux).
> 
> The main benefit, to my mind, is standards compliance.  The secondary
> benefit is ABI similarity for the purposes of supporting ABIs to run
> non-native software (e.g. Linux prior to 2.4). 

Could you point me at the standard that indicates these fields should be
shorts?  We're all advocating switching to uid_t/gid_t/id_t here, the only
question is with regard to compatibility.  Platforms such as Solaris
already use uid_t/gid_t for these fields, and we break portable
applications because applications assume that uid_t fits into ipc_perm.uid
(for example).

> Binary backward compatability *demands* that you limit the range of your
> UIDs and GIDs to what will fit in a uint16_t, just as the recent issue
> with a pid_t exceeeding this size has damaged binary backward
> compatability with third party a.out binaries. 

This has to do with the size of the field.  uid_t and gid_t are 32-bit on
most relevant platforms, although there are lingering software
compatibility issues (such as the Sysem V IPC issue).  The goal now is to
correct lingering incompatibilities so that we can properly support these
ranges. 

> > Freshly compiled applications should be using the proper types to
> > represent uid's and gid's -- if they're not doing that in the existing
> > code, they'll get truncated to the right size for "bug compatibility".  If
> > they are using the correct size, they'll work correctly.  To be able to
> > run properly on other platforms (vis Solaris), they already should be
> > using those types.
> 
> Truncating of oversized values for credentials is Bad(tm), in that what
> you get is a different credential.  The constraint has to be a priori
> enforced, or it's meaningless.

I think we're in agreement here.  Unfortunately, because of the "short" 
uid/gid/cuid/cgid fields, truncation is *already* happening.  That's what
we're trying to fix.  If you try to crush a uid_t into ipc_perm.uid on
FreeBSD, the field is truncated, resulting in a vulnerability.  What
pushing the type checking into the application space does is generate
warnings for applications making bogus assumptions, and corrects the
truncation performed by the kernel in the current scenario.  I.e., when a
SysVIPC shm segment is created by a user with a uid that doesn't fit in
short, the kernel gets it "wrong".  The change we're talking about will
fix the kernel, and make type problems visible to the applications if they
make incorrect assumptions.  Of course, past applications assuming 16-bit
uids and gids will still be wrong, nothing changes that, but we do fix
current applications.

> > And it's not like the approach you've described makes it any easier to
> > implement: you still have to break out the old and new structures since
> > changing ipc_perm breaks the ABI for all of the System V interfaces,
> > rewrite the kernel code, etc. You might as well have added the
> > compatibility system calls since you still have to do all the mapping.
> 
> His approach avoids the proliferation of system call entry points, which
> may conflict with those of other BSDs (among other things).  BSDI
> limited the number of available additional FreeBSD system calls in a
> standardization effort a while back, if you'll remember, so a
> proliferation of calls is Bad.  In addition, the compatability required
> this proliferation going forward.

I suspect that this may end up being a red herring.  You do realize that
OpenBSD and NetBSD have *already* made precisely the change I am
describing?  Here's the exerpt from OpenBSD's ipc.h:

struct ipc_perm {
        uid_t           cuid;   /* creator user id */
        gid_t           cgid;   /* creator group id */
        uid_t           uid;    /* user id */
        gid_t           gid;    /* group id */
        mode_t          mode;   /* r/w permission */
        unsigned short  seq;    /* sequence # (to generate unique
msg/sem/shm id) */
        key_t           key;    /* user specified msg/sem/shm key */
};

#ifdef _KERNEL
struct oipc_perm {
        unsigned short  cuid;   /* creator user id */
        unsigned short  cgid;   /* creator group id */
        unsigned short  uid;    /* user id */
        unsigned short  gid;    /* group id */
        unsigned short  mode;   /* r/w permission */
        unsigned short  seq;    /* sequence # (to generate unique
msg/sem/shm id) */
        key_t           key;    /* user specified msg/sem/shm key */
};
#endif

We're *improve* our compatibility with other BSD platforms by making these
changes.

> FWIW, I would agree with you, if you were advocating a cross-OS ABI
> definition of manifest constants, so that FreeBSD's new ABI, and, say,
> Solaris or Linux's ABI, were more congruent (you could get this without
> a new sstem call vector entry point, by using a different "ELF brand"
> value), but that's not what you are advocating. 

I'm advocating we adopt pretty much the ABI for these calls that Solaris
uses.  If you inspect their ipc.h, you'll see that they define two
versions of the structure, ipc_perm, and ipc_perm32.  ipc_perm is the
version that makes use of types such as uid_t and gid_t; ipc_perm32
hard-codes these fields to 32-bit and can be used for compatibility.

> Also FWIW, my personal preference would be to follow the Solaris ABI; 
> it's the least volatile of all ABI's in this area.  In terms of the
> available applications, Linux is probably a better choice, but in terms
> of the amount of maintenance work required, Solaris is far and away the
> leader. 

We already have the SysVIPC wrappers for the Linux code, but those are
actually broken because they don't take into account our truncation bugs.

Robert N M Watson             FreeBSD Core Team, TrustedBSD Projects
[EMAIL PROTECTED]      Network Associates Laboratories


To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-current" in the body of the message

Reply via email to