Commit 38e8883e authored by Sage Weil's avatar Sage Weil

ceph: simplify add_cap_releases

No functional change, aside from more useful debug output.
Signed-off-by: default avatarSage Weil <sage@newdream.net>
parent ee6b272b
...@@ -1069,11 +1069,14 @@ static int trim_caps(struct ceph_mds_client *mdsc, ...@@ -1069,11 +1069,14 @@ static int trim_caps(struct ceph_mds_client *mdsc,
int ceph_add_cap_releases(struct ceph_mds_client *mdsc, int ceph_add_cap_releases(struct ceph_mds_client *mdsc,
struct ceph_mds_session *session) struct ceph_mds_session *session)
{ {
struct ceph_msg *msg; struct ceph_msg *msg, *partial = NULL;
struct ceph_mds_cap_release *head; struct ceph_mds_cap_release *head;
int err = -ENOMEM; int err = -ENOMEM;
int extra = mdsc->client->mount_args->cap_release_safety; int extra = mdsc->client->mount_args->cap_release_safety;
int num;
dout("add_cap_releases %p mds%d extra %d\n", session, session->s_mds,
extra);
spin_lock(&session->s_cap_lock); spin_lock(&session->s_cap_lock);
...@@ -1082,9 +1085,14 @@ int ceph_add_cap_releases(struct ceph_mds_client *mdsc, ...@@ -1082,9 +1085,14 @@ int ceph_add_cap_releases(struct ceph_mds_client *mdsc,
struct ceph_msg, struct ceph_msg,
list_head); list_head);
head = msg->front.iov_base; head = msg->front.iov_base;
extra += CEPH_CAPS_PER_RELEASE - le32_to_cpu(head->num); num = le32_to_cpu(head->num);
if (num) {
dout(" partial %p with (%d/%d)\n", msg, num,
(int)CEPH_CAPS_PER_RELEASE);
extra += CEPH_CAPS_PER_RELEASE - num;
partial = msg;
}
} }
while (session->s_num_cap_releases < session->s_nr_caps + extra) { while (session->s_num_cap_releases < session->s_nr_caps + extra) {
spin_unlock(&session->s_cap_lock); spin_unlock(&session->s_cap_lock);
msg = ceph_msg_new(CEPH_MSG_CLIENT_CAPRELEASE, PAGE_CACHE_SIZE, msg = ceph_msg_new(CEPH_MSG_CLIENT_CAPRELEASE, PAGE_CACHE_SIZE,
...@@ -1101,19 +1109,14 @@ int ceph_add_cap_releases(struct ceph_mds_client *mdsc, ...@@ -1101,19 +1109,14 @@ int ceph_add_cap_releases(struct ceph_mds_client *mdsc,
session->s_num_cap_releases += CEPH_CAPS_PER_RELEASE; session->s_num_cap_releases += CEPH_CAPS_PER_RELEASE;
} }
if (!list_empty(&session->s_cap_releases)) { if (partial) {
msg = list_first_entry(&session->s_cap_releases, head = partial->front.iov_base;
struct ceph_msg, num = le32_to_cpu(head->num);
list_head); dout(" queueing partial %p with %d/%d\n", partial, num,
head = msg->front.iov_base; (int)CEPH_CAPS_PER_RELEASE);
if (head->num) { list_move_tail(&partial->list_head,
dout(" queueing non-full %p (%d)\n", msg, &session->s_cap_releases_done);
le32_to_cpu(head->num)); session->s_num_cap_releases -= CEPH_CAPS_PER_RELEASE - num;
list_move_tail(&msg->list_head,
&session->s_cap_releases_done);
session->s_num_cap_releases -=
CEPH_CAPS_PER_RELEASE - le32_to_cpu(head->num);
}
} }
err = 0; err = 0;
spin_unlock(&session->s_cap_lock); spin_unlock(&session->s_cap_lock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment