[Date Prev][Date Next] [Thread Prev][Thread Next] [Date Index] [Thread Index]

Re: symlinks with 2.1 kernels



Jason Gunthorpe <jgg@gpu.srv.ualberta.ca> writes:

> Christoph and I tracked this down last sunday. The summary as we see it is
> this:
> -  2.1.8x is no longer posix conforming, chown() attempts to change the 
>    ownership of the target of the link
> -  In 2.1.8x there is a new function call called lchown in the kernel 
>    that did NOT exist before
> -  The only way to change the ownership of a file is to use lchown()

Eh? Shouldn't that be '... the ownership of a link ...'?

> -  llibc6 currently makes chown = lchown because linux lacked a lchown
>    call
> -  dpkg, tar, chown and others will have to be changed to use the new bsd
>    lchown function
> -  libc6 will have to have special chown functions written that emulate
>    the new behavior on older kernels, most importantly providing a cover
>    for lchown that calls chown in the case where there is no lchown kernel
>    call.
> 
> BSD uses this 'new' system and claims it is posix conforming, but
> apparently the posix draft is a bit ambiguos. I think the lack of a lchown
> function in posix implies they intended you to use chown on symlinks.

BSD isn't alone here. Solaris (and every other SVR4 system I've ever used)
has been doing this for ages.

-- 
Stephen
---
"Normality is a statistical illusion." -- me


--
TO UNSUBSCRIBE FROM THIS MAILING LIST: e-mail the word "unsubscribe" to
debian-devel-request@lists.debian.org . 
Trouble?  e-mail to templin@bucknell.edu .


Reply to: