On 4/1/13 1:17 PM, Theodore Ts'o wrote: > On Mon, Apr 01, 2013 at 10:33:41AM -0500, Eric Sandeen wrote: >> + /* Have we already started readdir on this dx dir? */ >> + if (filp->private_data) { >> + err = -EINVAL; >> + goto hash32bits_out; >> + } > > I'm not sure how much we care, but if filp->private_data is non-NULL > and filp->f_pos == 0, then the application must have called > rewinddir(), and at that point it would be fair game for us to free > the rb_tree (see the code in ext4_dx_readdir() just after the comment > "Some one has messed with f_pos; reset the world".) Hm, I originally tested f_pos == 0, and Zach thought that wasn't the right test, suggested f_private, and that seemed right to me, but yeah, I suppose !f_pos && f_private means it got rewound. > This would allow a bit more flexibility than just requiring that the > ioctl be issued just after the opendir(), and allow it just after a > call to rewinddir(). I guess I do wonder what real-world use that might have, though. > This this would invalidate any previously issued telldir() cookies, > but according to SuSv3, telldir() cookies are not guaranteed to be > consistent after a rewinddir() or a closedir(), so it would be > standards compliant to do this. Well, could do. Think it's worth it? If so, then we could also allow flipping the flag on and off. I suppose it's good to get the interface right to start with; if we really want to be able to flip it on and off after a rewinddir, then . . . ok, V4? It's more flexible, but I don't know what the usecase might be. -Eric > - Ted > -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html