Pavel Emelyanov <xemul@openvz.org> writes:The cause is totally different this time, and is not limited to /proc/net. But this is the only side effect of the changes now. I used the one line version of your test program to confirm this: $ cd /proc/driver/ $ ls -l /proc/self/fd/100 100< . lr-x------ 1 eric eric 64 Nov 27 05:06 /proc/self/fd/100 -> /proc/driver/ $ ls -l /proc/self/fd/100 100< . lr-x------ 1 eric eric 64 Nov 27 05:07 /proc/self/fd/100 -> /proc/driver (deleted) What is happening is that the aggressive non-caching logic is dropping the dentries and thus they show up as deleted. I.e. When something triggers another lookup of that dentry revalidate drops the old dentry. This actually fixes a race in /proc today where if you open a file, remove the module for it, reload the module for that file, and then attempt to access it, lookup will return the old dentry with the old fops (even if there is not a current version of that file). kill_proc_inodes current keeps us from using the old version of the file_operations for directories (because it removes them) but it does not prevent this DOS attack where keeping a proc file open always ensures everyone will see the old version. Given that the behavior seems more correct then what we have currently I can live with files showing up as deleted from time to time. Ultimately the fix is to correct the caching logic in fs/proc/generic.c to only drop dentries when necessary and then the deleted markers will only show up when the file or directory really goes away. I don't expect user space will care about the semi-legitimate (deleted) marks. So I don't think this one down side will be a big deal for 2.6.24. Eric -
| Jan Engelhardt | intel iommu (Re: -mm merge plans for 2.6.23) |
| Greg Kroah-Hartman | [PATCH 001/196] Chinese: Add the known_regression URI to the HOWTO |
| Linus Torvalds | Linux 2.6.25-rc4 |
| Jon Smirl | Re: 463 kernel developers missing! |
git: | |
| Gerrit Renker | [PATCH 27/37] dccp: Integration of dynamic feature activation - part 2 (server side) |
| David Miller | [GIT]: Networking |
| Jarek Poplawski | Re: HTB accuracy for high speed |
| David Miller | Re: [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock(). |
