public inbox for linux-xfs@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] Use the incore inode size in xfs_file_readdir()
@ 2008-12-04  6:59 Lachlan McIlroy
  2008-12-04  7:08 ` Christoph Hellwig
  0 siblings, 1 reply; 4+ messages in thread
From: Lachlan McIlroy @ 2008-12-04  6:59 UTC (permalink / raw)
  To: xfs-oss

We should be using the incore inode size here not the linux inode
size.  The incore inode size is always up to date for directories
whereas the linux inode size is not updated for directories.

We've hit assertions in xfs_bmap() and traced it back to the linux
inode size being zero here but the incore size being correct.

--- xfs-fix.orig/fs/xfs/linux-2.6/xfs_file.c
+++ xfs-fix/fs/xfs/linux-2.6/xfs_file.c
@@ -254,7 +254,7 @@ xfs_file_readdir(
  	 * point we can change the ->readdir prototype to include the
  	 * buffer size.
  	 */
-	bufsize = (size_t)min_t(loff_t, PAGE_SIZE, inode->i_size);
+	bufsize = (size_t)min_t(loff_t, PAGE_SIZE, ip->i_d.di_size);

  	error = xfs_readdir(ip, dirent, bufsize,
  				(xfs_off_t *)&filp->f_pos, filldir);

_______________________________________________
xfs mailing list
xfs@oss.sgi.com
http://oss.sgi.com/mailman/listinfo/xfs

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2008-12-17 14:20 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-12-04  6:59 [PATCH] Use the incore inode size in xfs_file_readdir() Lachlan McIlroy
2008-12-04  7:08 ` Christoph Hellwig
2008-12-05  3:22   ` Lachlan McIlroy
2008-12-17 14:20     ` Christoph Hellwig

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox