Whamcloud - gitweb
Pass 64-bit object numbers wherever possible, instead of truncating to 32-bit.
[fs/lustre-release.git] / lustre / include / linux / obdfs.h
1 /* object based disk file system
2  * 
3  * This code is issued under the GNU General Public License.
4  * See the file COPYING in this distribution
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 static inline struct obdo *obdo_fromid(struct lustre_handle *conn, obd_id id,
18                                        obd_mode mode, obd_flag valid)
19 {
20         struct obdo *oa;
21         int err;
22
23         ENTRY;
24         oa = obdo_alloc();
25         if ( !oa ) {
26                 RETURN(ERR_PTR(-ENOMEM));
27         }
28
29         oa->o_id = id;
30         oa->o_mode = mode;
31         oa->o_valid = valid;
32         if ((err = obd_getattr(conn, oa))) {
33                 obdo_free(oa);
34                 RETURN(ERR_PTR(err));
35         }
36         RETURN(oa);
37 }
38
39
40 struct obdfs_inode_info {
41         int              oi_flags;
42         struct list_head oi_inodes;
43         struct list_head oi_pages;
44         char             oi_inline[OBD_INLINESZ];
45 };
46
47 struct obdfs_sb_info {
48         struct list_head         osi_list;      /* list of supers */
49         struct lustre_handle          osi_conn;
50         struct super_block      *osi_super;
51         struct obd_device       *osi_obd;
52         ino_t                    osi_rootino;   /* number of root inode */
53         int                      osi_minor;     /* minor of /dev/obdX */
54         struct list_head         osi_inodes;    /* list of dirty inodes */
55         unsigned long            osi_cache_count;
56         struct semaphore         osi_list_mutex;
57 };
58
59
60 static inline struct obdfs_inode_info *obdfs_i2info(struct inode *inode)
61 {
62         return (struct obdfs_inode_info *)&(inode->u.generic_ip);
63 }
64
65 static inline int obdfs_has_inline(struct inode *inode)
66 {
67         return (obdfs_i2info(inode)->oi_flags & OBD_FL_INLINEDATA);
68 }
69
70 static void inline obdfs_from_inode(struct obdo *oa, struct inode *inode)
71 {
72         struct obdfs_inode_info *oinfo = obdfs_i2info(inode);
73
74         CDEBUG(D_INFO, "src inode %ld, dst obdo %ld valid 0x%08x\n",
75                inode->i_ino, (long)oa->o_id, oa->o_valid);
76         obdo_from_inode(oa, inode);
77         if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) {
78                 CDEBUG(D_INODE, "copying device %x from inode to obdo\n",
79                        inode->i_rdev);
80                 *((obd_rdev *)oa->o_inline) = kdev_t_to_nr(inode->i_rdev);
81                 oa->o_obdflags |= OBD_FL_INLINEDATA;
82                 oa->o_valid |= OBD_MD_FLINLINE;
83         } else if (obdfs_has_inline(inode)) {
84                 CDEBUG(D_INODE, "copying inline data from inode to obdo\n");
85                 memcpy(oa->o_inline, oinfo->oi_inline, OBD_INLINESZ);
86                 oa->o_obdflags |= OBD_FL_INLINEDATA;
87                 oa->o_valid |= OBD_MD_FLINLINE;
88         }
89 } /* obdfs_from_inode */
90
91 static void inline obdfs_to_inode(struct inode *inode, struct obdo *oa)
92 {
93         struct obdfs_inode_info *oinfo = obdfs_i2info(inode);
94
95         CDEBUG(D_INFO, "src obdo %ld valid 0x%08x, dst inode %ld\n",
96                (long)oa->o_id, oa->o_valid, inode->i_ino);
97
98         obdo_to_inode(inode, oa);
99
100         if (obdo_has_inline(oa)) {
101                 if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode) ||
102                     S_ISFIFO(inode->i_mode)) {
103                         obd_rdev rdev = *((obd_rdev *)oa->o_inline);
104                         CDEBUG(D_INODE,
105                                "copying device %x from obdo to inode\n", rdev);
106                         init_special_inode(inode, inode->i_mode, rdev);
107                 } else {
108                         CDEBUG(D_INFO, "copying inline from obdo to inode\n");
109                         memcpy(oinfo->oi_inline, oa->o_inline, OBD_INLINESZ);
110                 }
111                 oinfo->oi_flags |= OBD_FL_INLINEDATA;
112         }
113 } /* obdfs_to_inode */
114
115 #define NOLOCK 0
116 #define LOCKED 1
117
118 #ifdef OPS
119 #warning "*** WARNING redefining OPS"
120 #else
121 #define OPS(sb,op) ((struct obdfs_sb_info *)(& (sb)->u.generic_sbp))->osi_ops->o_ ## op
122 #define IOPS(inode,op) ((struct obdfs_sb_info *)(&(inode)->i_sb->u.generic_sbp))->osi_ops->o_ ## op
123 #endif
124
125 #ifdef ID
126 #warning "*** WARNING redefining ID"
127 #else
128 #define ID(sb) (&((struct obdfs_sb_info *)( &(sb)->u.generic_sbp))->osi_conn)
129 #define IID(inode) (&((struct obdfs_sb_info *)( &(inode)->i_sb->u.generic_sbp))->osi_conn)
130 #endif
131
132 #define OBDFS_SUPER_MAGIC 0x4711
133
134 /* super.c */ 
135 struct obdfs_pgrq {
136         struct list_head         rq_plist;      /* linked list of req's */
137         unsigned long            rq_jiffies;
138         struct page             *rq_page;       /* page to be written */
139 };
140
141 extern struct list_head obdfs_super_list;       /* list of all OBDFS superblocks */
142
143
144
145 /* dir.c */
146 extern struct file_operations obdfs_dir_operations;
147 extern struct inode_operations obdfs_dir_inode_operations;
148
149 /* file.c */
150 extern struct file_operations obdfs_file_operations;
151 extern struct inode_operations obdfs_file_inode_operations;
152
153 /* flush.c */
154 void obdfs_dequeue_pages(struct inode *inode);
155 int obdfs_flushd_init(void);
156 int obdfs_flushd_cleanup(void);
157 int obdfs_flush_reqs(struct list_head *inode_list, unsigned long check_time);
158 int obdfs_flush_dirty_pages(unsigned long check_time);
159
160 /* namei.c */
161
162 /* rw.c */
163 int obdfs_do_writepage(struct page *, int sync);
164 int obdfs_init_pgrqcache(void);
165 void obdfs_cleanup_pgrqcache(void);
166 inline void obdfs_pgrq_del(struct obdfs_pgrq *pgrq);
167 int obdfs_readpage(struct file *file, struct page *page);
168 int obdfs_prepare_write(struct file *file, struct page *page, unsigned from, unsigned to);
169 int obdfs_commit_write(struct file *file, struct page *page, unsigned from, unsigned to);
170 int obdfs_writepage(struct page *page);
171 struct page *obdfs_getpage(struct inode *inode, unsigned long offset,
172                            int create, int locked);
173 int obdfs_write_one_page(struct file *file, struct page *page,
174                          unsigned long offset, unsigned long bytes,
175                          const char * buf);
176 int obdfs_do_vec_wr(struct inode **inodes, obd_count num_io, obd_count num_oa,
177                     struct obdo **obdos, obd_count *oa_bufs,
178                     struct page **pages, char **bufs, obd_size *counts,
179                     obd_off *offsets, obd_flag *flags);
180 void obdfs_truncate(struct inode *inode);
181
182 /* super.c */
183 extern long obdfs_cache_count;
184 extern long obdfs_mutex_start;
185
186 /* symlink.c */
187 extern struct inode_operations obdfs_fast_symlink_inode_operations;
188 extern struct inode_operations obdfs_symlink_inode_operations;
189
190 /* sysctl.c */
191 void obdfs_sysctl_init(void);
192 void obdfs_sysctl_clean(void);
193
194 static inline struct obdfs_sb_info *obdfs_i2sbi(struct inode *inode)
195 {
196         return (struct obdfs_sb_info *) &(inode->i_sb->u.generic_sbp);
197 }
198
199 static inline struct list_head *obdfs_iplist(struct inode *inode) 
200 {
201         struct obdfs_inode_info *info = obdfs_i2info(inode);
202
203         return &info->oi_pages;
204 }
205
206 static inline struct list_head *obdfs_islist(struct inode *inode) 
207 {
208         struct obdfs_inode_info *info = obdfs_i2info(inode);
209
210         return &info->oi_inodes;
211 }
212
213 static inline struct list_head *obdfs_slist(struct inode *inode) 
214 {
215         struct obdfs_sb_info *sbi = obdfs_i2sbi(inode);
216
217         return &sbi->osi_inodes;
218 }
219
220 static void inline obdfs_set_size (struct inode *inode, obd_size size)
221 {  
222        inode->i_size = size;
223        inode->i_blocks = (inode->i_size + inode->i_sb->s_blocksize - 1) >>
224                inode->i_sb->s_blocksize_bits;
225 } /* obdfs_set_size */
226
227 #endif
228