Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

kill spurious reference to vmtruncate

Lots of filesystems calls vmtruncate despite not implementing the old
->truncate method. Switch them to use simple_setsize and add some
comments about the truncate code where it seems fitting.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Nick Piggin <npiggin@suse.de>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>

authored by

npiggin@suse.de and committed by
Al Viro
15c6fd97 7bb46a67

+37 -22
+2 -1
fs/adfs/inode.c
··· 322 322 if (error) 323 323 goto out; 324 324 325 + /* XXX: this is missing some actual on-disk truncation.. */ 325 326 if (ia_valid & ATTR_SIZE) 326 - error = vmtruncate(inode, attr->ia_size); 327 + error = simple_setsize(inode, attr->ia_size); 327 328 328 329 if (error) 329 330 goto out;
+2 -2
fs/ecryptfs/inode.c
··· 805 805 - (ia->ia_size & ~PAGE_CACHE_MASK)); 806 806 807 807 if (!(crypt_stat->flags & ECRYPTFS_ENCRYPTED)) { 808 - rc = vmtruncate(inode, ia->ia_size); 808 + rc = simple_setsize(inode, ia->ia_size); 809 809 if (rc) 810 810 goto out; 811 811 lower_ia->ia_size = ia->ia_size; ··· 830 830 goto out; 831 831 } 832 832 } 833 - vmtruncate(inode, ia->ia_size); 833 + simple_setsize(inode, ia->ia_size); 834 834 rc = ecryptfs_write_inode_size_to_metadata(inode); 835 835 if (rc) { 836 836 printk(KERN_ERR "Problem with "
+7 -1
fs/gfs2/aops.c
··· 700 700 return 0; 701 701 702 702 page_cache_release(page); 703 + 704 + /* 705 + * XXX(hch): the call below should probably be replaced with 706 + * a call to the gfs2-specific truncate blocks helper to actually 707 + * release disk blocks.. 708 + */ 703 709 if (pos + len > ip->i_inode.i_size) 704 - vmtruncate(&ip->i_inode, ip->i_inode.i_size); 710 + simple_setsize(&ip->i_inode, ip->i_inode.i_size); 705 711 out_endtrans: 706 712 gfs2_trans_end(sdp); 707 713 out_trans_fail:
+4 -1
fs/gfs2/ops_inode.c
··· 1071 1071 return error; 1072 1072 } 1073 1073 1074 + /* 1075 + * XXX: should be changed to have proper ordering by opencoding simple_setsize 1076 + */ 1074 1077 static int setattr_size(struct inode *inode, struct iattr *attr) 1075 1078 { 1076 1079 struct gfs2_inode *ip = GFS2_I(inode); ··· 1084 1081 error = gfs2_trans_begin(sdp, 0, sdp->sd_jdesc->jd_blocks); 1085 1082 if (error) 1086 1083 return error; 1087 - error = vmtruncate(inode, attr->ia_size); 1084 + error = simple_setsize(inode, attr->ia_size); 1088 1085 gfs2_trans_end(sdp); 1089 1086 if (error) 1090 1087 return error;
+2 -2
fs/jffs2/fs.c
··· 169 169 mutex_unlock(&f->sem); 170 170 jffs2_complete_reservation(c); 171 171 172 - /* We have to do the vmtruncate() without f->sem held, since 172 + /* We have to do the simple_setsize() without f->sem held, since 173 173 some pages may be locked and waiting for it in readpage(). 174 174 We are protected from a simultaneous write() extending i_size 175 175 back past iattr->ia_size, because do_truncate() holds the 176 176 generic inode semaphore. */ 177 177 if (ivalid & ATTR_SIZE && inode->i_size > iattr->ia_size) { 178 - vmtruncate(inode, iattr->ia_size); 178 + simple_setsize(inode, iattr->ia_size); 179 179 inode->i_blocks = (inode->i_size + 511) >> 9; 180 180 } 181 181
+6 -2
fs/ocfs2/file.c
··· 1052 1052 } 1053 1053 1054 1054 /* 1055 - * This will intentionally not wind up calling vmtruncate(), 1055 + * This will intentionally not wind up calling simple_setsize(), 1056 1056 * since all the work for a size change has been done above. 1057 1057 * Otherwise, we could get into problems with truncate as 1058 1058 * ip_alloc_sem is used there to protect against i_size ··· 2118 2118 * direct write may have instantiated a few 2119 2119 * blocks outside i_size. Trim these off again. 2120 2120 * Don't need i_size_read because we hold i_mutex. 2121 + * 2122 + * XXX(hch): this looks buggy because ocfs2 did not 2123 + * actually implement ->truncate. Take a look at 2124 + * the new truncate sequence and update this accordingly 2121 2125 */ 2122 2126 if (*ppos + count > inode->i_size) 2123 - vmtruncate(inode, inode->i_size); 2127 + simple_setsize(inode, inode->i_size); 2124 2128 ret = written; 2125 2129 goto out_dio; 2126 2130 }
+1 -1
fs/smbfs/inode.c
··· 714 714 error = server->ops->truncate(inode, attr->ia_size); 715 715 if (error) 716 716 goto out; 717 - error = vmtruncate(inode, attr->ia_size); 717 + error = simple_setsize(inode, attr->ia_size); 718 718 if (error) 719 719 goto out; 720 720 refresh = 1;
+8 -5
fs/ubifs/file.c
··· 967 967 * the page locked, and it locks @ui_mutex. However, write-back does take inode 968 968 * @i_mutex, which means other VFS operations may be run on this inode at the 969 969 * same time. And the problematic one is truncation to smaller size, from where 970 - * we have to call 'vmtruncate()', which first changes @inode->i_size, then 970 + * we have to call 'simple_setsize()', which first changes @inode->i_size, then 971 971 * drops the truncated pages. And while dropping the pages, it takes the page 972 - * lock. This means that 'do_truncation()' cannot call 'vmtruncate()' with 972 + * lock. This means that 'do_truncation()' cannot call 'simple_setsize()' with 973 973 * @ui_mutex locked, because it would deadlock with 'ubifs_writepage()'. This 974 974 * means that @inode->i_size is changed while @ui_mutex is unlocked. 975 + * 976 + * XXX: with the new truncate the above is not true anymore, the simple_setsize 977 + * calls can be replaced with the individual components. 975 978 * 976 979 * But in 'ubifs_writepage()' we have to guarantee that we do not write beyond 977 980 * inode size. How do we do this if @inode->i_size may became smaller while we ··· 1128 1125 budgeted = 0; 1129 1126 } 1130 1127 1131 - err = vmtruncate(inode, new_size); 1128 + err = simple_setsize(inode, new_size); 1132 1129 if (err) 1133 1130 goto out_budg; 1134 1131 ··· 1217 1214 1218 1215 if (attr->ia_valid & ATTR_SIZE) { 1219 1216 dbg_gen("size %lld -> %lld", inode->i_size, new_size); 1220 - err = vmtruncate(inode, new_size); 1217 + err = simple_setsize(inode, new_size); 1221 1218 if (err) 1222 1219 goto out; 1223 1220 } ··· 1226 1223 if (attr->ia_valid & ATTR_SIZE) { 1227 1224 /* Truncation changes inode [mc]time */ 1228 1225 inode->i_mtime = inode->i_ctime = ubifs_current_time(inode); 1229 - /* 'vmtruncate()' changed @i_size, update @ui_size */ 1226 + /* 'simple_setsize()' changed @i_size, update @ui_size */ 1230 1227 ui->ui_size = inode->i_size; 1231 1228 } 1232 1229
+1 -1
fs/ubifs/ubifs.h
··· 379 379 * The @ui_size is a "shadow" variable for @inode->i_size and UBIFS uses 380 380 * @ui_size instead of @inode->i_size. The reason for this is that UBIFS cannot 381 381 * make sure @inode->i_size is always changed under @ui_mutex, because it 382 - * cannot call 'vmtruncate()' with @ui_mutex locked, because it would deadlock 382 + * cannot call 'simple_setsize()' with @ui_mutex locked, because it would deadlock 383 383 * with 'ubifs_writepage()' (see file.c). All the other inode fields are 384 384 * changed under @ui_mutex, so they do not need "shadow" fields. Note, one 385 385 * could consider to rework locking and base it on "shadow" fields.
+4 -6
fs/ufs/truncate.c
··· 501 501 return err; 502 502 } 503 503 504 - 505 504 /* 506 - * We don't define our `inode->i_op->truncate', and call it here, 507 - * because of: 508 - * - there is no way to know old size 509 - * - there is no way inform user about error, if it happens in `truncate' 505 + * TODO: 506 + * - truncate case should use proper ordering instead of using 507 + * simple_setsize 510 508 */ 511 509 int ufs_setattr(struct dentry *dentry, struct iattr *attr) 512 510 { ··· 528 530 if (ia_valid & ATTR_SIZE && attr->ia_size != inode->i_size) { 529 531 loff_t old_i_size = inode->i_size; 530 532 531 - error = vmtruncate(inode, attr->ia_size); 533 + error = simple_setsize(inode, attr->ia_size); 532 534 if (error) 533 535 return error; 534 536 error = ufs_truncate(inode, old_i_size);