<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">
From: Kirill Korotaev &lt;dev@sw.ru&gt;

I found another bug in invalidate_inodes-speedup.patch
introduced by WLI when doing forward porting:

-			list_del(&amp;inode-&gt;i_list);
+			list_del(&amp;inode-&gt;i_sb_list);

first list_del should be kept!!!

Patch fixing this issue and hugetlbfs is attached.



 25-akpm/fs/hugetlbfs/inode.c |    2 ++
 25-akpm/fs/inode.c           |    1 +
 2 files changed, 3 insertions(+)

diff -puN fs/hugetlbfs/inode.c~invalidate_inodes-speedup-fixes-2 fs/hugetlbfs/inode.c
--- 25/fs/hugetlbfs/inode.c~invalidate_inodes-speedup-fixes-2	Wed Oct 22 12:17:11 2003
+++ 25-akpm/fs/hugetlbfs/inode.c	Wed Oct 22 12:17:11 2003
@@ -194,6 +194,7 @@ static void hugetlbfs_delete_inode(struc
 
 	hlist_del_init(&amp;inode-&gt;i_hash);
 	list_del_init(&amp;inode-&gt;i_list);
+	list_del_init(&amp;inode-&gt;i_sb_list);
 	inode-&gt;i_state |= I_FREEING;
 	inodes_stat.nr_inodes--;
 	spin_unlock(&amp;inode_lock);
@@ -236,6 +237,7 @@ static void hugetlbfs_forget_inode(struc
 	hlist_del_init(&amp;inode-&gt;i_hash);
 out_truncate:
 	list_del_init(&amp;inode-&gt;i_list);
+	list_del_init(&amp;inode-&gt;i_sb_list);
 	inode-&gt;i_state |= I_FREEING;
 	inodes_stat.nr_inodes--;
 	spin_unlock(&amp;inode_lock);
diff -puN fs/inode.c~invalidate_inodes-speedup-fixes-2 fs/inode.c
--- 25/fs/inode.c~invalidate_inodes-speedup-fixes-2	Wed Oct 22 12:17:11 2003
+++ 25-akpm/fs/inode.c	Wed Oct 22 12:17:11 2003
@@ -302,6 +302,7 @@ static int invalidate_list(struct list_h
 		invalidate_inode_buffers(inode);
 		if (!atomic_read(&amp;inode-&gt;i_count)) {
 			hlist_del_init(&amp;inode-&gt;i_hash);
+			list_del(&amp;inode-&gt;i_list);
 			list_del(&amp;inode-&gt;i_sb_list);
 			list_add(&amp;inode-&gt;i_list, dispose);
 			inode-&gt;i_state |= I_FREEING;

_
</pre></body></html>