ocfs2: Provide convenience function for ino lookup

A couple paths which needed to just match a parent dir + name pair to an
inode number were a bit messy because they had to deal with
ocfs2_find_files_on_disk() which returns a larger number of values. Provide
a convenience function, ocfs2_lookup_ino_from_name() which internalizes all
the extra accounting.

Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
Reviewed-by: Joel Becker <joel.becker@oracle.com>
This commit is contained in:
Mark Fasheh 2007-09-11 15:22:06 -07:00
parent 0bfbbf62a8
commit be94d11704
5 changed files with 25 additions and 21 deletions

View file

@ -628,6 +628,23 @@ int ocfs2_find_files_on_disk(const char *name,
return status; return status;
} }
/*
* Convenience function for callers which just want the block number
* mapped to a name and don't require the full dirent info, etc.
*/
int ocfs2_lookup_ino_from_name(struct inode *dir, const char *name,
int namelen, u64 *blkno)
{
int ret;
struct buffer_head *bh = NULL;
struct ocfs2_dir_entry *dirent = NULL;
ret = ocfs2_find_files_on_disk(name, namelen, blkno, dir, &bh, &dirent);
brelse(bh);
return ret;
}
/* Check for a name within a directory. /* Check for a name within a directory.
* *
* Return 0 if the name does not exist * Return 0 if the name does not exist

View file

@ -61,6 +61,8 @@ int ocfs2_find_files_on_disk(const char *name,
struct inode *inode, struct inode *inode,
struct buffer_head **dirent_bh, struct buffer_head **dirent_bh,
struct ocfs2_dir_entry **dirent); struct ocfs2_dir_entry **dirent);
int ocfs2_lookup_ino_from_name(struct inode *dir, const char *name,
int namelen, u64 *blkno);
int ocfs2_readdir(struct file *filp, void *dirent, filldir_t filldir); int ocfs2_readdir(struct file *filp, void *dirent, filldir_t filldir);
int ocfs2_dir_foreach(struct inode *inode, loff_t *f_pos, void *priv, int ocfs2_dir_foreach(struct inode *inode, loff_t *f_pos, void *priv,
filldir_t filldir); filldir_t filldir);

View file

@ -88,8 +88,6 @@ static struct dentry *ocfs2_get_parent(struct dentry *child)
struct dentry *parent; struct dentry *parent;
struct inode *inode; struct inode *inode;
struct inode *dir = child->d_inode; struct inode *dir = child->d_inode;
struct buffer_head *dirent_bh = NULL;
struct ocfs2_dir_entry *dirent;
mlog_entry("(0x%p, '%.*s')\n", child, mlog_entry("(0x%p, '%.*s')\n", child,
child->d_name.len, child->d_name.name); child->d_name.len, child->d_name.name);
@ -105,8 +103,7 @@ static struct dentry *ocfs2_get_parent(struct dentry *child)
goto bail; goto bail;
} }
status = ocfs2_find_files_on_disk("..", 2, &blkno, dir, &dirent_bh, status = ocfs2_lookup_ino_from_name(dir, "..", 2, &blkno);
&dirent);
if (status < 0) { if (status < 0) {
parent = ERR_PTR(-ENOENT); parent = ERR_PTR(-ENOENT);
goto bail_unlock; goto bail_unlock;
@ -131,9 +128,6 @@ static struct dentry *ocfs2_get_parent(struct dentry *child)
bail_unlock: bail_unlock:
ocfs2_meta_unlock(dir, 0); ocfs2_meta_unlock(dir, 0);
if (dirent_bh)
brelse(dirent_bh);
bail: bail:
mlog_exit_ptr(parent); mlog_exit_ptr(parent);

View file

@ -101,10 +101,8 @@ static struct dentry *ocfs2_lookup(struct inode *dir, struct dentry *dentry,
{ {
int status; int status;
u64 blkno; u64 blkno;
struct buffer_head *dirent_bh = NULL;
struct inode *inode = NULL; struct inode *inode = NULL;
struct dentry *ret; struct dentry *ret;
struct ocfs2_dir_entry *dirent;
struct ocfs2_inode_info *oi; struct ocfs2_inode_info *oi;
mlog_entry("(0x%p, 0x%p, '%.*s')\n", dir, dentry, mlog_entry("(0x%p, 0x%p, '%.*s')\n", dir, dentry,
@ -126,9 +124,8 @@ static struct dentry *ocfs2_lookup(struct inode *dir, struct dentry *dentry,
goto bail; goto bail;
} }
status = ocfs2_find_files_on_disk(dentry->d_name.name, status = ocfs2_lookup_ino_from_name(dir, dentry->d_name.name,
dentry->d_name.len, &blkno, dentry->d_name.len, &blkno);
dir, &dirent_bh, &dirent);
if (status < 0) if (status < 0)
goto bail_add; goto bail_add;
@ -183,8 +180,6 @@ static struct dentry *ocfs2_lookup(struct inode *dir, struct dentry *dentry,
ocfs2_meta_unlock(dir, 0); ocfs2_meta_unlock(dir, 0);
bail: bail:
if (dirent_bh)
brelse(dirent_bh);
mlog_exit_ptr(ret); mlog_exit_ptr(ret);

View file

@ -100,17 +100,14 @@ static struct inode * _ocfs2_get_system_file_inode(struct ocfs2_super *osb,
char namebuf[40]; char namebuf[40];
struct inode *inode = NULL; struct inode *inode = NULL;
u64 blkno; u64 blkno;
struct buffer_head *dirent_bh = NULL;
struct ocfs2_dir_entry *de = NULL;
int status = 0; int status = 0;
ocfs2_sprintf_system_inode_name(namebuf, ocfs2_sprintf_system_inode_name(namebuf,
sizeof(namebuf), sizeof(namebuf),
type, slot); type, slot);
status = ocfs2_find_files_on_disk(namebuf, strlen(namebuf), status = ocfs2_lookup_ino_from_name(osb->sys_root_inode, namebuf,
&blkno, osb->sys_root_inode, strlen(namebuf), &blkno);
&dirent_bh, &de);
if (status < 0) { if (status < 0) {
goto bail; goto bail;
} }
@ -122,8 +119,7 @@ static struct inode * _ocfs2_get_system_file_inode(struct ocfs2_super *osb,
goto bail; goto bail;
} }
bail: bail:
if (dirent_bh)
brelse(dirent_bh);
return inode; return inode;
} }