mfd: vexpress: fix error handling vexpress_syscfg_regmap_init()
[linux/fpc-iii.git] / fs / gfs2 / incore.h
blob67d310c9ada3222ef1c08333397f65a29d1e454a
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;
468 unsigned int tr_alloced:1;
470 unsigned int tr_num_buf_new;
471 unsigned int tr_num_databuf_new;
472 unsigned int tr_num_buf_rm;
473 unsigned int tr_num_databuf_rm;
474 unsigned int tr_num_revoke;
475 unsigned int tr_num_revoke_rm;
477 struct list_head tr_list;
478 struct list_head tr_databuf;
479 struct list_head tr_buf;
481 unsigned int tr_first;
482 struct list_head tr_ail1_list;
483 struct list_head tr_ail2_list;
486 struct gfs2_journal_extent {
487 struct list_head list;
489 unsigned int lblock; /* First logical block */
490 u64 dblock; /* First disk block */
491 u64 blocks;
494 struct gfs2_jdesc {
495 struct list_head jd_list;
496 struct list_head extent_list;
497 unsigned int nr_extents;
498 struct work_struct jd_work;
499 struct inode *jd_inode;
500 unsigned long jd_flags;
501 #define JDF_RECOVERY 1
502 unsigned int jd_jid;
503 unsigned int jd_blocks;
504 int jd_recover_error;
505 /* Replay stuff */
507 unsigned int jd_found_blocks;
508 unsigned int jd_found_revokes;
509 unsigned int jd_replayed_blocks;
511 struct list_head jd_revoke_list;
512 unsigned int jd_replay_tail;
516 struct gfs2_statfs_change_host {
517 s64 sc_total;
518 s64 sc_free;
519 s64 sc_dinodes;
522 #define GFS2_QUOTA_DEFAULT GFS2_QUOTA_OFF
523 #define GFS2_QUOTA_OFF 0
524 #define GFS2_QUOTA_ACCOUNT 1
525 #define GFS2_QUOTA_ON 2
527 #define GFS2_DATA_DEFAULT GFS2_DATA_ORDERED
528 #define GFS2_DATA_WRITEBACK 1
529 #define GFS2_DATA_ORDERED 2
531 #define GFS2_ERRORS_DEFAULT GFS2_ERRORS_WITHDRAW
532 #define GFS2_ERRORS_WITHDRAW 0
533 #define GFS2_ERRORS_CONTINUE 1 /* place holder for future feature */
534 #define GFS2_ERRORS_RO 2 /* place holder for future feature */
535 #define GFS2_ERRORS_PANIC 3
537 struct gfs2_args {
538 char ar_lockproto[GFS2_LOCKNAME_LEN]; /* Name of the Lock Protocol */
539 char ar_locktable[GFS2_LOCKNAME_LEN]; /* Name of the Lock Table */
540 char ar_hostdata[GFS2_LOCKNAME_LEN]; /* Host specific data */
541 unsigned int ar_spectator:1; /* Don't get a journal */
542 unsigned int ar_localflocks:1; /* Let the VFS do flock|fcntl */
543 unsigned int ar_debug:1; /* Oops on errors */
544 unsigned int ar_posix_acl:1; /* Enable posix acls */
545 unsigned int ar_quota:2; /* off/account/on */
546 unsigned int ar_suiddir:1; /* suiddir support */
547 unsigned int ar_data:2; /* ordered/writeback */
548 unsigned int ar_meta:1; /* mount metafs */
549 unsigned int ar_discard:1; /* discard requests */
550 unsigned int ar_errors:2; /* errors=withdraw | panic */
551 unsigned int ar_nobarrier:1; /* do not send barriers */
552 unsigned int ar_rgrplvb:1; /* use lvbs for rgrp info */
553 int ar_commit; /* Commit interval */
554 int ar_statfs_quantum; /* The fast statfs interval */
555 int ar_quota_quantum; /* The quota interval */
556 int ar_statfs_percent; /* The % change to force sync */
559 struct gfs2_tune {
560 spinlock_t gt_spin;
562 unsigned int gt_logd_secs;
564 unsigned int gt_quota_warn_period; /* Secs between quota warn msgs */
565 unsigned int gt_quota_scale_num; /* Numerator */
566 unsigned int gt_quota_scale_den; /* Denominator */
567 unsigned int gt_quota_quantum; /* Secs between syncs to quota file */
568 unsigned int gt_new_files_jdata;
569 unsigned int gt_max_readahead; /* Max bytes to read-ahead from disk */
570 unsigned int gt_complain_secs;
571 unsigned int gt_statfs_quantum;
572 unsigned int gt_statfs_slow;
575 enum {
576 SDF_JOURNAL_CHECKED = 0,
577 SDF_JOURNAL_LIVE = 1,
578 SDF_SHUTDOWN = 2,
579 SDF_NOBARRIERS = 3,
580 SDF_NORECOVERY = 4,
581 SDF_DEMOTE = 5,
582 SDF_NOJOURNALID = 6,
583 SDF_RORECOVERY = 7, /* read only recovery */
584 SDF_SKIP_DLM_UNLOCK = 8,
587 #define GFS2_FSNAME_LEN 256
589 struct gfs2_inum_host {
590 u64 no_formal_ino;
591 u64 no_addr;
594 struct gfs2_sb_host {
595 u32 sb_magic;
596 u32 sb_type;
597 u32 sb_format;
599 u32 sb_fs_format;
600 u32 sb_multihost_format;
601 u32 sb_bsize;
602 u32 sb_bsize_shift;
604 struct gfs2_inum_host sb_master_dir;
605 struct gfs2_inum_host sb_root_dir;
607 char sb_lockproto[GFS2_LOCKNAME_LEN];
608 char sb_locktable[GFS2_LOCKNAME_LEN];
612 * lm_mount() return values
614 * ls_jid - the journal ID this node should use
615 * ls_first - this node is the first to mount the file system
616 * ls_lockspace - lock module's context for this file system
617 * ls_ops - lock module's functions
620 struct lm_lockstruct {
621 int ls_jid;
622 unsigned int ls_first;
623 const struct lm_lockops *ls_ops;
624 dlm_lockspace_t *ls_dlm;
626 int ls_recover_jid_done; /* These two are deprecated, */
627 int ls_recover_jid_status; /* used previously by gfs_controld */
629 struct dlm_lksb ls_mounted_lksb; /* mounted_lock */
630 struct dlm_lksb ls_control_lksb; /* control_lock */
631 char ls_control_lvb[GDLM_LVB_SIZE]; /* control_lock lvb */
632 struct completion ls_sync_wait; /* {control,mounted}_{lock,unlock} */
633 char *ls_lvb_bits;
635 spinlock_t ls_recover_spin; /* protects following fields */
636 unsigned long ls_recover_flags; /* DFL_ */
637 uint32_t ls_recover_mount; /* gen in first recover_done cb */
638 uint32_t ls_recover_start; /* gen in last recover_done cb */
639 uint32_t ls_recover_block; /* copy recover_start in last recover_prep */
640 uint32_t ls_recover_size; /* size of recover_submit, recover_result */
641 uint32_t *ls_recover_submit; /* gen in last recover_slot cb per jid */
642 uint32_t *ls_recover_result; /* result of last jid recovery */
645 struct gfs2_pcpu_lkstats {
646 /* One struct for each glock type */
647 struct gfs2_lkstats lkstats[10];
650 struct gfs2_sbd {
651 struct super_block *sd_vfs;
652 struct gfs2_pcpu_lkstats __percpu *sd_lkstats;
653 struct kobject sd_kobj;
654 unsigned long sd_flags; /* SDF_... */
655 struct gfs2_sb_host sd_sb;
657 /* Constants computed on mount */
659 u32 sd_fsb2bb;
660 u32 sd_fsb2bb_shift;
661 u32 sd_diptrs; /* Number of pointers in a dinode */
662 u32 sd_inptrs; /* Number of pointers in a indirect block */
663 u32 sd_jbsize; /* Size of a journaled data block */
664 u32 sd_hash_bsize; /* sizeof(exhash block) */
665 u32 sd_hash_bsize_shift;
666 u32 sd_hash_ptrs; /* Number of pointers in a hash block */
667 u32 sd_qc_per_block;
668 u32 sd_blocks_per_bitmap;
669 u32 sd_max_dirres; /* Max blocks needed to add a directory entry */
670 u32 sd_max_height; /* Max height of a file's metadata tree */
671 u64 sd_heightsize[GFS2_MAX_META_HEIGHT + 1];
672 u32 sd_max_jheight; /* Max height of journaled file's meta tree */
673 u64 sd_jheightsize[GFS2_MAX_META_HEIGHT + 1];
675 struct gfs2_args sd_args; /* Mount arguments */
676 struct gfs2_tune sd_tune; /* Filesystem tuning structure */
678 /* Lock Stuff */
680 struct lm_lockstruct sd_lockstruct;
681 struct gfs2_holder sd_live_gh;
682 struct gfs2_glock *sd_rename_gl;
683 struct gfs2_glock *sd_freeze_gl;
684 wait_queue_head_t sd_glock_wait;
685 atomic_t sd_glock_disposal;
686 struct completion sd_locking_init;
687 struct completion sd_wdack;
688 struct delayed_work sd_control_work;
690 /* Inode Stuff */
692 struct dentry *sd_master_dir;
693 struct dentry *sd_root_dir;
695 struct inode *sd_jindex;
696 struct inode *sd_statfs_inode;
697 struct inode *sd_sc_inode;
698 struct inode *sd_qc_inode;
699 struct inode *sd_rindex;
700 struct inode *sd_quota_inode;
702 /* StatFS stuff */
704 spinlock_t sd_statfs_spin;
705 struct gfs2_statfs_change_host sd_statfs_master;
706 struct gfs2_statfs_change_host sd_statfs_local;
707 int sd_statfs_force_sync;
709 /* Resource group stuff */
711 int sd_rindex_uptodate;
712 spinlock_t sd_rindex_spin;
713 struct rb_root sd_rindex_tree;
714 unsigned int sd_rgrps;
715 unsigned int sd_max_rg_data;
717 /* Journal index stuff */
719 struct list_head sd_jindex_list;
720 spinlock_t sd_jindex_spin;
721 struct mutex sd_jindex_mutex;
722 unsigned int sd_journals;
724 struct gfs2_jdesc *sd_jdesc;
725 struct gfs2_holder sd_journal_gh;
726 struct gfs2_holder sd_jinode_gh;
728 struct gfs2_holder sd_sc_gh;
729 struct gfs2_holder sd_qc_gh;
731 struct completion sd_journal_ready;
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;
797 struct gfs2_holder sd_freeze_root_gh;
798 struct gfs2_holder sd_thaw_gh;
799 atomic_t sd_log_freeze;
800 atomic_t sd_frozen_root;
801 wait_queue_head_t sd_frozen_root_wait;
802 wait_queue_head_t sd_log_frozen_wait;
804 char sd_fsname[GFS2_FSNAME_LEN];
805 char sd_table_name[GFS2_FSNAME_LEN];
806 char sd_proto_name[GFS2_FSNAME_LEN];
808 /* Debugging crud */
810 unsigned long sd_last_warning;
811 struct dentry *debugfs_dir; /* debugfs directory */
812 struct dentry *debugfs_dentry_glocks;
813 struct dentry *debugfs_dentry_glstats;
814 struct dentry *debugfs_dentry_sbstats;
817 static inline void gfs2_glstats_inc(struct gfs2_glock *gl, int which)
819 gl->gl_stats.stats[which]++;
822 static inline void gfs2_sbstats_inc(const struct gfs2_glock *gl, int which)
824 const struct gfs2_sbd *sdp = gl->gl_sbd;
825 preempt_disable();
826 this_cpu_ptr(sdp->sd_lkstats)->lkstats[gl->gl_name.ln_type].stats[which]++;
827 preempt_enable();
830 #endif /* __INCORE_DOT_H__ */