1 /* object based disk file system
3 * This code is issued under the GNU General Public License.
4 * See the file COPYING in this distribution
6 * Copyright (C), 1999, Stelias Computing Inc
14 #include <linux/obd_class.h>
15 #include <linux/obdo.h>
16 #include <linux/list.h>
18 #define LL_SUPER_MAGIC 0x0BD00BD0;
20 struct ll_inode_info {
23 char lli_inline[OBD_INLINESZ];
27 struct list_head ll_list; /* list of supers */
28 struct obd_conn ll_conn;
29 struct super_block *ll_super;
30 // struct obd_device *ll_obd;
31 //struct obd_ops *ll_ops;
32 ino_t ll_rootino; /* number of root inode */
33 int ll_minor; /* minor of /dev/obdX */
34 struct list_head ll_inodes; /* list of dirty inodes */
35 unsigned long ll_cache_count;
36 struct semaphore ll_list_mutex;
40 static inline struct ll_inode_info *ll_i2info(struct inode *inode)
42 return (struct ll_inode_info *)&(inode->u.generic_ip);
45 static inline int ll_has_inline(struct inode *inode)
47 return (ll_i2info(inode)->lli_flags & OBD_FL_INLINEDATA);
58 struct list_head rq_plist; /* linked list of req's */
59 unsigned long rq_jiffies;
60 struct page *rq_page; /* page to be written */
63 extern struct list_head ll_super_list; /* list of all LL superblocks */
68 #define EXT2_DIR_PAD 4
69 #define EXT2_DIR_ROUND (EXT2_DIR_PAD - 1)
70 #define EXT2_DIR_REC_LEN(name_len) (((name_len) + 8 + EXT2_DIR_ROUND) & \
72 #define EXT2_NAME_LEN 255
74 int ll_check_dir_entry (const char * function, struct inode * dir,
75 struct ext2_dir_entry_2 * de, struct page * page,
76 unsigned long offset);
77 extern struct file_operations ll_dir_operations;
78 extern struct inode_operations ll_dir_inode_operations;
81 extern struct file_operations ll_file_operations;
82 extern struct inode_operations ll_file_inode_operations;
85 void ll_dequeue_pages(struct inode *inode);
86 int ll_flushd_init(void);
87 int ll_flushd_cleanup(void);
88 int ll_flush_reqs(struct list_head *inode_list, unsigned long check_time);
89 int ll_flush_dirty_pages(unsigned long check_time);
93 * Structure of the super block
97 #define EXT2_SB(sb) (&((sb)->u.ext2_sb))
99 * Maximal count of links to a file
101 #define EXT2_LINK_MAX 32000
103 * Ext2 directory file types. Only the low 3 bits are used. The
104 * other bits are reserved for now.
106 #define EXT2_FT_UNKNOWN 0
107 #define EXT2_FT_REG_FILE 1
108 #define EXT2_FT_DIR 2
109 #define EXT2_FT_CHRDEV 3
110 #define EXT2_FT_BLKDEV 4
111 #define EXT2_FT_FIFO 5
112 #define EXT2_FT_SOCK 6
113 #define EXT2_FT_SYMLINK 7
115 #define EXT2_FT_MAX 8
117 #define EXT2_BTREE_FL 0x00001000 /* btree format dir */
118 #define EXT2_RESERVED_FL 0x80000000 /* reserved for ext2 lib */
119 #define EXT2_FEATURE_INCOMPAT_FILETYPE 0x0002
120 #define EXT2_HAS_COMPAT_FEATURE(sb,mask) \
121 ( EXT2_SB(sb)->s_es->s_feature_compat & cpu_to_le32(mask) )
122 #define EXT2_HAS_INCOMPAT_FEATURE(sb,mask) \
123 ( EXT2_SB(sb)->s_es->s_feature_incompat & cpu_to_le32(mask) )
126 int ll_do_writepage(struct page *, int sync);
127 int ll_init_pgrqcache(void);
128 void ll_cleanup_pgrqcache(void);
129 inline void ll_pgrq_del(struct ll_pgrq *pgrq);
130 int ll_readpage(struct file *file, struct page *page);
131 int ll_prepare_write(struct file *file, struct page *page, unsigned from, unsigned to);
132 int ll_commit_write(struct file *file, struct page *page, unsigned from, unsigned to);
133 int ll_writepage(struct page *page);
134 struct page *ll_getpage(struct inode *inode, unsigned long offset,
135 int create, int locked);
136 int ll_write_one_page(struct file *file, struct page *page,
137 unsigned long offset, unsigned long bytes,
139 int ll_do_vec_wr(struct inode **inodes, obd_count num_io, obd_count num_oa,
140 struct obdo **obdos, obd_count *oa_bufs,
141 struct page **pages, char **bufs, obd_size *counts,
142 obd_off *offsets, obd_flag *flags);
143 void ll_truncate(struct inode *inode);
146 extern long ll_cache_count;
147 extern long ll_mutex_start;
150 extern struct inode_operations ll_fast_symlink_inode_operations;
151 extern struct inode_operations ll_symlink_inode_operations;
154 void ll_sysctl_init(void);
155 void ll_sysctl_clean(void);
157 static inline struct ll_sb_info *ll_i2sbi(struct inode *inode)
159 return (struct ll_sb_info *) &(inode->i_sb->u.generic_sbp);
163 static inline struct list_head *ll_slist(struct inode *inode)
165 struct ll_sb_info *sbi = ll_i2sbi(inode);
167 return &sbi->ll_inodes;
170 static void inline ll_set_size (struct inode *inode, obd_size size)
172 inode->i_size = size;
173 inode->i_blocks = (inode->i_size + inode->i_sb->s_blocksize - 1) >>
174 inode->i_sb->s_blocksize_bits;
179 #define obd_down(mutex) { \
180 /* CDEBUG(D_INFO, "get lock\n"); */ \
181 ll_mutex_start = jiffies; \
183 if (jiffies - ll_mutex_start) \
184 CDEBUG(D_CACHE, "waited on mutex %ld jiffies\n", \
185 jiffies - ll_mutex_start); \
188 #define obd_up(mutex) { \
190 if (jiffies - ll_mutex_start > 1) \
191 CDEBUG(D_CACHE, "held mutex for %ld jiffies\n", \
192 jiffies - ll_mutex_start); \
193 /* CDEBUG(D_INFO, "free lock\n"); */ \
196 /* We track if a page has been added to the OBD page cache by stting a
197 * flag on the page. We have chosen a bit that will hopefully not be
200 #define PG_obdcache 29
201 #define OBDAddCachePage(page) test_and_set_bit(PG_obdcache, &(page)->flags)
202 #define OBDClearCachePage(page) clear_bit(PG_obdcache, &(page)->flags)