This source file includes following definitions.
- xfs_trans_ail_update_bulk
- xfs_trans_ail_update
- xfs_trans_ail_delete
- xfs_trans_ail_copy_lsn
- xfs_trans_ail_copy_lsn
- xfs_clear_li_failed
- xfs_set_li_failed
   1 
   2 
   3 
   4 
   5 
   6 #ifndef __XFS_TRANS_PRIV_H__
   7 #define __XFS_TRANS_PRIV_H__
   8 
   9 struct xfs_log_item;
  10 struct xfs_mount;
  11 struct xfs_trans;
  12 struct xfs_ail;
  13 struct xfs_log_vec;
  14 
  15 
  16 void    xfs_trans_init(struct xfs_mount *);
  17 void    xfs_trans_add_item(struct xfs_trans *, struct xfs_log_item *);
  18 void    xfs_trans_del_item(struct xfs_log_item *);
  19 void    xfs_trans_unreserve_and_mod_sb(struct xfs_trans *tp);
  20 
  21 void    xfs_trans_committed_bulk(struct xfs_ail *ailp, struct xfs_log_vec *lv,
  22                                 xfs_lsn_t commit_lsn, bool aborted);
  23 
  24 
  25 
  26 
  27 
  28 
  29 
  30 
  31 
  32 
  33 
  34 
  35 
  36 
  37 
  38 
  39 
  40 
  41 
  42 struct xfs_ail_cursor {
  43         struct list_head        list;
  44         struct xfs_log_item     *item;
  45 };
  46 
  47 
  48 
  49 
  50 
  51 
  52 struct xfs_ail {
  53         struct xfs_mount        *ail_mount;
  54         struct task_struct      *ail_task;
  55         struct list_head        ail_head;
  56         xfs_lsn_t               ail_target;
  57         xfs_lsn_t               ail_target_prev;
  58         struct list_head        ail_cursors;
  59         spinlock_t              ail_lock;
  60         xfs_lsn_t               ail_last_pushed_lsn;
  61         int                     ail_log_flush;
  62         struct list_head        ail_buf_list;
  63         wait_queue_head_t       ail_empty;
  64 };
  65 
  66 
  67 
  68 
  69 void    xfs_trans_ail_update_bulk(struct xfs_ail *ailp,
  70                                 struct xfs_ail_cursor *cur,
  71                                 struct xfs_log_item **log_items, int nr_items,
  72                                 xfs_lsn_t lsn) __releases(ailp->ail_lock);
  73 
  74 
  75 
  76 
  77 static inline struct xfs_log_item *
  78 xfs_ail_min(
  79         struct xfs_ail  *ailp)
  80 {
  81         return list_first_entry_or_null(&ailp->ail_head, struct xfs_log_item,
  82                                         li_ail);
  83 }
  84 
  85 static inline void
  86 xfs_trans_ail_update(
  87         struct xfs_ail          *ailp,
  88         struct xfs_log_item     *lip,
  89         xfs_lsn_t               lsn) __releases(ailp->ail_lock)
  90 {
  91         xfs_trans_ail_update_bulk(ailp, NULL, &lip, 1, lsn);
  92 }
  93 
  94 bool xfs_ail_delete_one(struct xfs_ail *ailp, struct xfs_log_item *lip);
  95 void xfs_trans_ail_delete(struct xfs_ail *ailp, struct xfs_log_item *lip,
  96                 int shutdown_type) __releases(ailp->ail_lock);
  97 
  98 static inline void
  99 xfs_trans_ail_remove(
 100         struct xfs_log_item     *lip,
 101         int                     shutdown_type)
 102 {
 103         struct xfs_ail          *ailp = lip->li_ailp;
 104 
 105         spin_lock(&ailp->ail_lock);
 106         
 107         if (test_bit(XFS_LI_IN_AIL, &lip->li_flags))
 108                 xfs_trans_ail_delete(ailp, lip, shutdown_type);
 109         else
 110                 spin_unlock(&ailp->ail_lock);
 111 }
 112 
 113 void                    xfs_ail_push(struct xfs_ail *, xfs_lsn_t);
 114 void                    xfs_ail_push_all(struct xfs_ail *);
 115 void                    xfs_ail_push_all_sync(struct xfs_ail *);
 116 struct xfs_log_item     *xfs_ail_min(struct xfs_ail  *ailp);
 117 xfs_lsn_t               xfs_ail_min_lsn(struct xfs_ail *ailp);
 118 
 119 struct xfs_log_item *   xfs_trans_ail_cursor_first(struct xfs_ail *ailp,
 120                                         struct xfs_ail_cursor *cur,
 121                                         xfs_lsn_t lsn);
 122 struct xfs_log_item *   xfs_trans_ail_cursor_last(struct xfs_ail *ailp,
 123                                         struct xfs_ail_cursor *cur,
 124                                         xfs_lsn_t lsn);
 125 struct xfs_log_item *   xfs_trans_ail_cursor_next(struct xfs_ail *ailp,
 126                                         struct xfs_ail_cursor *cur);
 127 void                    xfs_trans_ail_cursor_done(struct xfs_ail_cursor *cur);
 128 
 129 #if BITS_PER_LONG != 64
 130 static inline void
 131 xfs_trans_ail_copy_lsn(
 132         struct xfs_ail  *ailp,
 133         xfs_lsn_t       *dst,
 134         xfs_lsn_t       *src)
 135 {
 136         ASSERT(sizeof(xfs_lsn_t) == 8); 
 137         spin_lock(&ailp->ail_lock);
 138         *dst = *src;
 139         spin_unlock(&ailp->ail_lock);
 140 }
 141 #else
 142 static inline void
 143 xfs_trans_ail_copy_lsn(
 144         struct xfs_ail  *ailp,
 145         xfs_lsn_t       *dst,
 146         xfs_lsn_t       *src)
 147 {
 148         ASSERT(sizeof(xfs_lsn_t) == 8);
 149         *dst = *src;
 150 }
 151 #endif
 152 
 153 static inline void
 154 xfs_clear_li_failed(
 155         struct xfs_log_item     *lip)
 156 {
 157         struct xfs_buf  *bp = lip->li_buf;
 158 
 159         ASSERT(test_bit(XFS_LI_IN_AIL, &lip->li_flags));
 160         lockdep_assert_held(&lip->li_ailp->ail_lock);
 161 
 162         if (test_and_clear_bit(XFS_LI_FAILED, &lip->li_flags)) {
 163                 lip->li_buf = NULL;
 164                 xfs_buf_rele(bp);
 165         }
 166 }
 167 
 168 static inline void
 169 xfs_set_li_failed(
 170         struct xfs_log_item     *lip,
 171         struct xfs_buf          *bp)
 172 {
 173         lockdep_assert_held(&lip->li_ailp->ail_lock);
 174 
 175         if (!test_and_set_bit(XFS_LI_FAILED, &lip->li_flags)) {
 176                 xfs_buf_hold(bp);
 177                 lip->li_buf = bp;
 178         }
 179 }
 180 
 181 #endif