Whamcloud - gitweb
LU-6091 llite: glimpse the inode before doing fiemap 39/13439/2
authorLi Dongyang <dongyang.li@anu.edu.au>
Thu, 8 Jan 2015 00:02:24 +0000 (11:02 +1100)
committerOleg Drokin <oleg.drokin@intel.com>
Mon, 26 Jan 2015 19:30:35 +0000 (19:30 +0000)
For a new inode, the i_size is 0 until a stat, which will yield
an empty fiemap result.
Fix the issue by glimpsing the size before doing fiemap.

Lustre-commit: 4b983ad104310d6e67d22e42b057085cc9122604
Lustre-change: http://review.whamcloud.com/13280

Signed-off-by: Li Dongyang <dongyang.li@anu.edu.au>
Signed-off-by: Bob Glossman <bob.glossman@intel.com>
Reviewed-by: Andreas Dilger <andreas.dilger@intel.com>
Reviewed-by: Jinshan Xiong <jinshan.xiong@intel.com>
Change-Id: I072fd1f5e13c7fd127199a10b44366aed145b8e1
Reviewed-on: http://review.whamcloud.com/13439
Tested-by: Jenkins
Tested-by: Maloo <hpdd-maloo@intel.com>
Reviewed-by: Oleg Drokin <oleg.drokin@intel.com>
lustre/llite/file.c

index 46db441..6a9c0d4 100644 (file)
@@ -1837,6 +1837,12 @@ static int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap,
        fm_key.oa.o_oi = lsm->lsm_oi;
         fm_key.oa.o_valid = OBD_MD_FLID | OBD_MD_FLGROUP;
 
+       if (i_size_read(inode) == 0) {
+               rc = ll_glimpse_size(inode);
+               if (rc)
+                       GOTO(out, rc);
+       }
+
         obdo_from_inode(&fm_key.oa, inode, OBD_MD_FLSIZE);
         obdo_set_parent_fid(&fm_key.oa, &ll_i2info(inode)->lli_fid);
         /* If filesize is 0, then there would be no objects for mapping */