Lines Matching refs:epos
76 brelse(iinfo->cached_extent.epos.bh); in __udf_clear_extent_cache()
103 memcpy(pos, &iinfo->cached_extent.epos, in udf_read_extent_cache()
124 memcpy(&iinfo->cached_extent.epos, pos, sizeof(*pos)); in udf_update_extent_cache()
128 iinfo->cached_extent.epos.offset -= sizeof(struct short_ad); in udf_update_extent_cache()
131 iinfo->cached_extent.epos.offset -= sizeof(struct long_ad); in udf_update_extent_cache()
333 struct extent_position epos; in udf_expand_dir_adinicb() local
407 epos.bh = NULL; in udf_expand_dir_adinicb()
408 epos.block = iinfo->i_location; in udf_expand_dir_adinicb()
409 epos.offset = udf_file_entry_alloc_offset(inode); in udf_expand_dir_adinicb()
410 udf_add_aext(inode, &epos, &eloc, inode->i_size, 0); in udf_expand_dir_adinicb()
413 brelse(epos.bh); in udf_expand_dir_adinicb()
627 struct extent_position epos; in udf_extend_file() local
647 etype = inode_bmap(inode, first_block, &epos, &eloc, &elen, &offset); in udf_extend_file()
650 if ((!epos.bh && epos.offset == udf_file_entry_alloc_offset(inode)) || in udf_extend_file()
651 (epos.bh && epos.offset == sizeof(struct allocExtDesc))) { in udf_extend_file()
658 epos.offset -= adsize; in udf_extend_file()
659 etype = udf_next_aext(inode, &epos, &extent.extLocation, in udf_extend_file()
671 udf_do_extend_final_block(inode, &epos, &extent, in udf_extend_file()
676 err = udf_do_extend_file(inode, &epos, &extent, add); in udf_extend_file()
684 brelse(epos.bh); in udf_extend_file()
1176 struct extent_position *epos) in udf_update_extents() argument
1184 udf_delete_aext(inode, *epos); in udf_update_extents()
1187 udf_insert_aext(inode, *epos, laarr[i].extLocation, in udf_update_extents()
1189 udf_next_aext(inode, epos, &laarr[i].extLocation, in udf_update_extents()
1196 udf_next_aext(inode, epos, &tmploc, &tmplen, 0); in udf_update_extents()
1197 udf_write_aext(inode, epos, &laarr[i].extLocation, in udf_update_extents()
1924 struct extent_position *epos) in udf_setup_indirect_aext() argument
1941 neloc.partitionReferenceNum = epos->block.partitionReferenceNum; in udf_setup_indirect_aext()
1955 cpu_to_le32(epos->block.logicalBlockNum); in udf_setup_indirect_aext()
1973 if (epos->offset + adsize > sb->s_blocksize) { in udf_setup_indirect_aext()
1978 epos->offset -= adsize; in udf_setup_indirect_aext()
1979 cp_type = udf_current_aext(inode, epos, &cp_loc, &cp_len, 0); in udf_setup_indirect_aext()
1983 udf_write_aext(inode, epos, &nepos.block, in udf_setup_indirect_aext()
1986 __udf_add_aext(inode, epos, &nepos.block, in udf_setup_indirect_aext()
1990 brelse(epos->bh); in udf_setup_indirect_aext()
1991 *epos = nepos; in udf_setup_indirect_aext()
2001 int __udf_add_aext(struct inode *inode, struct extent_position *epos, in __udf_add_aext() argument
2015 if (!epos->bh) { in __udf_add_aext()
2017 epos->offset - udf_file_entry_alloc_offset(inode)); in __udf_add_aext()
2019 aed = (struct allocExtDesc *)epos->bh->b_data; in __udf_add_aext()
2021 epos->offset - sizeof(struct allocExtDesc)); in __udf_add_aext()
2022 WARN_ON(epos->offset + adsize > inode->i_sb->s_blocksize); in __udf_add_aext()
2025 udf_write_aext(inode, epos, eloc, elen, inc); in __udf_add_aext()
2027 if (!epos->bh) { in __udf_add_aext()
2031 aed = (struct allocExtDesc *)epos->bh->b_data; in __udf_add_aext()
2035 udf_update_tag(epos->bh->b_data, in __udf_add_aext()
2036 epos->offset + (inc ? 0 : adsize)); in __udf_add_aext()
2038 udf_update_tag(epos->bh->b_data, in __udf_add_aext()
2040 mark_buffer_dirty_inode(epos->bh, inode); in __udf_add_aext()
2050 int udf_add_aext(struct inode *inode, struct extent_position *epos, in udf_add_aext() argument
2063 if (epos->offset + (2 * adsize) > sb->s_blocksize) { in udf_add_aext()
2068 epos->block.partitionReferenceNum, in udf_add_aext()
2069 epos->block.logicalBlockNum, &err); in udf_add_aext()
2073 err = udf_setup_indirect_aext(inode, new_block, epos); in udf_add_aext()
2078 return __udf_add_aext(inode, epos, eloc, elen, inc); in udf_add_aext()
2081 void udf_write_aext(struct inode *inode, struct extent_position *epos, in udf_write_aext() argument
2090 if (!epos->bh) in udf_write_aext()
2091 ptr = iinfo->i_ext.i_data + epos->offset - in udf_write_aext()
2095 ptr = epos->bh->b_data + epos->offset; in udf_write_aext()
2115 if (epos->bh) { in udf_write_aext()
2119 (struct allocExtDesc *)epos->bh->b_data; in udf_write_aext()
2120 udf_update_tag(epos->bh->b_data, in udf_write_aext()
2124 mark_buffer_dirty_inode(epos->bh, inode); in udf_write_aext()
2130 epos->offset += adsize; in udf_write_aext()
2139 int8_t udf_next_aext(struct inode *inode, struct extent_position *epos, in udf_next_aext() argument
2145 while ((etype = udf_current_aext(inode, epos, eloc, elen, inc)) == in udf_next_aext()
2156 epos->block = *eloc; in udf_next_aext()
2157 epos->offset = sizeof(struct allocExtDesc); in udf_next_aext()
2158 brelse(epos->bh); in udf_next_aext()
2159 block = udf_get_lb_pblock(inode->i_sb, &epos->block, 0); in udf_next_aext()
2160 epos->bh = udf_tread(inode->i_sb, block); in udf_next_aext()
2161 if (!epos->bh) { in udf_next_aext()
2170 int8_t udf_current_aext(struct inode *inode, struct extent_position *epos, in udf_current_aext() argument
2180 if (!epos->bh) { in udf_current_aext()
2181 if (!epos->offset) in udf_current_aext()
2182 epos->offset = udf_file_entry_alloc_offset(inode); in udf_current_aext()
2183 ptr = iinfo->i_ext.i_data + epos->offset - in udf_current_aext()
2189 if (!epos->offset) in udf_current_aext()
2190 epos->offset = sizeof(struct allocExtDesc); in udf_current_aext()
2191 ptr = epos->bh->b_data + epos->offset; in udf_current_aext()
2193 le32_to_cpu(((struct allocExtDesc *)epos->bh->b_data)-> in udf_current_aext()
2199 sad = udf_get_fileshortad(ptr, alen, &epos->offset, inc); in udf_current_aext()
2209 lad = udf_get_filelongad(ptr, alen, &epos->offset, inc); in udf_current_aext()
2224 static int8_t udf_insert_aext(struct inode *inode, struct extent_position epos, in udf_insert_aext() argument
2231 if (epos.bh) in udf_insert_aext()
2232 get_bh(epos.bh); in udf_insert_aext()
2234 while ((etype = udf_next_aext(inode, &epos, &oeloc, &oelen, 0)) != -1) { in udf_insert_aext()
2235 udf_write_aext(inode, &epos, &neloc, nelen, 1); in udf_insert_aext()
2239 udf_add_aext(inode, &epos, &neloc, nelen, 1); in udf_insert_aext()
2240 brelse(epos.bh); in udf_insert_aext()
2245 int8_t udf_delete_aext(struct inode *inode, struct extent_position epos) in udf_delete_aext() argument
2255 if (epos.bh) { in udf_delete_aext()
2256 get_bh(epos.bh); in udf_delete_aext()
2257 get_bh(epos.bh); in udf_delete_aext()
2268 oepos = epos; in udf_delete_aext()
2269 if (udf_next_aext(inode, &epos, &eloc, &elen, 1) == -1) in udf_delete_aext()
2272 while ((etype = udf_next_aext(inode, &epos, &eloc, &elen, 1)) != -1) { in udf_delete_aext()
2274 if (oepos.bh != epos.bh) { in udf_delete_aext()
2275 oepos.block = epos.block; in udf_delete_aext()
2277 get_bh(epos.bh); in udf_delete_aext()
2278 oepos.bh = epos.bh; in udf_delete_aext()
2279 oepos.offset = epos.offset - adsize; in udf_delete_aext()
2285 if (epos.bh != oepos.bh) { in udf_delete_aext()
2286 udf_free_blocks(inode->i_sb, inode, &epos.block, 0, 1); in udf_delete_aext()
2315 epos.offset - adsize); in udf_delete_aext()
2323 brelse(epos.bh); in udf_delete_aext()
2366 struct extent_position epos = {}; in udf_block_map() local
2371 if (inode_bmap(inode, block, &epos, &eloc, &elen, &offset) == in udf_block_map()
2378 brelse(epos.bh); in udf_block_map()