cvs commit: src/sys/kern vfs_subr.c src/sys/fs/devfs
devfs_vnops.c
Scott Long
scottl at samsco.org
Thu Nov 10 06:55:07 PST 2005
Poul-Henning Kamp wrote:
> In message <437351BB.6000103 at samsco.org>, Scott Long writes:
>
>
>>Putting the cookie into the dirent means either changing the size of the
>>dirent struct and breaking the userland ABI (almost as bad as changing
>>the size of stat, but not quite), or making a 'kdirent' struct and then
>>manually shifting and copying it to a dirent struct.
>
>
> Not really that bad.
>
> My idea was to make a
> struct kdirent {
> struct dirent foo;
> cookie stuff bar;
> }
>
> Filesystems would call vfs_read_dirent() with a struct kdirent and
> depending on the userland/kernel flag in the uio vfs_read_dirent()
> would copy either the entire kdirent or only the userspace dirent.
>
>
>
>>What I really think this is is a ploy by PHK to get someone motivated to
>>fix it for him ;-)
>
>
> I'm generally in favour of people doing work so I don't have to but
> in this particular case that was not the motivation :-)
>
> (At least you can't prove anything!)
>
> Poul-Henning
>
I still don't see how this is supposed to work. VOP_READDIR() doesn't
return the dirent array to the caller, it's directly copied to the user
buffer.
Scott
More information about the cvs-all
mailing list