Whamcloud - gitweb
62be45ef7f9cba1f728e7323ef4f77367459fe4b
[fs/lustre-release.git] / lustre / include / linux / obdfs.h
1 /* object based disk file system
2  * 
3  * This software is licensed under the GPL.  See the file COPYING in the
4  * top directory of this distribution for details.
5  * 
6  * Copyright (C), 1999, Stelias Computing Inc
7  *
8  *
9  */
10
11
12 #ifndef _OBDFS_H
13 #define OBDFS_H
14 #include <linux/obd_class.h>
15 #include <linux/list.h>
16
17 /* super.c */
18 void obdfs_read_inode(struct inode *inode);
19
20 /* flush.c */
21 int flushd_init(void);
22
23
24 /* rw.c */
25 int obdfs_do_writepage(struct inode *, struct page *, int sync);
26 int obdfs_init_pgrqcache(void);
27 void obdfs_cleanup_pgrqcache(void);
28 int obdfs_readpage(struct dentry *dentry, struct page *page);
29 int obdfs_writepage(struct dentry *dentry, struct page *page);
30 struct page *obdfs_getpage(struct inode *inode, unsigned long offset, int create, int locked);
31 int obdfs_write_one_page(struct file *file, struct page *page, unsigned long offset, unsigned long bytes, const char * buf);
32 void obdfs_dequeue_reqs(struct inode *inode);
33
34 /* namei.c */
35 struct dentry *obdfs_lookup(struct inode * dir, struct dentry *dentry);
36 int obdfs_create (struct inode * dir, struct dentry * dentry, int mode);
37 int obdfs_mkdir(struct inode *dir, struct dentry *dentry, int mode);
38 int obdfs_rmdir(struct inode *dir, struct dentry *dentry);
39 int obdfs_unlink(struct inode *dir, struct dentry *dentry);
40 int obdfs_mknod(struct inode *dir, struct dentry *dentry, int mode, int rdev);
41 int obdfs_symlink(struct inode *dir, struct dentry *dentry, const char *symname);
42 int obdfs_link(struct dentry *old_dentry, struct inode *dir, struct dentry *dentry);
43 int obdfs_rename(struct inode *old_dir, struct dentry *old_dentry, struct inode *new_dir, struct dentry *new_dentry);
44 /* dir.c */
45 int obdfs_check_dir_entry (const char * function, struct inode * dir,
46                           struct ext2_dir_entry_2 * de, struct page * page,
47                           unsigned long offset);
48 /* symlink.c */
49 int obdfs_readlink (struct dentry *, char *, int);
50 struct dentry *obdfs_follow_link(struct dentry *, struct dentry *, unsigned int); 
51
52
53 /* list of all OBDFS super blocks  */
54 struct list_head obdfs_super_list;
55
56 struct obdfs_pgrq {
57         struct list_head         rq_plist;      /* linked list of req's */
58         unsigned long            rq_jiffies;
59         struct page             *rq_page;       /* page to be written */
60 };
61
62
63 inline void obdfs_pgrq_del(struct obdfs_pgrq *pgrq);
64 int obdfs_do_vec_wr(struct inode **inodes, obd_count num_io, obd_count num_oa,
65                     struct obdo **obdos, obd_count *oa_bufs,
66                     struct page **pages, char **bufs, obd_size *counts,
67                     obd_off *offsets, obd_flag *flags);
68
69
70 struct obdfs_sb_info {
71         struct list_head         osi_list;      /* list of supers */
72         struct obd_conn          osi_conn;
73         struct super_block      *osi_super;
74         struct obd_device       *osi_obd;
75         struct obd_ops          *osi_ops;
76         ino_t                    osi_rootino;   /* number of root inode */
77         int                      osi_minor;     /* minor of /dev/obdX */
78         struct list_head         osi_inodes;    /* list of dirty inodes */
79         struct semaphore         osi_list_mutex;
80 };
81
82 struct obdfs_inode_info {
83         int              oi_flags;
84         struct list_head oi_inodes;
85         struct list_head oi_pages;
86         char             oi_inline[OBD_INLINESZ];
87 };
88
89 #define OBDFS_INFO(inode) ((struct obdfs_inode_info *)(&(inode)->u.generic_ip))
90
91 static inline struct obdfs_sb_info *obdfs_i2sbi(struct inode *inode)
92 {
93         struct obdfs_sb_info *sbi;
94
95         sbi = (struct obdfs_sb_info *) &(inode->i_sb->u.generic_sbp);
96         return sbi;
97 }
98
99 static inline struct list_head *obdfs_iplist(struct inode *inode) 
100 {
101         struct obdfs_inode_info *info = (struct obdfs_inode_info *)&inode->u.generic_ip;
102
103         return &info->oi_pages;
104 }
105
106 static inline struct list_head *obdfs_islist(struct inode *inode) 
107 {
108         struct obdfs_inode_info *info = (struct obdfs_inode_info *)&inode->u.generic_ip;
109
110         return &info->oi_inodes;
111 }
112
113 static inline struct list_head *obdfs_slist(struct inode *inode) 
114 {
115         struct obdfs_sb_info *sbi = obdfs_i2sbi(inode);
116         return &sbi->osi_inodes;
117 }
118
119 #define obd_down(mutex) {\
120         CDEBUG(D_INODE, "got lock at %s, %d\n", __FUNCTION__, __LINE__);\
121         down(mutex);\
122 }
123
124 #define obd_up(mutex) {\
125         up(mutex);\
126         CDEBUG(D_INODE, "free lock at %s, %d\n", __FUNCTION__, __LINE__);\
127 }
128
129 static inline void obdfs_print_plist(struct inode *inode) 
130 {
131         struct list_head *page_list = obdfs_iplist(inode);
132         struct list_head *tmp;
133
134         CDEBUG(D_INODE, "inode %ld: page", inode->i_ino);
135         /* obd_down(&obdfs_i2sbi(inode)->osi_list_mutex); */
136         if (list_empty(page_list)) {
137                 printk(" list empty\n");
138                 obd_up(&obdfs_i2sbi(inode)->osi_list_mutex);
139                 return;
140         }
141
142         tmp = page_list;
143         while ( (tmp = tmp->next) != page_list) {
144                 struct obdfs_pgrq *pgrq;
145                 pgrq = list_entry(tmp, struct obdfs_pgrq, rq_plist);
146                 printk(" %p", pgrq->rq_page);
147         }
148         printk("\n");
149         /* obd_up(&obdfs_i2sbi(inode)->osi_list_mutex); */
150 }
151
152 void obdfs_sysctl_init(void);
153 void obdfs_sysctl_clean(void);
154
155 extern struct file_operations obdfs_file_operations;
156 extern struct inode_operations obdfs_file_inode_operations;
157 extern struct inode_operations obdfs_dir_inode_operations;
158 extern struct inode_operations obdfs_symlink_inode_operations;
159
160 static inline int obdfs_has_inline(struct inode *inode)
161 {
162         return (OBDFS_INFO(inode)->oi_flags & OBD_FL_INLINEDATA);
163 }
164
165 static void inline obdfs_from_inode(struct obdo *oa, struct inode *inode)
166 {
167         struct obdfs_inode_info *oinfo = OBDFS_INFO(inode);
168
169         CDEBUG(D_INODE, "src inode %ld, dst obdo %ld valid 0x%08x\n",
170                inode->i_ino, (long)oa->o_id, oa->o_valid);
171         obdo_from_inode(oa, inode);
172         if (obdfs_has_inline(inode)) {
173                 CDEBUG(D_INODE, "copying inline data from inode to obdo\n");
174                 memcpy(oa->o_inline, oinfo->oi_inline, OBD_INLINESZ);
175                 oa->o_obdflags |= OBD_FL_INLINEDATA;
176                 oa->o_valid |= OBD_MD_FLINLINE;
177         }
178 } /* obdfs_from_inode */
179
180 static void inline obdfs_to_inode(struct inode *inode, struct obdo *oa)
181 {
182         struct obdfs_inode_info *oinfo = OBDFS_INFO(inode);
183
184         CDEBUG(D_INODE, "src obdo %ld valid 0x%08x, dst inode %ld\n",
185                (long)oa->o_id, oa->o_valid, inode->i_ino);
186         obdo_to_inode(inode, oa);
187
188         if (obdo_has_inline(oa)) {
189                 CDEBUG(D_INODE, "copying inline data from obdo to inode\n");
190                 memcpy(oinfo->oi_inline, oa->o_inline, OBD_INLINESZ);
191                 oinfo->oi_flags |= OBD_FL_INLINEDATA;
192         }
193 } /* obdfs_to_inode */
194
195 #define NOLOCK 0
196 #define LOCKED 1
197
198 #ifdef OPS
199 #warning "*** WARNING redefining OPS"
200 #else
201 #define OPS(sb,op) ((struct obdfs_sb_info *)(& ## sb ## ->u.generic_sbp))->osi_ops->o_ ## op
202 #define IOPS(inode,op) ((struct obdfs_sb_info *)(& ## inode->i_sb ## ->u.generic_sbp))->osi_ops->o_ ## op
203 #endif
204
205 #ifdef ID
206 #warning "*** WARNING redefining ID"
207 #else
208 #define ID(sb) (&((struct obdfs_sb_info *)( & ## sb ## ->u.generic_sbp))->osi_conn)
209 #define IID(inode) (&((struct obdfs_sb_info *)( & ## inode->i_sb ## ->u.generic_sbp))->osi_conn)
210 #endif
211
212 #define OBDFS_SUPER_MAGIC 0x4711
213
214 #endif
215