Re: [PATCH] Re: ENOATTR and other error enums

Nathan Scott (nathans@sgi.com)
Tue, 9 Oct 2001 23:31:59 +1000


hi Alan,

Thanks for the comments.

On Tue, Oct 09, 2001 at 01:37:55PM +0100, Alan Cox wrote:
> > XFS needs both values. ENOATTR is also required by the ext2
> > extended attributes project (and any other filesystem intending
> > to implement extended attributes in the future). Both values
> > need to be visible in both kernel and user space, so this patch
> > would be an initial step toward libc support also, hopefully.
> >
> > In the absence of any cleaner way to do this (?), could we have
> > this patch applied please? Any/all feedback much appreciated
>
> Such an update needs to be synchronized with glibc to avoid people
> getting all sorts of odd "unknown" error messages.

Yup, understood. I was punting that it would need to appear
in the kernel headers first though, so thought I'd test the
water with you guys and try to understand the process for such
a change.

The "unknown error" messages can't really be avoided in all cases
anyway - even when there is a coordinated libc release there will
always be (the vast majority of?) people running new kernels with
older libc versions for awhile ... thats life though, I guess, if
there's no other solution to the problem.

> In general I dn't see why its needed.

For ENOATTR, an error code is needed which doesn't conflict
with any other used in the filesystem, so that a failure to
get/set/... an extended attribute can be distinguished from
other errors related to looking up the pathname initially,
as an example.

> > > EFSCORRUPTED = Filesystem is corrupted
>
> EIO is normally used for this

Yeah, the semantics here are slightly different, but perhaps we
can get away with this... (Steve? do you know of any cases in
the code where we need to be able to distinguish the EIO value
from EFSCORRUPTED? or any other reason why this wouldn't work?
It is the obvious one - I'd imagine there was a reason for not
using it originally).

> As to the string names for errors. They can't sanely go into the kernel
> or kernel headers.

Yes, that wasn't being suggested.

> Remember there are a lot of languages out there

Yup - understood.

thanks.

-- 
Nathan
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/