blob: c3fa6cfce169b1a37e29c8322956419e50f762fc [file] [log] [blame]
David Teiglandb3b94fa2006-01-16 16:50:04 +00001/*
2 * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved.
3 * Copyright (C) 2004-2005 Red Hat, Inc. All rights reserved.
4 *
5 * This copyrighted material is made available to anyone wishing to use,
6 * modify, copy, or redistribute it subject to the terms and conditions
7 * of the GNU General Public License v.2.
8 */
9
10#ifndef __INODE_DOT_H__
11#define __INODE_DOT_H__
12
13static inline int gfs2_is_stuffed(struct gfs2_inode *ip)
14{
15 return !ip->i_di.di_height;
16}
17
18static inline int gfs2_is_jdata(struct gfs2_inode *ip)
19{
20 return ip->i_di.di_flags & GFS2_DIF_JDATA;
21}
22
Steven Whitehouse18ec7d52006-02-08 11:50:51 +000023static inline int gfs2_is_dir(struct gfs2_inode *ip)
24{
25 return S_ISDIR(ip->i_di.di_mode);
26}
27
David Teiglandb3b94fa2006-01-16 16:50:04 +000028void gfs2_inode_attr_in(struct gfs2_inode *ip);
29void gfs2_inode_attr_out(struct gfs2_inode *ip);
30struct inode *gfs2_ip2v_lookup(struct gfs2_inode *ip);
31struct inode *gfs2_ip2v(struct gfs2_inode *ip);
32struct inode *gfs2_iget(struct super_block *sb, struct gfs2_inum *inum);
33
34void gfs2_inode_min_init(struct gfs2_inode *ip, unsigned int type);
35int gfs2_inode_refresh(struct gfs2_inode *ip);
36
37int gfs2_inode_get(struct gfs2_glock *i_gl,
Steven Whitehousec9fd4302006-03-01 15:31:02 -050038 const struct gfs2_inum *inum, int create,
David Teiglandb3b94fa2006-01-16 16:50:04 +000039 struct gfs2_inode **ipp);
40void gfs2_inode_hold(struct gfs2_inode *ip);
41void gfs2_inode_put(struct gfs2_inode *ip);
42void gfs2_inode_destroy(struct gfs2_inode *ip);
43
44int gfs2_inode_dealloc(struct gfs2_sbd *sdp, struct gfs2_unlinked *ul);
45
46int gfs2_change_nlink(struct gfs2_inode *ip, int diff);
Steven Whitehouse7359a192006-02-13 12:27:43 +000047int gfs2_lookupi(struct inode *dir, struct qstr *name, int is_root,
48 struct inode **ipp);
Steven Whitehouse568f4c92006-02-27 12:00:42 -050049struct inode *gfs2_createi(struct gfs2_holder *ghs, struct qstr *name,
50 unsigned int mode);
David Teiglandb3b94fa2006-01-16 16:50:04 +000051int gfs2_unlinki(struct gfs2_inode *dip, struct qstr *name,
52 struct gfs2_inode *ip, struct gfs2_unlinked *ul);
53int gfs2_rmdiri(struct gfs2_inode *dip, struct qstr *name,
54 struct gfs2_inode *ip, struct gfs2_unlinked *ul);
55int gfs2_unlink_ok(struct gfs2_inode *dip, struct qstr *name,
56 struct gfs2_inode *ip);
57int gfs2_ok_to_move(struct gfs2_inode *this, struct gfs2_inode *to);
58int gfs2_readlinki(struct gfs2_inode *ip, char **buf, unsigned int *len);
59
60int gfs2_glock_nq_atime(struct gfs2_holder *gh);
61int gfs2_glock_nq_m_atime(unsigned int num_gh, struct gfs2_holder *ghs);
62
63void gfs2_try_toss_vnode(struct gfs2_inode *ip);
64
65int gfs2_setattr_simple(struct gfs2_inode *ip, struct iattr *attr);
66
67int gfs2_repermission(struct inode *inode, int mask, struct nameidata *nd);
68
Steven Whitehousef42faf42006-01-30 18:34:10 +000069static inline int gfs2_lookup_simple(struct inode *dip, char *name,
70 struct inode **ipp)
David Teiglandb3b94fa2006-01-16 16:50:04 +000071{
72 struct qstr qstr;
Steven Whitehousef42faf42006-01-30 18:34:10 +000073 int err;
David Teiglandb3b94fa2006-01-16 16:50:04 +000074 memset(&qstr, 0, sizeof(struct qstr));
75 qstr.name = name;
76 qstr.len = strlen(name);
Steven Whitehouse7359a192006-02-13 12:27:43 +000077 err = gfs2_lookupi(dip, &qstr, 1, ipp);
Steven Whitehousef42faf42006-01-30 18:34:10 +000078 return err;
David Teiglandb3b94fa2006-01-16 16:50:04 +000079}
80
81#endif /* __INODE_DOT_H__ */
82