aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ceph/messenger.h
diff options
context:
space:
mode:
authorSage Weil <sage@newdream.net>2009-12-07 18:55:05 -0500
committerSage Weil <sage@newdream.net>2009-12-07 18:55:05 -0500
commitc2e552e76e2c6907ca50cd9a4b747a2e2e8c615e (patch)
tree4251e189caeb4de3f4a8763ae70600fc9d3acb51 /fs/ceph/messenger.h
parent415e49a9c4faf1a1480b1497da2037608e5aa2c5 (diff)
ceph: use kref for ceph_msg
Signed-off-by: Sage Weil <sage@newdream.net>
Diffstat (limited to 'fs/ceph/messenger.h')
-rw-r--r--fs/ceph/messenger.h13
1 files changed, 8 insertions, 5 deletions
diff --git a/fs/ceph/messenger.h b/fs/ceph/messenger.h
index f9c9f648730..981b7c08ad8 100644
--- a/fs/ceph/messenger.h
+++ b/fs/ceph/messenger.h
@@ -1,6 +1,7 @@
1#ifndef __FS_CEPH_MESSENGER_H 1#ifndef __FS_CEPH_MESSENGER_H
2#define __FS_CEPH_MESSENGER_H 2#define __FS_CEPH_MESSENGER_H
3 3
4#include <linux/kref.h>
4#include <linux/mutex.h> 5#include <linux/mutex.h>
5#include <linux/net.h> 6#include <linux/net.h>
6#include <linux/radix-tree.h> 7#include <linux/radix-tree.h>
@@ -85,7 +86,7 @@ struct ceph_msg {
85 struct page **pages; /* data payload. NOT OWNER. */ 86 struct page **pages; /* data payload. NOT OWNER. */
86 unsigned nr_pages; /* size of page array */ 87 unsigned nr_pages; /* size of page array */
87 struct list_head list_head; 88 struct list_head list_head;
88 atomic_t nref; 89 struct kref kref;
89 bool front_is_vmalloc; 90 bool front_is_vmalloc;
90 bool more_to_follow; 91 bool more_to_follow;
91 int front_max; 92 int front_max;
@@ -243,11 +244,13 @@ extern int ceph_alloc_middle(struct ceph_connection *con, struct ceph_msg *msg);
243 244
244static inline struct ceph_msg *ceph_msg_get(struct ceph_msg *msg) 245static inline struct ceph_msg *ceph_msg_get(struct ceph_msg *msg)
245{ 246{
246 dout("ceph_msg_get %p %d -> %d\n", msg, atomic_read(&msg->nref), 247 kref_get(&msg->kref);
247 atomic_read(&msg->nref)+1);
248 atomic_inc(&msg->nref);
249 return msg; 248 return msg;
250} 249}
251extern void ceph_msg_put(struct ceph_msg *msg); 250extern void ceph_msg_last_put(struct kref *kref);
251static inline void ceph_msg_put(struct ceph_msg *msg)
252{
253 kref_put(&msg->kref, ceph_msg_last_put);
254}
252 255
253#endif 256#endif