提交 4b7068c8 编写于 作者: A Al Viro

ufs: move calculation of offsets into ufs_getfrag_block()

... and massage ufs_frag_map() to take those instead of fragment number.

As it is, we duplicate the damn thing on the write side, open-coded and
bloody hard to follow.
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 5a39c255
...@@ -119,20 +119,18 @@ static inline int grow_chain64(struct ufs_inode_info *ufsi, ...@@ -119,20 +119,18 @@ static inline int grow_chain64(struct ufs_inode_info *ufsi,
* the beginning of the filesystem. * the beginning of the filesystem.
*/ */
static u64 ufs_frag_map(struct inode *inode, sector_t frag) static u64 ufs_frag_map(struct inode *inode, unsigned offsets[4], int depth)
{ {
struct ufs_inode_info *ufsi = UFS_I(inode); struct ufs_inode_info *ufsi = UFS_I(inode);
struct super_block *sb = inode->i_sb; struct super_block *sb = inode->i_sb;
struct ufs_sb_private_info *uspi = UFS_SB(sb)->s_uspi; struct ufs_sb_private_info *uspi = UFS_SB(sb)->s_uspi;
u64 mask = (u64) uspi->s_apbmask>>uspi->s_fpbshift; u64 mask = (u64) uspi->s_apbmask>>uspi->s_fpbshift;
int shift = uspi->s_apbshift-uspi->s_fpbshift; int shift = uspi->s_apbshift-uspi->s_fpbshift;
unsigned offsets[4], *p;
Indirect chain[4], *q = chain; Indirect chain[4], *q = chain;
int depth = ufs_block_to_path(inode, frag >> uspi->s_fpbshift, offsets); unsigned *p;
unsigned flags = UFS_SB(sb)->s_flags; unsigned flags = UFS_SB(sb)->s_flags;
u64 res = 0; u64 res = 0;
UFSD(": frag = %llu depth = %d\n", (unsigned long long)frag, depth);
UFSD(": uspi->s_fpbshift = %d ,uspi->s_apbmask = %x, mask=%llx\n", UFSD(": uspi->s_fpbshift = %d ,uspi->s_apbmask = %x, mask=%llx\n",
uspi->s_fpbshift, uspi->s_apbmask, uspi->s_fpbshift, uspi->s_apbmask,
(unsigned long long)mask); (unsigned long long)mask);
...@@ -191,7 +189,7 @@ static u64 ufs_frag_map(struct inode *inode, sector_t frag) ...@@ -191,7 +189,7 @@ static u64 ufs_frag_map(struct inode *inode, sector_t frag)
} }
res = fs64_to_cpu(sb, q->key64); res = fs64_to_cpu(sb, q->key64);
found: found:
res += uspi->s_sbbase + (frag & uspi->s_fpbmask); res += uspi->s_sbbase;
no_block: no_block:
while (q > chain) { while (q > chain) {
brelse(q->bh); brelse(q->bh);
...@@ -443,14 +441,17 @@ static int ufs_getfrag_block(struct inode *inode, sector_t fragment, struct buff ...@@ -443,14 +441,17 @@ static int ufs_getfrag_block(struct inode *inode, sector_t fragment, struct buff
struct ufs_sb_private_info * uspi = sbi->s_uspi; struct ufs_sb_private_info * uspi = sbi->s_uspi;
struct buffer_head * bh; struct buffer_head * bh;
int ret, err, new; int ret, err, new;
unsigned offsets[4];
int depth = ufs_block_to_path(inode, fragment >> uspi->s_fpbshift, offsets);
unsigned long ptr,phys; unsigned long ptr,phys;
u64 phys64 = 0; u64 phys64 = 0;
if (!create) { if (!create) {
phys64 = ufs_frag_map(inode, fragment); phys64 = ufs_frag_map(inode, offsets, depth);
UFSD("phys64 = %llu\n", (unsigned long long)phys64); if (phys64) {
if (phys64) phys64 += fragment & uspi->s_fpbmask;
map_bh(bh_result, sb, phys64); map_bh(bh_result, sb, phys64);
}
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册