• Home
  • Raw
  • Download

Lines Matching +full:ip +full:- +full:block

1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved.
4 * Copyright (C) 2004-2006 Red Hat, Inc. All rights reserved.
33 * block is 512, so __u16 is fine for that. It saves stack space to
43 static int punch_hole(struct gfs2_inode *ip, u64 offset, u64 length);
46 * gfs2_unstuffer_page - unstuff a stuffed inode into a block cached by a page
47 * @ip: the inode
49 * @block: the block number that was allocated
55 static int gfs2_unstuffer_page(struct gfs2_inode *ip, struct buffer_head *dibh, in gfs2_unstuffer_page() argument
56 u64 block, struct page *page) in gfs2_unstuffer_page() argument
58 struct inode *inode = &ip->i_inode; in gfs2_unstuffer_page()
61 if (!page || page->index) { in gfs2_unstuffer_page()
62 page = find_or_create_page(inode->i_mapping, 0, GFP_NOFS); in gfs2_unstuffer_page()
64 return -ENOMEM; in gfs2_unstuffer_page()
72 memcpy(kaddr, dibh->b_data + sizeof(struct gfs2_dinode), dsize); in gfs2_unstuffer_page()
73 memset(kaddr + dsize, 0, PAGE_SIZE - dsize); in gfs2_unstuffer_page()
79 if (gfs2_is_jdata(ip)) { in gfs2_unstuffer_page()
83 create_empty_buffers(page, BIT(inode->i_blkbits), in gfs2_unstuffer_page()
88 map_bh(bh, inode->i_sb, block); in gfs2_unstuffer_page()
91 gfs2_trans_add_data(ip->i_gl, bh); in gfs2_unstuffer_page()
94 gfs2_ordered_add_inode(ip); in gfs2_unstuffer_page()
106 * gfs2_unstuff_dinode - Unstuff a dinode when the data has grown too big
107 * @ip: The GFS2 inode to unstuff
116 int gfs2_unstuff_dinode(struct gfs2_inode *ip, struct page *page) in gfs2_unstuff_dinode() argument
120 u64 block = 0; in gfs2_unstuff_dinode() local
121 int isdir = gfs2_is_dir(ip); in gfs2_unstuff_dinode()
124 down_write(&ip->i_rw_mutex); in gfs2_unstuff_dinode()
126 error = gfs2_meta_inode_buffer(ip, &dibh); in gfs2_unstuff_dinode()
130 if (i_size_read(&ip->i_inode)) { in gfs2_unstuff_dinode()
131 /* Get a free block, fill it with the stuffed data, in gfs2_unstuff_dinode()
135 error = gfs2_alloc_blocks(ip, &block, &n, 0, NULL); in gfs2_unstuff_dinode()
139 gfs2_trans_remove_revoke(GFS2_SB(&ip->i_inode), block, 1); in gfs2_unstuff_dinode()
140 error = gfs2_dir_get_new_buffer(ip, block, &bh); in gfs2_unstuff_dinode()
147 error = gfs2_unstuffer_page(ip, dibh, block, page); in gfs2_unstuff_dinode()
153 /* Set up the pointer to the new block */ in gfs2_unstuff_dinode()
155 gfs2_trans_add_meta(ip->i_gl, dibh); in gfs2_unstuff_dinode()
156 di = (struct gfs2_dinode *)dibh->b_data; in gfs2_unstuff_dinode()
159 if (i_size_read(&ip->i_inode)) { in gfs2_unstuff_dinode()
160 *(__be64 *)(di + 1) = cpu_to_be64(block); in gfs2_unstuff_dinode()
161 gfs2_add_inode_blocks(&ip->i_inode, 1); in gfs2_unstuff_dinode()
162 di->di_blocks = cpu_to_be64(gfs2_get_inode_blocks(&ip->i_inode)); in gfs2_unstuff_dinode()
165 ip->i_height = 1; in gfs2_unstuff_dinode()
166 di->di_height = cpu_to_be16(1); in gfs2_unstuff_dinode()
171 up_write(&ip->i_rw_mutex); in gfs2_unstuff_dinode()
177 * find_metapath - Find path through the metadata tree
179 * @block: The disk block to look up
181 * @height: The pre-calculated height of the metadata tree
184 * through the metadata of inode "ip" to get to block "block".
187 * Given: "ip" is a height 3 file, "offset" is 101342453, and this is a
193 * That means that in order to get to the block containing the byte at
194 * offset 101342453, we would load the indirect block pointed to by pointer
195 * 0 in the dinode. We would then load the indirect block pointed to by
196 * pointer 48 in that indirect block. We would then load the data block
197 * pointed to by pointer 165 in that indirect block.
199 * ----------------------------------------
204 * ----------------------------------------
208 * ----------------------------------------
209 * | Indirect Block |
213 * ----------------------------------------
217 * ----------------------------------------
218 * | Indirect Block |
222 * ----------------------------------------
226 * ----------------------------------------
227 * | Data block containing offset |
231 * ----------------------------------------
235 static void find_metapath(const struct gfs2_sbd *sdp, u64 block, in find_metapath() argument
240 mp->mp_fheight = height; in find_metapath()
241 for (i = height; i--;) in find_metapath()
242 mp->mp_list[i] = do_div(block, sdp->sd_inptrs); in find_metapath()
247 if (mp->mp_list[0] == 0) in metapath_branch_start()
253 * metaptr1 - Return the first possible metadata pointer in a metapath buffer
259 struct buffer_head *bh = mp->mp_bh[height]; in metaptr1()
261 return ((__be64 *)(bh->b_data + sizeof(struct gfs2_dinode))); in metaptr1()
262 return ((__be64 *)(bh->b_data + sizeof(struct gfs2_meta_header))); in metaptr1()
266 * metapointer - Return pointer to start of metadata in a buffer
270 * Return a pointer to the block number of the next height of the metadata
278 return p + mp->mp_list[height]; in metapointer()
283 const struct buffer_head *bh = mp->mp_bh[height]; in metaend()
284 return (const __be64 *)(bh->b_data + bh->b_size); in metaend()
292 for (hgt = 0; hgt < mp->mp_aheight; hgt++) in clone_metapath()
293 get_bh(clone->mp_bh[hgt]); in clone_metapath()
309 rabh->b_end_io = end_buffer_read_sync; in gfs2_metapath_ra()
321 static int __fillup_metapath(struct gfs2_inode *ip, struct metapath *mp, in __fillup_metapath() argument
331 ret = gfs2_meta_indirect_buffer(ip, x + 1, dblock, &mp->mp_bh[x + 1]); in __fillup_metapath()
335 mp->mp_aheight = x + 1; in __fillup_metapath()
340 * lookup_metapath - Walk the metadata tree to a specific point
341 * @ip: The inode
345 * hooked onto mp->mp_bh[0] and that the metapath has been initialised
350 * at which it found the unallocated block. Blocks which are found are
351 * added to the mp->mp_bh[] list.
356 static int lookup_metapath(struct gfs2_inode *ip, struct metapath *mp) in lookup_metapath() argument
358 return __fillup_metapath(ip, mp, 0, ip->i_height - 1); in lookup_metapath()
362 * fillup_metapath - fill up buffers for the metadata path to a specific height
363 * @ip: The inode
372 static int fillup_metapath(struct gfs2_inode *ip, struct metapath *mp, int h) in fillup_metapath() argument
379 for (x = h - 1; x > 0; x--) { in fillup_metapath()
380 if (mp->mp_bh[x]) in fillup_metapath()
384 ret = __fillup_metapath(ip, mp, x, h); in fillup_metapath()
387 return mp->mp_aheight - x - 1; in fillup_metapath()
392 sector_t factor = 1, block = 0; in metapath_to_block() local
395 for (hgt = mp->mp_fheight - 1; hgt >= 0; hgt--) { in metapath_to_block()
396 if (hgt < mp->mp_aheight) in metapath_to_block()
397 block += mp->mp_list[hgt] * factor; in metapath_to_block()
398 factor *= sdp->sd_inptrs; in metapath_to_block()
400 return block; in metapath_to_block()
408 if (mp->mp_bh[i] == NULL) in release_metapath()
410 brelse(mp->mp_bh[i]); in release_metapath()
411 mp->mp_bh[i] = NULL; in release_metapath()
416 * gfs2_extent_length - Returns length of an extent of blocks
417 * @bh: The metadata block
420 * @eob: Set to 1 if we hit "end of block"
422 * Returns: The length of the extent (minimum of one block)
427 const __be64 *end = (__be64 *)(bh->b_data + bh->b_size); in gfs2_extent_length()
440 return ptr - first; in gfs2_extent_length()
446 * gfs2_metadata_walker - walk an indirect block
447 * @mp: Metapath to indirect block
451 * indirect block to follow.
457 * gfs2_walk_metadata - walk a tree of indirect blocks
470 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_walk_metadata() local
477 * The walk starts in the lowest allocated indirect block, which may be in gfs2_walk_metadata()
481 for (hgt = mp->mp_fheight - 1; hgt >= mp->mp_aheight; hgt--) { in gfs2_walk_metadata()
482 max_len += mp->mp_list[hgt] * factor; in gfs2_walk_metadata()
483 mp->mp_list[hgt] = 0; in gfs2_walk_metadata()
484 factor *= sdp->sd_inptrs; in gfs2_walk_metadata()
488 u16 start = mp->mp_list[hgt]; in gfs2_walk_metadata()
493 /* Walk indirect block. */ in gfs2_walk_metadata()
494 ptrs = (hgt >= 1 ? sdp->sd_inptrs : sdp->sd_diptrs) - start; in gfs2_walk_metadata()
503 BUG_ON(mp->mp_aheight == mp->mp_fheight); in gfs2_walk_metadata()
504 ptrs = mp->mp_list[hgt] - start; in gfs2_walk_metadata()
512 max_len -= len; in gfs2_walk_metadata()
518 brelse(mp->mp_bh[hgt]); in gfs2_walk_metadata()
519 mp->mp_bh[hgt] = NULL; in gfs2_walk_metadata()
520 mp->mp_list[hgt] = 0; in gfs2_walk_metadata()
523 hgt--; in gfs2_walk_metadata()
524 factor *= sdp->sd_inptrs; in gfs2_walk_metadata()
527 (mp->mp_list[hgt])++; in gfs2_walk_metadata()
529 if (mp->mp_list[hgt] >= sdp->sd_inptrs) in gfs2_walk_metadata()
532 if (mp->mp_list[hgt] >= sdp->sd_diptrs) in gfs2_walk_metadata()
538 ret = fillup_metapath(ip, mp, ip->i_height - 1); in gfs2_walk_metadata()
542 for (; ret; ret--) in gfs2_walk_metadata()
543 do_div(factor, sdp->sd_inptrs); in gfs2_walk_metadata()
544 mp->mp_aheight = hgt + 1; in gfs2_walk_metadata()
555 hgt = mp->mp_aheight - 1; in gfs2_hole_walker()
561 mp->mp_list[hgt] += ptr - start; in gfs2_hole_walker()
562 if (mp->mp_aheight == mp->mp_fheight) in gfs2_hole_walker()
571 * gfs2_hole_size - figure out the size of a hole
573 * @lblock: The logical starting block number
595 hole_size = metapath_to_block(GFS2_SB(inode), &clone) - lblock; in gfs2_hole_size()
598 iomap->length = hole_size << inode->i_blkbits; in gfs2_hole_size()
610 __be64 *ptr = (__be64 *)(mp->mp_bh[i - 1]->b_data + in gfs2_indirect_init()
614 BUG_ON(mp->mp_bh[i] != NULL); in gfs2_indirect_init()
615 mp->mp_bh[i] = gfs2_meta_new(gl, bn); in gfs2_indirect_init()
616 gfs2_trans_add_meta(gl, mp->mp_bh[i]); in gfs2_indirect_init()
617 gfs2_metatype_set(mp->mp_bh[i], GFS2_METATYPE_IN, GFS2_FORMAT_IN); in gfs2_indirect_init()
618 gfs2_buffer_clear_tail(mp->mp_bh[i], sizeof(struct gfs2_meta_header)); in gfs2_indirect_init()
632 * gfs2_iomap_alloc - Build a metadata tree of the requested height
650 * Right now, this function will allocate at most one indirect block
651 * worth of data -- with a default block size of 4K, that's slightly
663 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_iomap_alloc() local
665 struct buffer_head *dibh = mp->mp_bh[0]; in gfs2_iomap_alloc()
668 size_t dblks = iomap->length >> inode->i_blkbits; in gfs2_iomap_alloc()
669 const unsigned end_of_metadata = mp->mp_fheight - 1; in gfs2_iomap_alloc()
675 BUG_ON(mp->mp_aheight < 1); in gfs2_iomap_alloc()
679 gfs2_trans_add_meta(ip->i_gl, dibh); in gfs2_iomap_alloc()
681 down_write(&ip->i_rw_mutex); in gfs2_iomap_alloc()
683 if (mp->mp_fheight == mp->mp_aheight) { in gfs2_iomap_alloc()
684 /* Bottom indirect block exists */ in gfs2_iomap_alloc()
688 if (mp->mp_fheight == ip->i_height) { in gfs2_iomap_alloc()
690 iblks = mp->mp_fheight - mp->mp_aheight; in gfs2_iomap_alloc()
695 iblks = mp->mp_fheight - ip->i_height; in gfs2_iomap_alloc()
697 iblks += (mp->mp_fheight - branch_start); in gfs2_iomap_alloc()
704 i = mp->mp_aheight; in gfs2_iomap_alloc()
706 n = blks - alloced; in gfs2_iomap_alloc()
707 ret = gfs2_alloc_blocks(ip, &bn, &n, 0, NULL); in gfs2_iomap_alloc()
711 if (state != ALLOC_DATA || gfs2_is_jdata(ip)) in gfs2_iomap_alloc()
717 ptr = (__be64 *)(dibh->b_data + in gfs2_iomap_alloc()
721 for (; i - 1 < mp->mp_fheight - ip->i_height && n > 0; in gfs2_iomap_alloc()
722 i++, n--) in gfs2_iomap_alloc()
723 gfs2_indirect_init(mp, ip->i_gl, i, 0, bn++); in gfs2_iomap_alloc()
724 if (i - 1 == mp->mp_fheight - ip->i_height) { in gfs2_iomap_alloc()
725 i--; in gfs2_iomap_alloc()
726 gfs2_buffer_copy_tail(mp->mp_bh[i], in gfs2_iomap_alloc()
732 ptr = (__be64 *)(mp->mp_bh[i]->b_data + in gfs2_iomap_alloc()
736 for(i = branch_start; i < mp->mp_fheight; i++) { in gfs2_iomap_alloc()
737 if (mp->mp_bh[i] == NULL) in gfs2_iomap_alloc()
739 brelse(mp->mp_bh[i]); in gfs2_iomap_alloc()
740 mp->mp_bh[i] = NULL; in gfs2_iomap_alloc()
748 if (i > 1 && i < mp->mp_fheight) in gfs2_iomap_alloc()
749 gfs2_trans_add_meta(ip->i_gl, mp->mp_bh[i-1]); in gfs2_iomap_alloc()
750 for (; i < mp->mp_fheight && n > 0; i++, n--) in gfs2_iomap_alloc()
751 gfs2_indirect_init(mp, ip->i_gl, i, in gfs2_iomap_alloc()
752 mp->mp_list[i-1], bn++); in gfs2_iomap_alloc()
753 if (i == mp->mp_fheight) in gfs2_iomap_alloc()
760 BUG_ON(mp->mp_bh[end_of_metadata] == NULL); in gfs2_iomap_alloc()
761 gfs2_trans_add_meta(ip->i_gl, mp->mp_bh[end_of_metadata]); in gfs2_iomap_alloc()
764 iomap->addr = bn << inode->i_blkbits; in gfs2_iomap_alloc()
765 iomap->flags |= IOMAP_F_MERGED | IOMAP_F_NEW; in gfs2_iomap_alloc()
766 while (n-- > 0) in gfs2_iomap_alloc()
770 } while (iomap->addr == IOMAP_NULL_ADDR); in gfs2_iomap_alloc()
772 iomap->type = IOMAP_MAPPED; in gfs2_iomap_alloc()
773 iomap->length = (u64)dblks << inode->i_blkbits; in gfs2_iomap_alloc()
774 ip->i_height = mp->mp_fheight; in gfs2_iomap_alloc()
775 gfs2_add_inode_blocks(&ip->i_inode, alloced); in gfs2_iomap_alloc()
776 gfs2_dinode_out(ip, dibh->b_data); in gfs2_iomap_alloc()
778 up_write(&ip->i_rw_mutex); in gfs2_iomap_alloc()
785 * gfs2_alloc_size - Compute the maximum allocation size
796 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_alloc_size() local
808 if (gfs2_is_stuffed(ip) || mp->mp_fheight != mp->mp_aheight) { in gfs2_alloc_size()
809 unsigned int maxsize = mp->mp_fheight > 1 ? in gfs2_alloc_size()
810 sdp->sd_inptrs : sdp->sd_diptrs; in gfs2_alloc_size()
811 maxsize -= mp->mp_list[mp->mp_fheight - 1]; in gfs2_alloc_size()
817 first = metapointer(ip->i_height - 1, mp); in gfs2_alloc_size()
818 end = metaend(ip->i_height - 1, mp); in gfs2_alloc_size()
819 if (end - first > size) in gfs2_alloc_size()
825 return ptr - first; in gfs2_alloc_size()
829 * gfs2_iomap_get - Map blocks from an inode to disk blocks
843 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_iomap_get() local
856 return -EINVAL; in gfs2_iomap_get()
858 down_read(&ip->i_rw_mutex); in gfs2_iomap_get()
860 ret = gfs2_meta_inode_buffer(ip, &dibh); in gfs2_iomap_get()
863 mp->mp_bh[0] = dibh; in gfs2_iomap_get()
865 if (gfs2_is_stuffed(ip)) { in gfs2_iomap_get()
867 loff_t max_size = gfs2_max_stuffed_size(ip); in gfs2_iomap_get()
871 iomap->length = max_size; in gfs2_iomap_get()
875 ret = -ENOENT; in gfs2_iomap_get()
878 iomap->offset = pos; in gfs2_iomap_get()
879 iomap->length = length; in gfs2_iomap_get()
883 iomap->length = size; in gfs2_iomap_get()
885 iomap->addr = (ip->i_no_addr << inode->i_blkbits) + in gfs2_iomap_get()
887 iomap->type = IOMAP_INLINE; in gfs2_iomap_get()
888 iomap->inline_data = dibh->b_data + sizeof(struct gfs2_dinode); in gfs2_iomap_get()
893 lblock = pos >> inode->i_blkbits; in gfs2_iomap_get()
894 iomap->offset = lblock << inode->i_blkbits; in gfs2_iomap_get()
895 lblock_stop = (pos + length - 1) >> inode->i_blkbits; in gfs2_iomap_get()
896 len = lblock_stop - lblock + 1; in gfs2_iomap_get()
897 iomap->length = len << inode->i_blkbits; in gfs2_iomap_get()
899 height = ip->i_height; in gfs2_iomap_get()
900 while ((lblock + 1) * sdp->sd_sb.sb_bsize > sdp->sd_heightsize[height]) in gfs2_iomap_get()
903 if (height > ip->i_height || gfs2_is_stuffed(ip)) in gfs2_iomap_get()
906 ret = lookup_metapath(ip, mp); in gfs2_iomap_get()
910 if (mp->mp_aheight != ip->i_height) in gfs2_iomap_get()
913 ptr = metapointer(ip->i_height - 1, mp); in gfs2_iomap_get()
917 bh = mp->mp_bh[ip->i_height - 1]; in gfs2_iomap_get()
920 iomap->addr = be64_to_cpu(*ptr) << inode->i_blkbits; in gfs2_iomap_get()
921 iomap->length = len << inode->i_blkbits; in gfs2_iomap_get()
922 iomap->type = IOMAP_MAPPED; in gfs2_iomap_get()
923 iomap->flags |= IOMAP_F_MERGED; in gfs2_iomap_get()
925 iomap->flags |= IOMAP_F_GFS2_BOUNDARY; in gfs2_iomap_get()
928 iomap->bdev = inode->i_sb->s_bdev; in gfs2_iomap_get()
930 up_read(&ip->i_rw_mutex); in gfs2_iomap_get()
936 ret = -ENOENT; in gfs2_iomap_get()
937 else if (height == ip->i_height) in gfs2_iomap_get()
940 iomap->length = size - iomap->offset; in gfs2_iomap_get()
948 alloc_size = len << inode->i_blkbits; in gfs2_iomap_get()
949 if (alloc_size < iomap->length) in gfs2_iomap_get()
950 iomap->length = alloc_size; in gfs2_iomap_get()
952 if (pos < size && height == ip->i_height) in gfs2_iomap_get()
956 iomap->addr = IOMAP_NULL_ADDR; in gfs2_iomap_get()
957 iomap->type = IOMAP_HOLE; in gfs2_iomap_get()
962 * gfs2_lblk_to_dblk - convert logical block to disk block
964 * @lblock: the block relative to the start of the file
967 * This function maps a single block from a file logical block (relative to
968 * the start of the file) to a file system absolute block using iomap.
970 * Returns: the absolute file system block, or an error
976 loff_t pos = (loff_t)lblock << inode->i_blkbits; in gfs2_lblk_to_dblk()
982 *dblock = iomap.addr >> inode->i_blkbits; in gfs2_lblk_to_dblk()
989 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_write_lock() local
993 gfs2_holder_init(ip->i_gl, LM_ST_EXCLUSIVE, 0, &ip->i_gh); in gfs2_write_lock()
994 error = gfs2_glock_nq(&ip->i_gh); in gfs2_write_lock()
997 if (&ip->i_inode == sdp->sd_rindex) { in gfs2_write_lock()
998 struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); in gfs2_write_lock()
1000 error = gfs2_glock_nq_init(m_ip->i_gl, LM_ST_EXCLUSIVE, in gfs2_write_lock()
1001 GL_NOCACHE, &m_ip->i_gh); in gfs2_write_lock()
1008 gfs2_glock_dq(&ip->i_gh); in gfs2_write_lock()
1010 gfs2_holder_uninit(&ip->i_gh); in gfs2_write_lock()
1016 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_write_unlock() local
1019 if (&ip->i_inode == sdp->sd_rindex) { in gfs2_write_unlock()
1020 struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); in gfs2_write_unlock()
1022 gfs2_glock_dq_uninit(&m_ip->i_gh); in gfs2_write_unlock()
1024 gfs2_glock_dq_uninit(&ip->i_gh); in gfs2_write_unlock()
1030 unsigned int blockmask = i_blocksize(inode) - 1; in gfs2_iomap_page_prepare()
1034 blocks = ((pos & blockmask) + len + blockmask) >> inode->i_blkbits; in gfs2_iomap_page_prepare()
1042 struct gfs2_trans *tr = current->journal_info; in gfs2_iomap_page_done()
1043 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_iomap_page_done() local
1046 if (page && !gfs2_is_stuffed(ip)) in gfs2_iomap_page_done()
1047 gfs2_page_add_databufs(ip, page, offset_in_page(pos), copied); in gfs2_iomap_page_done()
1049 if (tr->tr_num_buf_new) in gfs2_iomap_page_done()
1065 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_iomap_begin_write() local
1070 unstuff = gfs2_is_stuffed(ip) && in gfs2_iomap_begin_write()
1071 pos + length > gfs2_max_stuffed_size(ip); in gfs2_iomap_begin_write()
1073 if (unstuff || iomap->type == IOMAP_HOLE) { in gfs2_iomap_begin_write()
1079 gfs2_write_calc_reserv(ip, iomap->length, &data_blocks, in gfs2_iomap_begin_write()
1082 ret = gfs2_quota_lock_check(ip, &ap); in gfs2_iomap_begin_write()
1086 ret = gfs2_inplace_reserve(ip, &ap); in gfs2_iomap_begin_write()
1091 if (gfs2_is_jdata(ip)) in gfs2_iomap_begin_write()
1095 if (inode == sdp->sd_rindex) in gfs2_iomap_begin_write()
1097 rblocks += gfs2_rg_blocks(ip, data_blocks + ind_blocks); in gfs2_iomap_begin_write()
1100 iomap->length >> inode->i_blkbits); in gfs2_iomap_begin_write()
1105 ret = gfs2_unstuff_dinode(ip, NULL); in gfs2_iomap_begin_write()
1109 ret = gfs2_iomap_get(inode, iomap->offset, in gfs2_iomap_begin_write()
1110 iomap->length, flags, iomap, mp); in gfs2_iomap_begin_write()
1115 if (iomap->type == IOMAP_HOLE) { in gfs2_iomap_begin_write()
1119 gfs2_inplace_release(ip); in gfs2_iomap_begin_write()
1120 punch_hole(ip, iomap->offset, iomap->length); in gfs2_iomap_begin_write()
1125 tr = current->journal_info; in gfs2_iomap_begin_write()
1126 if (tr->tr_num_buf_new) in gfs2_iomap_begin_write()
1132 if (gfs2_is_stuffed(ip) || gfs2_is_jdata(ip)) in gfs2_iomap_begin_write()
1133 iomap->page_ops = &gfs2_iomap_page_ops; in gfs2_iomap_begin_write()
1139 gfs2_inplace_release(ip); in gfs2_iomap_begin_write()
1141 gfs2_quota_unlock(ip); in gfs2_iomap_begin_write()
1154 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_iomap_begin() local
1158 if (gfs2_is_jdata(ip)) in gfs2_iomap_begin()
1159 iomap->flags |= IOMAP_F_BUFFER_HEAD; in gfs2_iomap_begin()
1161 trace_gfs2_iomap_start(ip, pos, length, flags); in gfs2_iomap_begin()
1179 if (iomap->type != IOMAP_MAPPED) in gfs2_iomap_begin()
1180 ret = -ENOTBLK; in gfs2_iomap_begin()
1185 if (iomap->type == IOMAP_HOLE) in gfs2_iomap_begin()
1199 trace_gfs2_iomap_end(ip, iomap, ret); in gfs2_iomap_begin()
1206 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_iomap_end() local
1215 if (iomap->type == IOMAP_HOLE) in gfs2_iomap_end()
1222 if (!gfs2_is_stuffed(ip)) in gfs2_iomap_end()
1223 gfs2_ordered_add_inode(ip); in gfs2_iomap_end()
1225 if (inode == sdp->sd_rindex) in gfs2_iomap_end()
1228 gfs2_inplace_release(ip); in gfs2_iomap_end()
1230 if (ip->i_qadata && ip->i_qadata->qa_qd_num) in gfs2_iomap_end()
1231 gfs2_quota_unlock(ip); in gfs2_iomap_end()
1233 if (length != written && (iomap->flags & IOMAP_F_NEW)) { in gfs2_iomap_end()
1236 loff_t hend = iomap->offset + iomap->length; in gfs2_iomap_end()
1239 truncate_pagecache_range(inode, hstart, hend - 1); in gfs2_iomap_end()
1240 punch_hole(ip, hstart, hend - hstart); in gfs2_iomap_end()
1247 if (iomap->flags & IOMAP_F_SIZE_CHANGED) in gfs2_iomap_end()
1249 set_bit(GLF_DIRTY, &ip->i_gl->gl_flags); in gfs2_iomap_end()
1263 * gfs2_block_map - Map one or more blocks of an inode to a disk block
1265 * @lblock: The logical block number
1269 * The size of the requested mapping is defined in bh_map->b_size.
1271 * Clears buffer_mapped(bh_map) and leaves bh_map->b_size unchanged
1273 * bh_map->b_size to indicate the size of the mapping when @lblock and
1277 * before the next block can be mapped. Sets buffer_new() if new
1286 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_block_map() local
1287 loff_t pos = (loff_t)lblock << inode->i_blkbits; in gfs2_block_map()
1288 loff_t length = bh_map->b_size; in gfs2_block_map()
1297 trace_gfs2_bmap(ip, bh_map, lblock, create, 1); in gfs2_block_map()
1306 if (iomap.length > bh_map->b_size) { in gfs2_block_map()
1307 iomap.length = bh_map->b_size; in gfs2_block_map()
1311 map_bh(bh_map, inode->i_sb, iomap.addr >> inode->i_blkbits); in gfs2_block_map()
1312 bh_map->b_size = iomap.length; in gfs2_block_map()
1319 trace_gfs2_bmap(ip, bh_map, lblock, create, ret); in gfs2_block_map()
1336 bh.b_size = BIT(inode->i_blkbits + (create ? 0 : 5)); in gfs2_extent_map()
1338 *extlen = bh.b_size >> inode->i_blkbits; in gfs2_extent_map()
1355 BUG_ON(current->journal_info); in gfs2_block_zero_range()
1362 * gfs2_journaled_truncate - Wrapper for truncate_pagecache for jdata files
1367 * With jdata files, we have to journal a revoke for each block which is
1375 u64 max_chunk = GFS2_JTRUNC_REVOKES * sdp->sd_vfs->s_blocksize; in gfs2_journaled_truncate()
1383 chunk = oldsize - newsize; in gfs2_journaled_truncate()
1389 chunk = offs + ((chunk - offs) & PAGE_MASK); in gfs2_journaled_truncate()
1391 truncate_pagecache(inode, oldsize - chunk); in gfs2_journaled_truncate()
1392 oldsize -= chunk; in gfs2_journaled_truncate()
1394 tr = current->journal_info; in gfs2_journaled_truncate()
1395 if (!test_bit(TR_TOUCHED, &tr->tr_flags)) in gfs2_journaled_truncate()
1409 struct gfs2_inode *ip = GFS2_I(inode); in trunc_start() local
1412 int journaled = gfs2_is_jdata(ip); in trunc_start()
1413 u64 oldsize = inode->i_size; in trunc_start()
1416 if (!gfs2_is_stuffed(ip)) { in trunc_start()
1418 unsigned int offs = newsize & (blocksize - 1); in trunc_start()
1421 blocksize - offs); in trunc_start()
1433 error = gfs2_meta_inode_buffer(ip, &dibh); in trunc_start()
1437 gfs2_trans_add_meta(ip->i_gl, dibh); in trunc_start()
1439 if (gfs2_is_stuffed(ip)) in trunc_start()
1442 ip->i_diskflags |= GFS2_DIF_TRUNC_IN_PROG; in trunc_start()
1445 ip->i_inode.i_mtime = ip->i_inode.i_ctime = current_time(&ip->i_inode); in trunc_start()
1446 gfs2_dinode_out(ip, dibh->b_data); in trunc_start()
1455 if (current->journal_info) in trunc_start()
1467 if (!ret && iomap->type == IOMAP_HOLE) in gfs2_iomap_get_alloc()
1474 * sweep_bh_for_rgrps - find an rgrp in a meta buffer and free blocks therein
1475 * @ip: inode
1485 * block has references to multiple rgrps, we break it into individual
1490 * if we're interrupted by power-outages.
1495 static int sweep_bh_for_rgrps(struct gfs2_inode *ip, struct gfs2_holder *rd_gh, in sweep_bh_for_rgrps() argument
1499 struct gfs2_sbd *sdp = GFS2_SB(&ip->i_inode); in sweep_bh_for_rgrps()
1512 rgd = gfs2_glock2rgrp(rd_gh->gh_gl); in sweep_bh_for_rgrps()
1514 gfs2_glock_is_locked_by_me(rd_gh->gh_gl)); in sweep_bh_for_rgrps()
1533 ret = -EIO; in sweep_bh_for_rgrps()
1536 ret = gfs2_glock_nq_init(rgd->rd_gl, LM_ST_EXCLUSIVE, in sweep_bh_for_rgrps()
1542 if (gfs2_rs_active(&ip->i_res) && in sweep_bh_for_rgrps()
1543 rgd == ip->i_res.rs_rbm.rgd) in sweep_bh_for_rgrps()
1544 gfs2_rs_deltree(&ip->i_res); in sweep_bh_for_rgrps()
1552 if (current->journal_info == NULL) { in sweep_bh_for_rgrps()
1555 jblocks_rqsted = rgd->rd_length + RES_DINODE + in sweep_bh_for_rgrps()
1557 isize_blks = gfs2_get_inode_blocks(&ip->i_inode); in sweep_bh_for_rgrps()
1558 if (isize_blks > atomic_read(&sdp->sd_log_thresh2)) in sweep_bh_for_rgrps()
1560 atomic_read(&sdp->sd_log_thresh2); in sweep_bh_for_rgrps()
1565 revokes += end - start; in sweep_bh_for_rgrps()
1566 else if (ip->i_depth) in sweep_bh_for_rgrps()
1567 revokes += sdp->sd_inptrs; in sweep_bh_for_rgrps()
1571 down_write(&ip->i_rw_mutex); in sweep_bh_for_rgrps()
1574 tr = current->journal_info; in sweep_bh_for_rgrps()
1575 if (tr->tr_num_buf_new + RES_STATFS + in sweep_bh_for_rgrps()
1576 RES_QUOTA >= atomic_read(&sdp->sd_log_thresh2)) { in sweep_bh_for_rgrps()
1582 to the transaction, we've already set some block in sweep_bh_for_rgrps()
1598 gfs2_trans_add_meta(ip->i_gl, bh); in sweep_bh_for_rgrps()
1606 __gfs2_free_blocks(ip, rgd, bstart, (u32)blen, meta); in sweep_bh_for_rgrps()
1608 gfs2_add_inode_blocks(&ip->i_inode, -blen); in sweep_bh_for_rgrps()
1614 __gfs2_free_blocks(ip, rgd, bstart, (u32)blen, meta); in sweep_bh_for_rgrps()
1616 gfs2_add_inode_blocks(&ip->i_inode, -blen); in sweep_bh_for_rgrps()
1619 if (!ret && blks_outside_rgrp) { /* If buffer still has non-zero blocks in sweep_bh_for_rgrps()
1622 if (current->journal_info) { in sweep_bh_for_rgrps()
1625 ret = gfs2_meta_inode_buffer(ip, &dibh); in sweep_bh_for_rgrps()
1631 ip->i_inode.i_mtime = ip->i_inode.i_ctime = in sweep_bh_for_rgrps()
1632 current_time(&ip->i_inode); in sweep_bh_for_rgrps()
1633 gfs2_trans_add_meta(ip->i_gl, dibh); in sweep_bh_for_rgrps()
1634 gfs2_dinode_out(ip, dibh->b_data); in sweep_bh_for_rgrps()
1636 up_write(&ip->i_rw_mutex); in sweep_bh_for_rgrps()
1650 if (memcmp(mp->mp_list, list, h * sizeof(mp->mp_list[0]))) in mp_eq_to_hgt()
1656 * find_nonnull_ptr - find a non-null pointer given a metapath and height
1661 * Returns: true if a non-null pointer was found in the metapath buffer
1668 struct buffer_head *bh = mp->mp_bh[h]; in find_nonnull_ptr()
1672 ptr = first + mp->mp_list[h]; in find_nonnull_ptr()
1673 end = (__be64 *)(bh->b_data + bh->b_size); in find_nonnull_ptr()
1680 if (*ptr) { /* if we have a non-null pointer */ in find_nonnull_ptr()
1681 mp->mp_list[h] = ptr - first; in find_nonnull_ptr()
1684 mp->mp_list[h] = 0; in find_nonnull_ptr()
1705 struct buffer_head *bh = mp->mp_bh[height]; in metapointer_range()
1714 *end = (__be64 *)(bh->b_data + bh->b_size); in metapointer_range()
1733 end = (height > 0) ? sdp->sd_inptrs : sdp->sd_diptrs; in walk_done()
1734 return mp->mp_list[height] >= end; in walk_done()
1738 * punch_hole - deallocate blocks in a file
1739 * @ip: inode to truncate
1753 static int punch_hole(struct gfs2_inode *ip, u64 offset, u64 length) in punch_hole() argument
1755 struct gfs2_sbd *sdp = GFS2_SB(&ip->i_inode); in punch_hole()
1756 u64 maxsize = sdp->sd_heightsize[ip->i_height]; in punch_hole()
1760 unsigned int bsize_shift = sdp->sd_sb.sb_bsize_shift; in punch_hole()
1761 u64 lblock = (offset + (1 << bsize_shift) - 1) >> bsize_shift; in punch_hole()
1765 unsigned int strip_h = ip->i_height - 1; in punch_hole()
1774 * The starting point lies beyond the allocated meta-data; in punch_hole()
1808 find_metapath(sdp, lend, &mp, ip->i_height); in punch_hole()
1812 for (mp_h = ip->i_height - 1; mp_h > 0; mp_h--) { in punch_hole()
1819 find_metapath(sdp, lblock, &mp, ip->i_height); in punch_hole()
1822 for (mp_h = ip->i_height - 1; mp_h > 0; mp_h--) { in punch_hole()
1828 ret = gfs2_meta_inode_buffer(ip, &dibh); in punch_hole()
1833 ret = lookup_metapath(ip, &mp); in punch_hole()
1837 /* issue read-ahead on metadata */ in punch_hole()
1838 for (mp_h = 0; mp_h < mp.mp_aheight - 1; mp_h++) { in punch_hole()
1841 gfs2_metapath_ra(ip->i_gl, start, end); in punch_hole()
1844 if (mp.mp_aheight == ip->i_height) in punch_hole()
1853 ret = gfs2_quota_hold(ip, NO_UID_QUOTA_CHANGE, NO_GID_QUOTA_CHANGE); in punch_hole()
1868 prev_bnr != bh->b_blocknr)) { in punch_hole()
1869 fs_emerg(sdp, "inode %llu, block:%llu, i_h:%u," in punch_hole()
1871 (unsigned long long)ip->i_no_addr, in punch_hole()
1872 prev_bnr, ip->i_height, strip_h, mp_h); in punch_hole()
1874 prev_bnr = bh->b_blocknr; in punch_hole()
1879 ret = -EIO; in punch_hole()
1892 ret = sweep_bh_for_rgrps(ip, &rd_gh, mp.mp_bh[mp_h], in punch_hole()
1894 mp_h != ip->i_height - 1, in punch_hole()
1919 strip_h--; in punch_hole()
1926 mp_h--; /* search one metadata height down */ in punch_hole()
1932 * next non-null pointer. */ in punch_hole()
1937 /* No more non-null pointers at this height. Back up in punch_hole()
1944 ret = fillup_metapath(ip, &mp, mp_h); in punch_hole()
1948 /* On the first pass, issue read-ahead on metadata. */ in punch_hole()
1949 if (mp.mp_aheight > 1 && strip_h == ip->i_height - 1) { in punch_hole()
1950 unsigned int height = mp.mp_aheight - 1; in punch_hole()
1952 /* No read-ahead for data blocks. */ in punch_hole()
1953 if (mp.mp_aheight - 1 == strip_h) in punch_hole()
1954 height--; in punch_hole()
1956 for (; height >= mp.mp_aheight - ret; height--) { in punch_hole()
1961 gfs2_metapath_ra(ip->i_gl, start, end); in punch_hole()
1966 if (mp.mp_aheight - 1 == strip_h) { in punch_hole()
1970 if (mp.mp_aheight < ip->i_height) /* We have a partial height */ in punch_hole()
1971 mp_h = mp.mp_aheight - 1; in punch_hole()
1973 /* If we find a non-null block pointer, crawl a bit in punch_hole()
1985 if (current->journal_info == NULL) { in punch_hole()
1990 down_write(&ip->i_rw_mutex); in punch_hole()
1993 gfs2_quota_change(ip, -(s64)btotal, ip->i_inode.i_uid, in punch_hole()
1994 ip->i_inode.i_gid); in punch_hole()
1995 ip->i_inode.i_mtime = ip->i_inode.i_ctime = current_time(&ip->i_inode); in punch_hole()
1996 gfs2_trans_add_meta(ip->i_gl, dibh); in punch_hole()
1997 gfs2_dinode_out(ip, dibh->b_data); in punch_hole()
1998 up_write(&ip->i_rw_mutex); in punch_hole()
2005 if (current->journal_info) { in punch_hole()
2006 up_write(&ip->i_rw_mutex); in punch_hole()
2010 gfs2_quota_unhold(ip); in punch_hole()
2016 static int trunc_end(struct gfs2_inode *ip) in trunc_end() argument
2018 struct gfs2_sbd *sdp = GFS2_SB(&ip->i_inode); in trunc_end()
2026 down_write(&ip->i_rw_mutex); in trunc_end()
2028 error = gfs2_meta_inode_buffer(ip, &dibh); in trunc_end()
2032 if (!i_size_read(&ip->i_inode)) { in trunc_end()
2033 ip->i_height = 0; in trunc_end()
2034 ip->i_goal = ip->i_no_addr; in trunc_end()
2036 gfs2_ordered_del_inode(ip); in trunc_end()
2038 ip->i_inode.i_mtime = ip->i_inode.i_ctime = current_time(&ip->i_inode); in trunc_end()
2039 ip->i_diskflags &= ~GFS2_DIF_TRUNC_IN_PROG; in trunc_end()
2041 gfs2_trans_add_meta(ip->i_gl, dibh); in trunc_end()
2042 gfs2_dinode_out(ip, dibh->b_data); in trunc_end()
2046 up_write(&ip->i_rw_mutex); in trunc_end()
2052 * do_shrink - make a file smaller
2064 struct gfs2_inode *ip = GFS2_I(inode); in do_shrink() local
2070 if (gfs2_is_stuffed(ip)) in do_shrink()
2073 error = punch_hole(ip, newsize, 0); in do_shrink()
2075 error = trunc_end(ip); in do_shrink()
2084 ret = do_shrink(inode, inode->i_size); in gfs2_trim_blocks()
2089 * do_grow - Touch and update inode size
2105 * Returns: 0 on success, or -ve on error
2110 struct gfs2_inode *ip = GFS2_I(inode); in do_grow() local
2117 if (gfs2_is_stuffed(ip) && size > gfs2_max_stuffed_size(ip)) { in do_grow()
2118 error = gfs2_quota_lock_check(ip, &ap); in do_grow()
2122 error = gfs2_inplace_reserve(ip, &ap); in do_grow()
2130 gfs2_is_jdata(ip) ? RES_JDATA : 0) + in do_grow()
2131 (sdp->sd_args.ar_quota == GFS2_QUOTA_OFF ? in do_grow()
2137 error = gfs2_unstuff_dinode(ip, NULL); in do_grow()
2142 error = gfs2_meta_inode_buffer(ip, &dibh); in do_grow()
2147 ip->i_inode.i_mtime = ip->i_inode.i_ctime = current_time(&ip->i_inode); in do_grow()
2148 gfs2_trans_add_meta(ip->i_gl, dibh); in do_grow()
2149 gfs2_dinode_out(ip, dibh->b_data); in do_grow()
2156 gfs2_inplace_release(ip); in do_grow()
2158 gfs2_quota_unlock(ip); in do_grow()
2164 * gfs2_setattr_size - make a file a given size
2177 struct gfs2_inode *ip = GFS2_I(inode); in gfs2_setattr_size() local
2180 BUG_ON(!S_ISREG(inode->i_mode)); in gfs2_setattr_size()
2188 ret = gfs2_qa_get(ip); in gfs2_setattr_size()
2192 if (newsize >= inode->i_size) { in gfs2_setattr_size()
2199 gfs2_rs_delete(ip); in gfs2_setattr_size()
2200 gfs2_qa_put(ip); in gfs2_setattr_size()
2204 int gfs2_truncatei_resume(struct gfs2_inode *ip) in gfs2_truncatei_resume() argument
2207 error = punch_hole(ip, i_size_read(&ip->i_inode), 0); in gfs2_truncatei_resume()
2209 error = trunc_end(ip); in gfs2_truncatei_resume()
2213 int gfs2_file_dealloc(struct gfs2_inode *ip) in gfs2_file_dealloc() argument
2215 return punch_hole(ip, 0, 0); in gfs2_file_dealloc()
2219 * gfs2_free_journal_extents - Free cached journal bmap info
2228 while(!list_empty(&jd->extent_list)) { in gfs2_free_journal_extents()
2229 jext = list_first_entry(&jd->extent_list, struct gfs2_journal_extent, list); in gfs2_free_journal_extents()
2230 list_del(&jext->list); in gfs2_free_journal_extents()
2236 * gfs2_add_jextent - Add or merge a new extent to extent cache
2238 * @lblock: The logical block at start of new extent
2239 * @dblock: The physical block at start of new extent
2242 * Returns: 0 on success or -ENOMEM
2249 if (!list_empty(&jd->extent_list)) { in gfs2_add_jextent()
2250 jext = list_last_entry(&jd->extent_list, struct gfs2_journal_extent, list); in gfs2_add_jextent()
2251 if ((jext->dblock + jext->blocks) == dblock) { in gfs2_add_jextent()
2252 jext->blocks += blocks; in gfs2_add_jextent()
2259 return -ENOMEM; in gfs2_add_jextent()
2260 jext->dblock = dblock; in gfs2_add_jextent()
2261 jext->lblock = lblock; in gfs2_add_jextent()
2262 jext->blocks = blocks; in gfs2_add_jextent()
2263 list_add_tail(&jext->list, &jd->extent_list); in gfs2_add_jextent()
2264 jd->nr_extents++; in gfs2_add_jextent()
2269 * gfs2_map_journal_extents - Cache journal bmap info
2270 * @sdp: The super block
2278 * So the extent would map the first block for the entire file length.
2292 struct gfs2_inode *ip = GFS2_I(jd->jd_inode); in gfs2_map_journal_extents() local
2294 unsigned int shift = sdp->sd_sb.sb_bsize_shift; in gfs2_map_journal_extents()
2300 lblock_stop = i_size_read(jd->jd_inode) >> shift; in gfs2_map_journal_extents()
2301 size = (lblock_stop - lblock) << shift; in gfs2_map_journal_extents()
2302 jd->nr_extents = 0; in gfs2_map_journal_extents()
2303 WARN_ON(!list_empty(&jd->extent_list)); in gfs2_map_journal_extents()
2309 rc = gfs2_block_map(jd->jd_inode, lblock, &bh, 0); in gfs2_map_journal_extents()
2315 size -= bh.b_size; in gfs2_map_journal_extents()
2316 lblock += (bh.b_size >> ip->i_inode.i_blkbits); in gfs2_map_journal_extents()
2320 fs_info(sdp, "journal %d mapped with %u extents in %lldms\n", jd->jd_jid, in gfs2_map_journal_extents()
2321 jd->nr_extents, ktime_ms_delta(end, start)); in gfs2_map_journal_extents()
2326 rc, jd->jd_jid, in gfs2_map_journal_extents()
2327 (unsigned long long)(i_size_read(jd->jd_inode) - size), in gfs2_map_journal_extents()
2328 jd->nr_extents); in gfs2_map_journal_extents()
2329 fs_warn(sdp, "bmap=%d lblock=%llu block=%llu, state=0x%08lx, size=%llu\n", in gfs2_map_journal_extents()
2337 * gfs2_write_alloc_required - figure out if a write will require an allocation
2338 * @ip: the file being written to
2345 int gfs2_write_alloc_required(struct gfs2_inode *ip, u64 offset, in gfs2_write_alloc_required() argument
2348 struct gfs2_sbd *sdp = GFS2_SB(&ip->i_inode); in gfs2_write_alloc_required()
2357 if (gfs2_is_stuffed(ip)) { in gfs2_write_alloc_required()
2358 if (offset + len > gfs2_max_stuffed_size(ip)) in gfs2_write_alloc_required()
2363 shift = sdp->sd_sb.sb_bsize_shift; in gfs2_write_alloc_required()
2364 BUG_ON(gfs2_is_dir(ip)); in gfs2_write_alloc_required()
2365 end_of_file = (i_size_read(&ip->i_inode) + sdp->sd_sb.sb_bsize - 1) >> shift; in gfs2_write_alloc_required()
2367 lblock_stop = (offset + len + sdp->sd_sb.sb_bsize - 1) >> shift; in gfs2_write_alloc_required()
2368 if (lblock_stop > end_of_file && ip != GFS2_I(sdp->sd_rindex)) in gfs2_write_alloc_required()
2371 size = (lblock_stop - lblock) << shift; in gfs2_write_alloc_required()
2375 gfs2_block_map(&ip->i_inode, lblock, &bh, 0); in gfs2_write_alloc_required()
2378 size -= bh.b_size; in gfs2_write_alloc_required()
2379 lblock += (bh.b_size >> ip->i_inode.i_blkbits); in gfs2_write_alloc_required()
2387 struct gfs2_inode *ip = GFS2_I(inode); in stuffed_zero_range() local
2391 if (offset >= inode->i_size) in stuffed_zero_range()
2393 if (offset + length > inode->i_size) in stuffed_zero_range()
2394 length = inode->i_size - offset; in stuffed_zero_range()
2396 error = gfs2_meta_inode_buffer(ip, &dibh); in stuffed_zero_range()
2399 gfs2_trans_add_meta(ip->i_gl, dibh); in stuffed_zero_range()
2400 memset(dibh->b_data + sizeof(struct gfs2_dinode) + offset, 0, in stuffed_zero_range()
2410 loff_t max_chunk = GFS2_JTRUNC_REVOKES * sdp->sd_vfs->s_blocksize; in gfs2_journaled_truncate_range()
2424 chunk = offs + ((chunk - offs) & PAGE_MASK); in gfs2_journaled_truncate_range()
2428 length -= chunk; in gfs2_journaled_truncate_range()
2430 tr = current->journal_info; in gfs2_journaled_truncate_range()
2431 if (!test_bit(TR_TOUCHED, &tr->tr_flags)) in gfs2_journaled_truncate_range()
2445 struct gfs2_inode *ip = GFS2_I(inode); in __gfs2_punch_hole() local
2451 if (!gfs2_is_stuffed(ip)) { in __gfs2_punch_hole()
2454 start_off = offset & (blocksize - 1); in __gfs2_punch_hole()
2455 end_len = (offset + length) & (blocksize - 1); in __gfs2_punch_hole()
2458 if (length > blocksize - start_off) in __gfs2_punch_hole()
2459 len = blocksize - start_off; in __gfs2_punch_hole()
2468 offset + length - end_len, end_len); in __gfs2_punch_hole()
2475 end = round_up(offset + length, blocksize) - 1; in __gfs2_punch_hole()
2476 error = filemap_write_and_wait_range(inode->i_mapping, start, end); in __gfs2_punch_hole()
2480 if (gfs2_is_jdata(ip)) in __gfs2_punch_hole()
2488 if (gfs2_is_stuffed(ip)) { in __gfs2_punch_hole()
2494 if (gfs2_is_jdata(ip)) { in __gfs2_punch_hole()
2495 BUG_ON(!current->journal_info); in __gfs2_punch_hole()
2498 truncate_pagecache_range(inode, offset, offset + length - 1); in __gfs2_punch_hole()
2503 if (current->journal_info) in __gfs2_punch_hole()
2506 if (!gfs2_is_stuffed(ip)) in __gfs2_punch_hole()
2507 error = punch_hole(ip, offset, length); in __gfs2_punch_hole()
2510 if (current->journal_info) in __gfs2_punch_hole()
2522 return -EIO; in gfs2_map_blocks()
2524 if (offset >= wpc->iomap.offset && in gfs2_map_blocks()
2525 offset < wpc->iomap.offset + wpc->iomap.length) in gfs2_map_blocks()
2528 memset(&wpc->iomap, 0, sizeof(wpc->iomap)); in gfs2_map_blocks()
2529 ret = gfs2_iomap_get(inode, offset, INT_MAX, 0, &wpc->iomap, &mp); in gfs2_map_blocks()