ceph: queue cap release when trimming cap
authorYan, Zheng <zheng.z.yan@intel.com>
Mon, 18 Feb 2013 05:43:43 +0000 (13:43 +0800)
committerSage Weil <sage@inktank.com>
Thu, 2 May 2013 04:14:31 +0000 (21:14 -0700)
So the client will later send cap release message to MDS

Signed-off-by: Yan, Zheng <zheng.z.yan@intel.com>
Reviewed-by: Greg Farnum <greg@inktank.com>
fs/ceph/caps.c
fs/ceph/mds_client.c
fs/ceph/super.h

index 78e2f575247dce25ebbfdef971ac8f458531442c..0d54368490db1d955ad4ea0627745a7a995e892b 100644 (file)
@@ -997,9 +997,9 @@ static int send_cap_msg(struct ceph_mds_session *session,
        return 0;
 }
 
-static void __queue_cap_release(struct ceph_mds_session *session,
-                               u64 ino, u64 cap_id, u32 migrate_seq,
-                               u32 issue_seq)
+void __queue_cap_release(struct ceph_mds_session *session,
+                        u64 ino, u64 cap_id, u32 migrate_seq,
+                        u32 issue_seq)
 {
        struct ceph_msg *msg;
        struct ceph_mds_cap_release *head;
index 6e67a350167359ab84fd7192681b797438a80ee2..fb7cb05d8abac93683ccfddffaf91474821381bd 100644 (file)
@@ -1197,6 +1197,8 @@ static int trim_caps_cb(struct inode *inode, struct ceph_cap *cap, void *arg)
        session->s_trim_caps--;
        if (oissued) {
                /* we aren't the only cap.. just remove us */
+               __queue_cap_release(session, ceph_ino(inode), cap->cap_id,
+                                   cap->mseq, cap->issue_seq);
                __ceph_remove_cap(cap);
        } else {
                /* try to drop referring dentries */
index c7b309723dcc2ee1db835db6395b42d36b461fe6..86810b6d973b9f7a0dd4ebca08e7a28ba0cb5348 100644 (file)
@@ -755,6 +755,8 @@ static inline void ceph_remove_cap(struct ceph_cap *cap)
 extern void ceph_put_cap(struct ceph_mds_client *mdsc,
                         struct ceph_cap *cap);
 
+extern void __queue_cap_release(struct ceph_mds_session *session, u64 ino,
+                               u64 cap_id, u32 migrate_seq, u32 issue_seq);
 extern void ceph_queue_caps_release(struct inode *inode);
 extern int ceph_write_inode(struct inode *inode, struct writeback_control *wbc);
 extern int ceph_fsync(struct file *file, loff_t start, loff_t end,