提交 49559d87 编写于 作者: P Philipp Reisner

drbd: Improved the dec_*() macros

Now those can be used with a struct drbd_conf * that has an other
name than 'mdev'.
Signed-off-by: NPhilipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: NLars Ellenberg <lars.ellenberg@linbit.com>
上级 3f9cbe93
...@@ -1988,17 +1988,19 @@ static inline void inc_ap_pending(struct drbd_conf *mdev) ...@@ -1988,17 +1988,19 @@ static inline void inc_ap_pending(struct drbd_conf *mdev)
atomic_inc(&mdev->ap_pending_cnt); atomic_inc(&mdev->ap_pending_cnt);
} }
#define ERR_IF_CNT_IS_NEGATIVE(which) \ #define ERR_IF_CNT_IS_NEGATIVE(which, func, line) \
if (atomic_read(&mdev->which) < 0) \ if (atomic_read(&mdev->which) < 0) \
dev_err(DEV, "in %s:%d: " #which " = %d < 0 !\n", \ dev_err(DEV, "in %s:%d: " #which " = %d < 0 !\n", \
__func__ , __LINE__ , \ func, line, \
atomic_read(&mdev->which)) atomic_read(&mdev->which))
#define dec_ap_pending(mdev) do { \ #define dec_ap_pending(mdev) _dec_ap_pending(mdev, __FUNCTION__, __LINE__)
typecheck(struct drbd_conf *, mdev); \ static inline void _dec_ap_pending(struct drbd_conf *mdev, const char *func, int line)
if (atomic_dec_and_test(&mdev->ap_pending_cnt)) \ {
wake_up(&mdev->misc_wait); \ if (atomic_dec_and_test(&mdev->ap_pending_cnt))
ERR_IF_CNT_IS_NEGATIVE(ap_pending_cnt); } while (0) wake_up(&mdev->misc_wait);
ERR_IF_CNT_IS_NEGATIVE(ap_pending_cnt, func, line);
}
/* counts how many resync-related answers we still expect from the peer /* counts how many resync-related answers we still expect from the peer
* increase decrease * increase decrease
...@@ -2011,10 +2013,12 @@ static inline void inc_rs_pending(struct drbd_conf *mdev) ...@@ -2011,10 +2013,12 @@ static inline void inc_rs_pending(struct drbd_conf *mdev)
atomic_inc(&mdev->rs_pending_cnt); atomic_inc(&mdev->rs_pending_cnt);
} }
#define dec_rs_pending(mdev) do { \ #define dec_rs_pending(mdev) _dec_rs_pending(mdev, __FUNCTION__, __LINE__)
typecheck(struct drbd_conf *, mdev); \ static inline void _dec_rs_pending(struct drbd_conf *mdev, const char *func, int line)
atomic_dec(&mdev->rs_pending_cnt); \ {
ERR_IF_CNT_IS_NEGATIVE(rs_pending_cnt); } while (0) atomic_dec(&mdev->rs_pending_cnt);
ERR_IF_CNT_IS_NEGATIVE(rs_pending_cnt, func, line);
}
/* counts how many answers we still need to send to the peer. /* counts how many answers we still need to send to the peer.
* increased on * increased on
...@@ -2030,16 +2034,19 @@ static inline void inc_unacked(struct drbd_conf *mdev) ...@@ -2030,16 +2034,19 @@ static inline void inc_unacked(struct drbd_conf *mdev)
atomic_inc(&mdev->unacked_cnt); atomic_inc(&mdev->unacked_cnt);
} }
#define dec_unacked(mdev) do { \ #define dec_unacked(mdev) _dec_unacked(mdev, __FUNCTION__, __LINE__)
typecheck(struct drbd_conf *, mdev); \ static inline void _dec_unacked(struct drbd_conf *mdev, const char *func, int line)
atomic_dec(&mdev->unacked_cnt); \ {
ERR_IF_CNT_IS_NEGATIVE(unacked_cnt); } while (0) atomic_dec(&mdev->unacked_cnt);
ERR_IF_CNT_IS_NEGATIVE(unacked_cnt, func, line);
#define sub_unacked(mdev, n) do { \ }
typecheck(struct drbd_conf *, mdev); \
atomic_sub(n, &mdev->unacked_cnt); \
ERR_IF_CNT_IS_NEGATIVE(unacked_cnt); } while (0)
#define sub_unacked(mdev, n) _sub_unacked(mdev, n, __FUNCTION__, __LINE__)
static inline void _sub_unacked(struct drbd_conf *mdev, int n, const char *func, int line)
{
atomic_sub(n, &mdev->unacked_cnt);
ERR_IF_CNT_IS_NEGATIVE(unacked_cnt, func, line);
}
static inline void put_net_conf(struct drbd_tconn *tconn) static inline void put_net_conf(struct drbd_tconn *tconn)
{ {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册