GFS2: Fix uninitialized VFS inode in gfs2_create_inode
[linux-2.6/btrfs-unstable.git] / fs / gfs2 / incore.h
blobbdf70c18610cfafd26d8d475e7ea939d54487a44
1 /*
2 * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved.
3 * Copyright (C) 2004-2008 Red Hat, Inc. All rights reserved.
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 version 2.
8 */
10 #ifndef __INCORE_DOT_H__
11 #define __INCORE_DOT_H__
13 #include <linux/fs.h>
14 #include <linux/kobject.h>
15 #include <linux/workqueue.h>
16 #include <linux/dlm.h>
17 #include <linux/buffer_head.h>
18 #include <linux/rcupdate.h>
19 #include <linux/rculist_bl.h>
20 #include <linux/completion.h>
21 #include <linux/rbtree.h>
22 #include <linux/ktime.h>
23 #include <linux/percpu.h>
24 #include <linux/lockref.h>
26 #define DIO_WAIT 0x00000010
27 #define DIO_METADATA 0x00000020
29 struct gfs2_log_operations;
30 struct gfs2_bufdata;
31 struct gfs2_holder;
32 struct gfs2_glock;
33 struct gfs2_quota_data;
34 struct gfs2_trans;
35 struct gfs2_jdesc;
36 struct gfs2_sbd;
37 struct lm_lockops;
39 typedef void (*gfs2_glop_bh_t) (struct gfs2_glock *gl, unsigned int ret);
41 struct gfs2_log_header_host {
42 u64 lh_sequence; /* Sequence number of this transaction */
43 u32 lh_flags; /* GFS2_LOG_HEAD_... */
44 u32 lh_tail; /* Block number of log tail */
45 u32 lh_blkno;
46 u32 lh_hash;
50 * Structure of operations that are associated with each
51 * type of element in the log.
54 struct gfs2_log_operations {
55 void (*lo_before_commit) (struct gfs2_sbd *sdp, struct gfs2_trans *tr);
56 void (*lo_after_commit) (struct gfs2_sbd *sdp, struct gfs2_trans *tr);
57 void (*lo_before_scan) (struct gfs2_jdesc *jd,
58 struct gfs2_log_header_host *head, int pass);
59 int (*lo_scan_elements) (struct gfs2_jdesc *jd, unsigned int start,
60 struct gfs2_log_descriptor *ld, __be64 *ptr,
61 int pass);
62 void (*lo_after_scan) (struct gfs2_jdesc *jd, int error, int pass);
63 const char *lo_name;
66 #define GBF_FULL 1
68 struct gfs2_bitmap {
69 struct buffer_head *bi_bh;
70 char *bi_clone;
71 unsigned long bi_flags;
72 u32 bi_offset;
73 u32 bi_start;
74 u32 bi_len;
75 u32 bi_blocks;
78 struct gfs2_rgrpd {
79 struct rb_node rd_node; /* Link with superblock */
80 struct gfs2_glock *rd_gl; /* Glock for this rgrp */
81 u64 rd_addr; /* grp block disk address */
82 u64 rd_data0; /* first data location */
83 u32 rd_length; /* length of rgrp header in fs blocks */
84 u32 rd_data; /* num of data blocks in rgrp */
85 u32 rd_bitbytes; /* number of bytes in data bitmaps */
86 u32 rd_free;
87 u32 rd_reserved; /* number of blocks reserved */
88 u32 rd_free_clone;
89 u32 rd_dinodes;
90 u64 rd_igeneration;
91 struct gfs2_bitmap *rd_bits;
92 struct gfs2_sbd *rd_sbd;
93 struct gfs2_rgrp_lvb *rd_rgl;
94 u32 rd_last_alloc;
95 u32 rd_flags;
96 u32 rd_extfail_pt; /* extent failure point */
97 #define GFS2_RDF_CHECK 0x10000000 /* check for unlinked inodes */
98 #define GFS2_RDF_UPTODATE 0x20000000 /* rg is up to date */
99 #define GFS2_RDF_ERROR 0x40000000 /* error in rg */
100 #define GFS2_RDF_MASK 0xf0000000 /* mask for internal flags */
101 spinlock_t rd_rsspin; /* protects reservation related vars */
102 struct rb_root rd_rstree; /* multi-block reservation tree */
105 struct gfs2_rbm {
106 struct gfs2_rgrpd *rgd;
107 u32 offset; /* The offset is bitmap relative */
108 int bii; /* Bitmap index */
111 static inline struct gfs2_bitmap *rbm_bi(const struct gfs2_rbm *rbm)
113 return rbm->rgd->rd_bits + rbm->bii;
116 static inline u64 gfs2_rbm_to_block(const struct gfs2_rbm *rbm)
118 return rbm->rgd->rd_data0 + (rbm_bi(rbm)->bi_start * GFS2_NBBY) +
119 rbm->offset;
122 static inline bool gfs2_rbm_eq(const struct gfs2_rbm *rbm1,
123 const struct gfs2_rbm *rbm2)
125 return (rbm1->rgd == rbm2->rgd) && (rbm1->bii == rbm2->bii) &&
126 (rbm1->offset == rbm2->offset);
129 enum gfs2_state_bits {
130 BH_Pinned = BH_PrivateStart,
131 BH_Escaped = BH_PrivateStart + 1,
132 BH_Zeronew = BH_PrivateStart + 2,
135 BUFFER_FNS(Pinned, pinned)
136 TAS_BUFFER_FNS(Pinned, pinned)
137 BUFFER_FNS(Escaped, escaped)
138 TAS_BUFFER_FNS(Escaped, escaped)
139 BUFFER_FNS(Zeronew, zeronew)
140 TAS_BUFFER_FNS(Zeronew, zeronew)
142 struct gfs2_bufdata {
143 struct buffer_head *bd_bh;
144 struct gfs2_glock *bd_gl;
145 u64 bd_blkno;
147 struct list_head bd_list;
148 const struct gfs2_log_operations *bd_ops;
150 struct gfs2_trans *bd_tr;
151 struct list_head bd_ail_st_list;
152 struct list_head bd_ail_gl_list;
156 * Internally, we prefix things with gdlm_ and GDLM_ (for gfs-dlm) since a
157 * prefix of lock_dlm_ gets awkward.
160 #define GDLM_STRNAME_BYTES 25
161 #define GDLM_LVB_SIZE 32
164 * ls_recover_flags:
166 * DFL_BLOCK_LOCKS: dlm is in recovery and will grant locks that had been
167 * held by failed nodes whose journals need recovery. Those locks should
168 * only be used for journal recovery until the journal recovery is done.
169 * This is set by the dlm recover_prep callback and cleared by the
170 * gfs2_control thread when journal recovery is complete. To avoid
171 * races between recover_prep setting and gfs2_control clearing, recover_spin
172 * is held while changing this bit and reading/writing recover_block
173 * and recover_start.
175 * DFL_NO_DLM_OPS: dlm lockspace ops/callbacks are not being used.
177 * DFL_FIRST_MOUNT: this node is the first to mount this fs and is doing
178 * recovery of all journals before allowing other nodes to mount the fs.
179 * This is cleared when FIRST_MOUNT_DONE is set.
181 * DFL_FIRST_MOUNT_DONE: this node was the first mounter, and has finished
182 * recovery of all journals, and now allows other nodes to mount the fs.
184 * DFL_MOUNT_DONE: gdlm_mount has completed successfully and cleared
185 * BLOCK_LOCKS for the first time. The gfs2_control thread should now
186 * control clearing BLOCK_LOCKS for further recoveries.
188 * DFL_UNMOUNT: gdlm_unmount sets to keep sdp off gfs2_control_wq.
190 * DFL_DLM_RECOVERY: set while dlm is in recovery, between recover_prep()
191 * and recover_done(), i.e. set while recover_block == recover_start.
194 enum {
195 DFL_BLOCK_LOCKS = 0,
196 DFL_NO_DLM_OPS = 1,
197 DFL_FIRST_MOUNT = 2,
198 DFL_FIRST_MOUNT_DONE = 3,
199 DFL_MOUNT_DONE = 4,
200 DFL_UNMOUNT = 5,
201 DFL_DLM_RECOVERY = 6,
204 struct lm_lockname {
205 u64 ln_number;
206 unsigned int ln_type;
209 #define lm_name_equal(name1, name2) \
210 (((name1)->ln_number == (name2)->ln_number) && \
211 ((name1)->ln_type == (name2)->ln_type))
214 struct gfs2_glock_operations {
215 void (*go_sync) (struct gfs2_glock *gl);
216 int (*go_xmote_bh) (struct gfs2_glock *gl, struct gfs2_holder *gh);
217 void (*go_inval) (struct gfs2_glock *gl, int flags);
218 int (*go_demote_ok) (const struct gfs2_glock *gl);
219 int (*go_lock) (struct gfs2_holder *gh);
220 void (*go_unlock) (struct gfs2_holder *gh);
221 void (*go_dump)(struct seq_file *seq, const struct gfs2_glock *gl);
222 void (*go_callback)(struct gfs2_glock *gl, bool remote);
223 const int go_type;
224 const unsigned long go_flags;
225 #define GLOF_ASPACE 1
226 #define GLOF_LVB 2
229 enum {
230 GFS2_LKS_SRTT = 0, /* Non blocking smoothed round trip time */
231 GFS2_LKS_SRTTVAR = 1, /* Non blocking smoothed variance */
232 GFS2_LKS_SRTTB = 2, /* Blocking smoothed round trip time */
233 GFS2_LKS_SRTTVARB = 3, /* Blocking smoothed variance */
234 GFS2_LKS_SIRT = 4, /* Smoothed Inter-request time */
235 GFS2_LKS_SIRTVAR = 5, /* Smoothed Inter-request variance */
236 GFS2_LKS_DCOUNT = 6, /* Count of dlm requests */
237 GFS2_LKS_QCOUNT = 7, /* Count of gfs2_holder queues */
238 GFS2_NR_LKSTATS
241 struct gfs2_lkstats {
242 s64 stats[GFS2_NR_LKSTATS];
245 enum {
246 /* States */
247 HIF_HOLDER = 6, /* Set for gh that "holds" the glock */
248 HIF_FIRST = 7,
249 HIF_WAIT = 10,
252 struct gfs2_holder {
253 struct list_head gh_list;
255 struct gfs2_glock *gh_gl;
256 struct pid *gh_owner_pid;
257 unsigned int gh_state;
258 unsigned gh_flags;
260 int gh_error;
261 unsigned long gh_iflags; /* HIF_... */
262 unsigned long gh_ip;
265 /* Resource group multi-block reservation, in order of appearance:
267 Step 1. Function prepares to write, allocates a mb, sets the size hint.
268 Step 2. User calls inplace_reserve to target an rgrp, sets the rgrp info
269 Step 3. Function get_local_rgrp locks the rgrp, determines which bits to use
270 Step 4. Bits are assigned from the rgrp based on either the reservation
271 or wherever it can.
274 struct gfs2_blkreserv {
275 /* components used during write (step 1): */
276 atomic_t rs_sizehint; /* hint of the write size */
278 struct gfs2_holder rs_rgd_gh; /* Filled in by get_local_rgrp */
279 struct rb_node rs_node; /* link to other block reservations */
280 struct gfs2_rbm rs_rbm; /* Start of reservation */
281 u32 rs_free; /* how many blocks are still free */
282 u64 rs_inum; /* Inode number for reservation */
284 /* ancillary quota stuff */
285 struct gfs2_quota_data *rs_qa_qd[2 * MAXQUOTAS];
286 struct gfs2_holder rs_qa_qd_ghs[2 * MAXQUOTAS];
287 unsigned int rs_qa_qd_num;
291 * Allocation parameters
292 * @target: The number of blocks we'd ideally like to allocate
293 * @aflags: The flags (e.g. Orlov flag)
295 * The intent is to gradually expand this structure over time in
296 * order to give more information, e.g. alignment, min extent size
297 * to the allocation code.
299 struct gfs2_alloc_parms {
300 u32 target;
301 u32 aflags;
304 enum {
305 GLF_LOCK = 1,
306 GLF_DEMOTE = 3,
307 GLF_PENDING_DEMOTE = 4,
308 GLF_DEMOTE_IN_PROGRESS = 5,
309 GLF_DIRTY = 6,
310 GLF_LFLUSH = 7,
311 GLF_INVALIDATE_IN_PROGRESS = 8,
312 GLF_REPLY_PENDING = 9,
313 GLF_INITIAL = 10,
314 GLF_FROZEN = 11,
315 GLF_QUEUED = 12,
316 GLF_LRU = 13,
317 GLF_OBJECT = 14, /* Used only for tracing */
318 GLF_BLOCKING = 15,
321 struct gfs2_glock {
322 struct hlist_bl_node gl_list;
323 struct gfs2_sbd *gl_sbd;
324 unsigned long gl_flags; /* GLF_... */
325 struct lm_lockname gl_name;
327 struct lockref gl_lockref;
328 #define gl_spin gl_lockref.lock
330 /* State fields protected by gl_spin */
331 unsigned int gl_state:2, /* Current state */
332 gl_target:2, /* Target state */
333 gl_demote_state:2, /* State requested by remote node */
334 gl_req:2, /* State in last dlm request */
335 gl_reply:8; /* Last reply from the dlm */
337 unsigned int gl_hash;
338 unsigned long gl_demote_time; /* time of first demote request */
339 long gl_hold_time;
340 struct list_head gl_holders;
342 const struct gfs2_glock_operations *gl_ops;
343 ktime_t gl_dstamp;
344 struct gfs2_lkstats gl_stats;
345 struct dlm_lksb gl_lksb;
346 unsigned long gl_tchange;
347 void *gl_object;
349 struct list_head gl_lru;
350 struct list_head gl_ail_list;
351 atomic_t gl_ail_count;
352 atomic_t gl_revokes;
353 struct delayed_work gl_work;
354 union {
355 /* For inode and iopen glocks only */
356 struct work_struct gl_delete;
357 /* For rgrp glocks only */
358 struct {
359 loff_t start;
360 loff_t end;
361 } gl_vm;
363 struct rcu_head gl_rcu;
366 #define GFS2_MIN_LVB_SIZE 32 /* Min size of LVB that gfs2 supports */
368 enum {
369 GIF_INVALID = 0,
370 GIF_QD_LOCKED = 1,
371 GIF_ALLOC_FAILED = 2,
372 GIF_SW_PAGED = 3,
373 GIF_ORDERED = 4,
374 GIF_FREE_VFS_INODE = 5,
377 struct gfs2_inode {
378 struct inode i_inode;
379 u64 i_no_addr;
380 u64 i_no_formal_ino;
381 u64 i_generation;
382 u64 i_eattr;
383 unsigned long i_flags; /* GIF_... */
384 struct gfs2_glock *i_gl; /* Move into i_gh? */
385 struct gfs2_holder i_iopen_gh;
386 struct gfs2_holder i_gh; /* for prepare/commit_write only */
387 struct gfs2_blkreserv *i_res; /* rgrp multi-block reservation */
388 struct gfs2_rgrpd *i_rgd;
389 u64 i_goal; /* goal block for allocations */
390 struct rw_semaphore i_rw_mutex;
391 struct list_head i_ordered;
392 struct list_head i_trunc_list;
393 __be64 *i_hash_cache;
394 u32 i_entries;
395 u32 i_diskflags;
396 u8 i_height;
397 u8 i_depth;
401 * Since i_inode is the first element of struct gfs2_inode,
402 * this is effectively a cast.
404 static inline struct gfs2_inode *GFS2_I(struct inode *inode)
406 return container_of(inode, struct gfs2_inode, i_inode);
409 static inline struct gfs2_sbd *GFS2_SB(const struct inode *inode)
411 return inode->i_sb->s_fs_info;
414 struct gfs2_file {
415 struct mutex f_fl_mutex;
416 struct gfs2_holder f_fl_gh;
419 struct gfs2_revoke_replay {
420 struct list_head rr_list;
421 u64 rr_blkno;
422 unsigned int rr_where;
425 enum {
426 QDF_CHANGE = 1,
427 QDF_LOCKED = 2,
428 QDF_REFRESH = 3,
431 struct gfs2_quota_data {
432 struct hlist_bl_node qd_hlist;
433 struct list_head qd_list;
434 struct kqid qd_id;
435 struct gfs2_sbd *qd_sbd;
436 struct lockref qd_lockref;
437 struct list_head qd_lru;
438 unsigned qd_hash;
440 unsigned long qd_flags; /* QDF_... */
442 s64 qd_change;
443 s64 qd_change_sync;
445 unsigned int qd_slot;
446 unsigned int qd_slot_count;
448 struct buffer_head *qd_bh;
449 struct gfs2_quota_change *qd_bh_qc;
450 unsigned int qd_bh_count;
452 struct gfs2_glock *qd_gl;
453 struct gfs2_quota_lvb qd_qb;
455 u64 qd_sync_gen;
456 unsigned long qd_last_warn;
457 struct rcu_head qd_rcu;
460 struct gfs2_trans {
461 unsigned long tr_ip;
463 unsigned int tr_blocks;
464 unsigned int tr_revokes;
465 unsigned int tr_reserved;
466 unsigned int tr_touched:1;
467 unsigned int tr_attached:1;
469 struct gfs2_holder tr_t_gh;
472 unsigned int tr_num_buf_new;
473 unsigned int tr_num_databuf_new;
474 unsigned int tr_num_buf_rm;
475 unsigned int tr_num_databuf_rm;
476 unsigned int tr_num_revoke;
477 unsigned int tr_num_revoke_rm;
479 struct list_head tr_list;
480 struct list_head tr_databuf;
481 struct list_head tr_buf;
483 unsigned int tr_first;
484 struct list_head tr_ail1_list;
485 struct list_head tr_ail2_list;
488 struct gfs2_journal_extent {
489 struct list_head list;
491 unsigned int lblock; /* First logical block */
492 u64 dblock; /* First disk block */
493 u64 blocks;
496 struct gfs2_jdesc {
497 struct list_head jd_list;
498 struct list_head extent_list;
499 unsigned int nr_extents;
500 struct work_struct jd_work;
501 struct inode *jd_inode;
502 unsigned long jd_flags;
503 #define JDF_RECOVERY 1
504 unsigned int jd_jid;
505 unsigned int jd_blocks;
506 int jd_recover_error;
507 /* Replay stuff */
509 unsigned int jd_found_blocks;
510 unsigned int jd_found_revokes;
511 unsigned int jd_replayed_blocks;
513 struct list_head jd_revoke_list;
514 unsigned int jd_replay_tail;
518 struct gfs2_statfs_change_host {
519 s64 sc_total;
520 s64 sc_free;
521 s64 sc_dinodes;
524 #define GFS2_QUOTA_DEFAULT GFS2_QUOTA_OFF
525 #define GFS2_QUOTA_OFF 0
526 #define GFS2_QUOTA_ACCOUNT 1
527 #define GFS2_QUOTA_ON 2
529 #define GFS2_DATA_DEFAULT GFS2_DATA_ORDERED
530 #define GFS2_DATA_WRITEBACK 1
531 #define GFS2_DATA_ORDERED 2
533 #define GFS2_ERRORS_DEFAULT GFS2_ERRORS_WITHDRAW
534 #define GFS2_ERRORS_WITHDRAW 0
535 #define GFS2_ERRORS_CONTINUE 1 /* place holder for future feature */
536 #define GFS2_ERRORS_RO 2 /* place holder for future feature */
537 #define GFS2_ERRORS_PANIC 3
539 struct gfs2_args {
540 char ar_lockproto[GFS2_LOCKNAME_LEN]; /* Name of the Lock Protocol */
541 char ar_locktable[GFS2_LOCKNAME_LEN]; /* Name of the Lock Table */
542 char ar_hostdata[GFS2_LOCKNAME_LEN]; /* Host specific data */
543 unsigned int ar_spectator:1; /* Don't get a journal */
544 unsigned int ar_localflocks:1; /* Let the VFS do flock|fcntl */
545 unsigned int ar_debug:1; /* Oops on errors */
546 unsigned int ar_posix_acl:1; /* Enable posix acls */
547 unsigned int ar_quota:2; /* off/account/on */
548 unsigned int ar_suiddir:1; /* suiddir support */
549 unsigned int ar_data:2; /* ordered/writeback */
550 unsigned int ar_meta:1; /* mount metafs */
551 unsigned int ar_discard:1; /* discard requests */
552 unsigned int ar_errors:2; /* errors=withdraw | panic */
553 unsigned int ar_nobarrier:1; /* do not send barriers */
554 unsigned int ar_rgrplvb:1; /* use lvbs for rgrp info */
555 int ar_commit; /* Commit interval */
556 int ar_statfs_quantum; /* The fast statfs interval */
557 int ar_quota_quantum; /* The quota interval */
558 int ar_statfs_percent; /* The % change to force sync */
561 struct gfs2_tune {
562 spinlock_t gt_spin;
564 unsigned int gt_logd_secs;
566 unsigned int gt_quota_warn_period; /* Secs between quota warn msgs */
567 unsigned int gt_quota_scale_num; /* Numerator */
568 unsigned int gt_quota_scale_den; /* Denominator */
569 unsigned int gt_quota_quantum; /* Secs between syncs to quota file */
570 unsigned int gt_new_files_jdata;
571 unsigned int gt_max_readahead; /* Max bytes to read-ahead from disk */
572 unsigned int gt_complain_secs;
573 unsigned int gt_statfs_quantum;
574 unsigned int gt_statfs_slow;
577 enum {
578 SDF_JOURNAL_CHECKED = 0,
579 SDF_JOURNAL_LIVE = 1,
580 SDF_SHUTDOWN = 2,
581 SDF_NOBARRIERS = 3,
582 SDF_NORECOVERY = 4,
583 SDF_DEMOTE = 5,
584 SDF_NOJOURNALID = 6,
585 SDF_RORECOVERY = 7, /* read only recovery */
586 SDF_SKIP_DLM_UNLOCK = 8,
589 #define GFS2_FSNAME_LEN 256
591 struct gfs2_inum_host {
592 u64 no_formal_ino;
593 u64 no_addr;
596 struct gfs2_sb_host {
597 u32 sb_magic;
598 u32 sb_type;
599 u32 sb_format;
601 u32 sb_fs_format;
602 u32 sb_multihost_format;
603 u32 sb_bsize;
604 u32 sb_bsize_shift;
606 struct gfs2_inum_host sb_master_dir;
607 struct gfs2_inum_host sb_root_dir;
609 char sb_lockproto[GFS2_LOCKNAME_LEN];
610 char sb_locktable[GFS2_LOCKNAME_LEN];
614 * lm_mount() return values
616 * ls_jid - the journal ID this node should use
617 * ls_first - this node is the first to mount the file system
618 * ls_lockspace - lock module's context for this file system
619 * ls_ops - lock module's functions
622 struct lm_lockstruct {
623 int ls_jid;
624 unsigned int ls_first;
625 const struct lm_lockops *ls_ops;
626 dlm_lockspace_t *ls_dlm;
628 int ls_recover_jid_done; /* These two are deprecated, */
629 int ls_recover_jid_status; /* used previously by gfs_controld */
631 struct dlm_lksb ls_mounted_lksb; /* mounted_lock */
632 struct dlm_lksb ls_control_lksb; /* control_lock */
633 char ls_control_lvb[GDLM_LVB_SIZE]; /* control_lock lvb */
634 struct completion ls_sync_wait; /* {control,mounted}_{lock,unlock} */
635 char *ls_lvb_bits;
637 spinlock_t ls_recover_spin; /* protects following fields */
638 unsigned long ls_recover_flags; /* DFL_ */
639 uint32_t ls_recover_mount; /* gen in first recover_done cb */
640 uint32_t ls_recover_start; /* gen in last recover_done cb */
641 uint32_t ls_recover_block; /* copy recover_start in last recover_prep */
642 uint32_t ls_recover_size; /* size of recover_submit, recover_result */
643 uint32_t *ls_recover_submit; /* gen in last recover_slot cb per jid */
644 uint32_t *ls_recover_result; /* result of last jid recovery */
647 struct gfs2_pcpu_lkstats {
648 /* One struct for each glock type */
649 struct gfs2_lkstats lkstats[10];
652 struct gfs2_sbd {
653 struct super_block *sd_vfs;
654 struct gfs2_pcpu_lkstats __percpu *sd_lkstats;
655 struct kobject sd_kobj;
656 unsigned long sd_flags; /* SDF_... */
657 struct gfs2_sb_host sd_sb;
659 /* Constants computed on mount */
661 u32 sd_fsb2bb;
662 u32 sd_fsb2bb_shift;
663 u32 sd_diptrs; /* Number of pointers in a dinode */
664 u32 sd_inptrs; /* Number of pointers in a indirect block */
665 u32 sd_jbsize; /* Size of a journaled data block */
666 u32 sd_hash_bsize; /* sizeof(exhash block) */
667 u32 sd_hash_bsize_shift;
668 u32 sd_hash_ptrs; /* Number of pointers in a hash block */
669 u32 sd_qc_per_block;
670 u32 sd_blocks_per_bitmap;
671 u32 sd_max_dirres; /* Max blocks needed to add a directory entry */
672 u32 sd_max_height; /* Max height of a file's metadata tree */
673 u64 sd_heightsize[GFS2_MAX_META_HEIGHT + 1];
674 u32 sd_max_jheight; /* Max height of journaled file's meta tree */
675 u64 sd_jheightsize[GFS2_MAX_META_HEIGHT + 1];
677 struct gfs2_args sd_args; /* Mount arguments */
678 struct gfs2_tune sd_tune; /* Filesystem tuning structure */
680 /* Lock Stuff */
682 struct lm_lockstruct sd_lockstruct;
683 struct gfs2_holder sd_live_gh;
684 struct gfs2_glock *sd_rename_gl;
685 struct gfs2_glock *sd_trans_gl;
686 wait_queue_head_t sd_glock_wait;
687 atomic_t sd_glock_disposal;
688 struct completion sd_locking_init;
689 struct completion sd_wdack;
690 struct delayed_work sd_control_work;
692 /* Inode Stuff */
694 struct dentry *sd_master_dir;
695 struct dentry *sd_root_dir;
697 struct inode *sd_jindex;
698 struct inode *sd_statfs_inode;
699 struct inode *sd_sc_inode;
700 struct inode *sd_qc_inode;
701 struct inode *sd_rindex;
702 struct inode *sd_quota_inode;
704 /* StatFS stuff */
706 spinlock_t sd_statfs_spin;
707 struct gfs2_statfs_change_host sd_statfs_master;
708 struct gfs2_statfs_change_host sd_statfs_local;
709 int sd_statfs_force_sync;
711 /* Resource group stuff */
713 int sd_rindex_uptodate;
714 spinlock_t sd_rindex_spin;
715 struct rb_root sd_rindex_tree;
716 unsigned int sd_rgrps;
717 unsigned int sd_max_rg_data;
719 /* Journal index stuff */
721 struct list_head sd_jindex_list;
722 spinlock_t sd_jindex_spin;
723 struct mutex sd_jindex_mutex;
724 unsigned int sd_journals;
726 struct gfs2_jdesc *sd_jdesc;
727 struct gfs2_holder sd_journal_gh;
728 struct gfs2_holder sd_jinode_gh;
730 struct gfs2_holder sd_sc_gh;
731 struct gfs2_holder sd_qc_gh;
733 /* Daemon stuff */
735 struct task_struct *sd_logd_process;
736 struct task_struct *sd_quotad_process;
738 /* Quota stuff */
740 struct list_head sd_quota_list;
741 atomic_t sd_quota_count;
742 struct mutex sd_quota_mutex;
743 struct mutex sd_quota_sync_mutex;
744 wait_queue_head_t sd_quota_wait;
745 struct list_head sd_trunc_list;
746 spinlock_t sd_trunc_lock;
748 unsigned int sd_quota_slots;
749 unsigned long *sd_quota_bitmap;
750 spinlock_t sd_bitmap_lock;
752 u64 sd_quota_sync_gen;
754 /* Log stuff */
756 struct address_space sd_aspace;
758 spinlock_t sd_log_lock;
760 struct gfs2_trans *sd_log_tr;
761 unsigned int sd_log_blks_reserved;
762 int sd_log_commited_revoke;
764 atomic_t sd_log_pinned;
765 unsigned int sd_log_num_revoke;
767 struct list_head sd_log_le_revoke;
768 struct list_head sd_log_le_ordered;
769 spinlock_t sd_ordered_lock;
771 atomic_t sd_log_thresh1;
772 atomic_t sd_log_thresh2;
773 atomic_t sd_log_blks_free;
774 wait_queue_head_t sd_log_waitq;
775 wait_queue_head_t sd_logd_waitq;
777 u64 sd_log_sequence;
778 unsigned int sd_log_head;
779 unsigned int sd_log_tail;
780 int sd_log_idle;
782 struct rw_semaphore sd_log_flush_lock;
783 atomic_t sd_log_in_flight;
784 struct bio *sd_log_bio;
785 wait_queue_head_t sd_log_flush_wait;
786 int sd_log_error;
788 unsigned int sd_log_flush_head;
789 u64 sd_log_flush_wrapped;
791 spinlock_t sd_ail_lock;
792 struct list_head sd_ail1_list;
793 struct list_head sd_ail2_list;
795 /* For quiescing the filesystem */
796 struct gfs2_holder sd_freeze_gh;
798 char sd_fsname[GFS2_FSNAME_LEN];
799 char sd_table_name[GFS2_FSNAME_LEN];
800 char sd_proto_name[GFS2_FSNAME_LEN];
802 /* Debugging crud */
804 unsigned long sd_last_warning;
805 struct dentry *debugfs_dir; /* debugfs directory */
806 struct dentry *debugfs_dentry_glocks;
807 struct dentry *debugfs_dentry_glstats;
808 struct dentry *debugfs_dentry_sbstats;
811 static inline void gfs2_glstats_inc(struct gfs2_glock *gl, int which)
813 gl->gl_stats.stats[which]++;
816 static inline void gfs2_sbstats_inc(const struct gfs2_glock *gl, int which)
818 const struct gfs2_sbd *sdp = gl->gl_sbd;
819 preempt_disable();
820 this_cpu_ptr(sdp->sd_lkstats)->lkstats[gl->gl_name.ln_type].stats[which]++;
821 preempt_enable();
824 #endif /* __INCORE_DOT_H__ */