Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 22 Dec 2004 12:13:14 -0600
From:      "Matthew D. Fuller" <fullermd@over-yonder.net>
To:        Poul-Henning Kamp <phk@phk.freebsd.dk>
Cc:        FreeBSD Architecture Mailing List <arch@freebsd.org>
Subject:   Re: Header files with enums instead of defines?
Message-ID:  <20041222181313.GJ32388@over-yonder.net>
In-Reply-To: <8412.1103737516@critter.freebsd.dk>
References:  <20041222010143.GS53357@wantadilla.lemis.com> <8412.1103737516@critter.freebsd.dk>

next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, Dec 22, 2004 at 06:45:16PM +0100 I heard the voice of
Poul-Henning Kamp, and lo! it spake thus:
> 
> One of my pet peeves is that comples system calls have no way to
> convey additional information about why the return a given return
> value like EPERM.
> 
> I would almost advocate adding a char[X] to each thread and a system
> call which could retrieve it.  Complex system calls like
> mount/nmount, ioctl and similar could then stick an explanation into
> that string which strerror(3) or err(3) and similar functions could
> pull out and give the user.

I do roughly this in the errno-ish facility in my sadly-dormant
libpostal project.  My error structure looks like

struct postal_errfoo_t
{
    unsigned int    postal_errno;
    char            postal_errstr[POSTAL_ERRSTR_LEN];
};

Of course, I get to mandate that you use postal_errno() and
postal_errstr() to retrieve the data.  I use (1<<15) as a flag in the
errno int (at least, until I get a WHOLE lot more error conditions
that I have now) for when there's an extra message to be returned.  I
don't think I actually USE the capability anywhere right now, but it's
designed in.


-- 
Matthew Fuller     (MF4839)   |  fullermd@over-yonder.net
Systems/Network Administrator |  http://www.over-yonder.net/~fullermd/

"The only reason I'm burning my candle at both ends, is because I
      haven't figured out how to light the middle yet"



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20041222181313.GJ32388>