Lines Matching refs:cap

138 	struct ceph_cap *cap;  in ceph_caps_finalize()  local
142 cap = list_first_entry(&mdsc->caps_list, in ceph_caps_finalize()
144 list_del(&cap->caps_item); in ceph_caps_finalize()
145 kmem_cache_free(ceph_cap_cachep, cap); in ceph_caps_finalize()
171 struct ceph_cap *cap; in __ceph_unreserve_caps() local
181 cap = list_first_entry(&mdsc->caps_list, in __ceph_unreserve_caps()
183 list_del(&cap->caps_item); in __ceph_unreserve_caps()
184 kmem_cache_free(ceph_cap_cachep, cap); in __ceph_unreserve_caps()
208 struct ceph_cap *cap; in ceph_reserve_caps() local
233 cap = kmem_cache_alloc(ceph_cap_cachep, GFP_NOFS); in ceph_reserve_caps()
234 if (cap) { in ceph_reserve_caps()
235 list_add(&cap->caps_item, &newcaps); in ceph_reserve_caps()
335 struct ceph_cap *cap = NULL; in ceph_get_cap() local
339 cap = kmem_cache_alloc(ceph_cap_cachep, GFP_NOFS); in ceph_get_cap()
340 if (cap) { in ceph_get_cap()
352 cap = list_first_entry(&mdsc->caps_list, in ceph_get_cap()
354 list_del(&cap->caps_item); in ceph_get_cap()
362 return cap; in ceph_get_cap()
378 cap = list_first_entry(&mdsc->caps_list, struct ceph_cap, caps_item); in ceph_get_cap()
379 list_del(&cap->caps_item); in ceph_get_cap()
384 return cap; in ceph_get_cap()
387 void ceph_put_cap(struct ceph_mds_client *mdsc, struct ceph_cap *cap) in ceph_put_cap() argument
392 doutc(cl, "%p %d = %d used + %d resv + %d avail\n", cap, in ceph_put_cap()
403 kmem_cache_free(ceph_cap_cachep, cap); in ceph_put_cap()
406 list_add(&cap->caps_item, &mdsc->caps_list); in ceph_put_cap()
443 struct ceph_cap *cap; in __get_cap_for_mds() local
447 cap = rb_entry(n, struct ceph_cap, ci_node); in __get_cap_for_mds()
448 if (mds < cap->mds) in __get_cap_for_mds()
450 else if (mds > cap->mds) in __get_cap_for_mds()
453 return cap; in __get_cap_for_mds()
460 struct ceph_cap *cap; in ceph_get_cap_for_mds() local
463 cap = __get_cap_for_mds(ci, mds); in ceph_get_cap_for_mds()
465 return cap; in ceph_get_cap_for_mds()
476 struct ceph_cap *cap = NULL; in __insert_cap_node() local
480 cap = rb_entry(parent, struct ceph_cap, ci_node); in __insert_cap_node()
481 if (new->mds < cap->mds) in __insert_cap_node()
483 else if (new->mds > cap->mds) in __insert_cap_node()
577 static void __check_cap_issue(struct ceph_inode_info *ci, struct ceph_cap *cap, in __check_cap_issue() argument
659 struct ceph_cap *cap; in ceph_add_cap() local
672 cap = __get_cap_for_mds(ci, mds); in ceph_add_cap()
673 if (!cap) { in ceph_add_cap()
674 cap = *new_cap; in ceph_add_cap()
677 cap->issued = 0; in ceph_add_cap()
678 cap->implemented = 0; in ceph_add_cap()
679 cap->mds = mds; in ceph_add_cap()
680 cap->mds_wanted = 0; in ceph_add_cap()
681 cap->mseq = 0; in ceph_add_cap()
683 cap->ci = ci; in ceph_add_cap()
684 __insert_cap_node(ci, cap); in ceph_add_cap()
687 cap->session = session; in ceph_add_cap()
689 list_add_tail(&cap->session_caps, &session->s_caps); in ceph_add_cap()
695 list_move_tail(&cap->session_caps, &session->s_caps); in ceph_add_cap()
698 if (cap->cap_gen < gen) in ceph_add_cap()
699 cap->issued = cap->implemented = CEPH_CAP_PIN; in ceph_add_cap()
710 if (ceph_seq_cmp(seq, cap->seq) <= 0) { in ceph_add_cap()
711 WARN_ON(cap != ci->i_auth_cap); in ceph_add_cap()
712 WARN_ON(cap->cap_id != cap_id); in ceph_add_cap()
713 seq = cap->seq; in ceph_add_cap()
714 mseq = cap->mseq; in ceph_add_cap()
715 issued |= cap->issued; in ceph_add_cap()
736 __check_cap_issue(ci, cap, issued); in ceph_add_cap()
756 ci->i_auth_cap->session != cap->session) in ceph_add_cap()
757 change_auth_cap_ses(ci, cap->session); in ceph_add_cap()
758 ci->i_auth_cap = cap; in ceph_add_cap()
759 cap->mds_wanted = wanted; in ceph_add_cap()
762 WARN_ON(ci->i_auth_cap == cap); in ceph_add_cap()
766 inode, ceph_vinop(inode), cap, ceph_cap_string(issued), in ceph_add_cap()
767 ceph_cap_string(issued|cap->issued), seq, mds); in ceph_add_cap()
768 cap->cap_id = cap_id; in ceph_add_cap()
769 cap->issued = issued; in ceph_add_cap()
770 cap->implemented |= issued; in ceph_add_cap()
771 if (ceph_seq_cmp(mseq, cap->mseq) > 0) in ceph_add_cap()
772 cap->mds_wanted = wanted; in ceph_add_cap()
774 cap->mds_wanted |= wanted; in ceph_add_cap()
775 cap->seq = seq; in ceph_add_cap()
776 cap->issue_seq = seq; in ceph_add_cap()
777 cap->mseq = mseq; in ceph_add_cap()
778 cap->cap_gen = gen; in ceph_add_cap()
787 static int __cap_is_valid(struct ceph_cap *cap) in __cap_is_valid() argument
789 struct inode *inode = &cap->ci->netfs.inode; in __cap_is_valid()
790 struct ceph_client *cl = cap->session->s_mdsc->fsc->client; in __cap_is_valid()
794 gen = atomic_read(&cap->session->s_cap_gen); in __cap_is_valid()
795 ttl = cap->session->s_cap_ttl; in __cap_is_valid()
797 if (cap->cap_gen < gen || time_after_eq(jiffies, ttl)) { in __cap_is_valid()
799 inode, ceph_vinop(inode), cap, in __cap_is_valid()
800 ceph_cap_string(cap->issued), cap->cap_gen, gen); in __cap_is_valid()
817 struct ceph_cap *cap; in __ceph_caps_issued() local
823 cap = rb_entry(p, struct ceph_cap, ci_node); in __ceph_caps_issued()
824 if (!__cap_is_valid(cap)) in __ceph_caps_issued()
827 ceph_vinop(inode), cap, ceph_cap_string(cap->issued)); in __ceph_caps_issued()
828 have |= cap->issued; in __ceph_caps_issued()
830 *implemented |= cap->implemented; in __ceph_caps_issued()
838 cap = ci->i_auth_cap; in __ceph_caps_issued()
839 have &= ~cap->implemented | cap->issued; in __ceph_caps_issued()
850 struct ceph_cap *cap; in __ceph_caps_issued_other() local
854 cap = rb_entry(p, struct ceph_cap, ci_node); in __ceph_caps_issued_other()
855 if (cap == ocap) in __ceph_caps_issued_other()
857 if (!__cap_is_valid(cap)) in __ceph_caps_issued_other()
859 have |= cap->issued; in __ceph_caps_issued_other()
868 static void __touch_cap(struct ceph_cap *cap) in __touch_cap() argument
870 struct inode *inode = &cap->ci->netfs.inode; in __touch_cap()
871 struct ceph_mds_session *s = cap->session; in __touch_cap()
877 ceph_vinop(inode), cap, s->s_mds); in __touch_cap()
878 list_move_tail(&cap->session_caps, &s->s_caps); in __touch_cap()
881 inode, ceph_vinop(inode), cap, s->s_mds); in __touch_cap()
895 struct ceph_cap *cap; in __ceph_caps_issued_mask() local
907 cap = rb_entry(p, struct ceph_cap, ci_node); in __ceph_caps_issued_mask()
908 if (!__cap_is_valid(cap)) in __ceph_caps_issued_mask()
910 if ((cap->issued & mask) == mask) { in __ceph_caps_issued_mask()
912 inode, ceph_vinop(inode), cap, in __ceph_caps_issued_mask()
913 ceph_cap_string(cap->issued), in __ceph_caps_issued_mask()
916 __touch_cap(cap); in __ceph_caps_issued_mask()
921 have |= cap->issued; in __ceph_caps_issued_mask()
925 ceph_cap_string(cap->issued), in __ceph_caps_issued_mask()
931 __touch_cap(cap); in __ceph_caps_issued_mask()
934 cap = rb_entry(q, struct ceph_cap, in __ceph_caps_issued_mask()
936 if (!__cap_is_valid(cap)) in __ceph_caps_issued_mask()
938 if (cap->issued & mask) in __ceph_caps_issued_mask()
939 __touch_cap(cap); in __ceph_caps_issued_mask()
969 struct ceph_cap *cap; in __ceph_caps_revoking_other() local
973 cap = rb_entry(p, struct ceph_cap, ci_node); in __ceph_caps_revoking_other()
974 if (cap != ocap && in __ceph_caps_revoking_other()
975 (cap->implemented & ~cap->issued & mask)) in __ceph_caps_revoking_other()
1101 struct ceph_cap *cap; in __ceph_caps_mds_wanted() local
1106 cap = rb_entry(p, struct ceph_cap, ci_node); in __ceph_caps_mds_wanted()
1107 if (check && !__cap_is_valid(cap)) in __ceph_caps_mds_wanted()
1109 if (cap == ci->i_auth_cap) in __ceph_caps_mds_wanted()
1110 mds_wanted |= cap->mds_wanted; in __ceph_caps_mds_wanted()
1112 mds_wanted |= (cap->mds_wanted & ~CEPH_CAP_ANY_FILE_WR); in __ceph_caps_mds_wanted()
1135 void __ceph_remove_cap(struct ceph_cap *cap, bool queue_release) in __ceph_remove_cap() argument
1137 struct ceph_mds_session *session = cap->session; in __ceph_remove_cap()
1139 struct ceph_inode_info *ci = cap->ci; in __ceph_remove_cap()
1152 doutc(cl, "%p from %p %llx.%llx\n", cap, inode, ceph_vinop(inode)); in __ceph_remove_cap()
1157 rb_erase(&cap->ci_node, &ci->i_caps); in __ceph_remove_cap()
1158 if (ci->i_auth_cap == cap) in __ceph_remove_cap()
1163 if (session->s_cap_iterator == cap) { in __ceph_remove_cap()
1165 doutc(cl, "delaying %p removal from session %p\n", cap, in __ceph_remove_cap()
1166 cap->session); in __ceph_remove_cap()
1168 list_del_init(&cap->session_caps); in __ceph_remove_cap()
1171 cap->session = NULL; in __ceph_remove_cap()
1175 cap->ci = NULL; in __ceph_remove_cap()
1183 cap->cap_gen == atomic_read(&session->s_cap_gen))) { in __ceph_remove_cap()
1184 cap->queue_release = 1; in __ceph_remove_cap()
1186 __ceph_queue_cap_release(session, cap); in __ceph_remove_cap()
1190 cap->queue_release = 0; in __ceph_remove_cap()
1192 cap->cap_ino = ci->i_vino.ino; in __ceph_remove_cap()
1197 ceph_put_cap(mdsc, cap); in __ceph_remove_cap()
1211 void ceph_remove_cap(struct ceph_mds_client *mdsc, struct ceph_cap *cap, in ceph_remove_cap() argument
1214 struct ceph_inode_info *ci = cap->ci; in ceph_remove_cap()
1226 WARN_ON_ONCE(ci->i_auth_cap == cap && in ceph_remove_cap()
1231 __ceph_remove_cap(cap, queue_release); in ceph_remove_cap()
1389 struct ceph_cap *cap = rb_entry(p, struct ceph_cap, ci_node); in __ceph_remove_caps() local
1391 ceph_remove_cap(mdsc, cap, true); in __ceph_remove_caps()
1404 static void __prep_cap(struct cap_msg_args *arg, struct ceph_cap *cap, in __prep_cap() argument
1408 struct ceph_inode_info *ci = cap->ci; in __prep_cap()
1415 held = cap->issued | cap->implemented; in __prep_cap()
1416 revoking = cap->implemented & ~cap->issued; in __prep_cap()
1420 inode, ceph_vinop(inode), cap, cap->session, in __prep_cap()
1427 cap->issued &= retain; /* drop bits we don't want */ in __prep_cap()
1433 arg->wake = cap->implemented & ~cap->issued; in __prep_cap()
1434 cap->implemented &= cap->issued | used; in __prep_cap()
1435 cap->mds_wanted = want; in __prep_cap()
1437 arg->session = cap->session; in __prep_cap()
1439 arg->cid = cap->cap_id; in __prep_cap()
1446 if (cap == ci->i_auth_cap) { in __prep_cap()
1469 arg->caps = cap->implemented; in __prep_cap()
1473 arg->seq = cap->seq; in __prep_cap()
1474 arg->issue_seq = cap->issue_seq; in __prep_cap()
1475 arg->mseq = cap->mseq; in __prep_cap()
1685 struct ceph_cap *cap = ci->i_auth_cap; in __ceph_flush_snaps() local
1689 if (!(cap && cap->session == session)) { in __ceph_flush_snaps()
1691 inode, ceph_vinop(inode), cap, session->s_mds); in __ceph_flush_snaps()
1716 ret = __send_flush_snap(inode, session, capsnap, cap->mseq, in __ceph_flush_snaps()
2028 struct ceph_cap *cap; in ceph_check_caps() local
2141 cap = rb_entry(p, struct ceph_cap, ci_node); in ceph_check_caps()
2144 if (mds >= cap->mds || in ceph_check_caps()
2145 ((flags & CHECK_CAPS_AUTHONLY) && cap != ci->i_auth_cap)) in ceph_check_caps()
2153 if (ci->i_auth_cap && cap != ci->i_auth_cap) in ceph_check_caps()
2156 revoking = cap->implemented & ~cap->issued; in ceph_check_caps()
2158 cap->mds, cap, ceph_cap_string(cap_used), in ceph_check_caps()
2159 ceph_cap_string(cap->issued), in ceph_check_caps()
2160 ceph_cap_string(cap->implemented), in ceph_check_caps()
2167 ceph_cap_string(cap->implemented & ~cap->issued)); in ceph_check_caps()
2192 if (cap == ci->i_auth_cap && in ceph_check_caps()
2193 (cap->issued & CEPH_CAP_FILE_WR)) { in ceph_check_caps()
2208 if (cap == ci->i_auth_cap) { in ceph_check_caps()
2220 if (want & ~cap->mds_wanted) { in ceph_check_caps()
2221 if (want & ~(cap->mds_wanted | cap->issued)) in ceph_check_caps()
2223 if (!__cap_is_valid(cap)) in ceph_check_caps()
2228 if ((cap->issued & ~retain) == 0) in ceph_check_caps()
2233 session = ceph_get_mds_session(cap->session); in ceph_check_caps()
2237 if (cap == ci->i_auth_cap && in ceph_check_caps()
2248 if (cap == ci->i_auth_cap && ci->i_dirty_caps) { in ceph_check_caps()
2263 mds = cap->mds; /* remember mds, so we don't repeat */ in ceph_check_caps()
2265 __prep_cap(&arg, cap, CEPH_CAP_OP_UPDATE, mflags, cap_used, in ceph_check_caps()
2305 struct ceph_cap *cap = ci->i_auth_cap; in try_flush_caps() local
2307 struct ceph_mds_session *session = cap->session; in try_flush_caps()
2327 __prep_cap(&arg, cap, CEPH_CAP_OP_FLUSH, CEPH_CLIENT_CAPS_SYNC, in try_flush_caps()
2329 (cap->issued | cap->implemented), in try_flush_caps()
2583 struct ceph_cap *cap; in __kick_flushing_caps() local
2606 cap = ci->i_auth_cap; in __kick_flushing_caps()
2607 if (!(cap && cap->session == session)) { in __kick_flushing_caps()
2609 inode, cap, session->s_mds); in __kick_flushing_caps()
2619 inode, ceph_vinop(inode), cap, cf->tid, in __kick_flushing_caps()
2621 __prep_cap(&arg, cap, CEPH_CAP_OP_FLUSH, in __kick_flushing_caps()
2626 (cap->issued | cap->implemented), in __kick_flushing_caps()
2641 ret = __send_flush_snap(inode, session, capsnap, cap->mseq, in __kick_flushing_caps()
2662 struct ceph_cap *cap; in ceph_early_kick_flushing_caps() local
2675 cap = ci->i_auth_cap; in ceph_early_kick_flushing_caps()
2676 if (!(cap && cap->session == session)) { in ceph_early_kick_flushing_caps()
2678 inode, ceph_vinop(inode), cap, in ceph_early_kick_flushing_caps()
2691 if ((cap->issued & ci->i_flushing_caps) != in ceph_early_kick_flushing_caps()
2696 cap->seq = 0; in ceph_early_kick_flushing_caps()
2697 cap->issue_seq = 0; in ceph_early_kick_flushing_caps()
2698 cap->mseq = 0; in ceph_early_kick_flushing_caps()
2714 struct ceph_cap *cap; in ceph_kick_flushing_caps() local
2729 cap = ci->i_auth_cap; in ceph_kick_flushing_caps()
2730 if (!(cap && cap->session == session)) { in ceph_kick_flushing_caps()
2732 inode, ceph_vinop(inode), cap, in ceph_kick_flushing_caps()
2749 struct ceph_cap *cap = ci->i_auth_cap; in ceph_kick_flushing_inode_caps() local
2762 &cap->session->s_cap_flushing); in ceph_kick_flushing_inode_caps()
3500 struct ceph_cap *cap, in handle_cap_grant() argument
3515 bool was_stale = cap->cap_gen < atomic_read(&session->s_cap_gen); in handle_cap_grant()
3534 ceph_vinop(inode), cap, session->s_mds, seq, in handle_cap_grant()
3546 ((cap->issued & ~newcaps) & CEPH_CAP_FILE_CACHE) && in handle_cap_grant()
3560 cap->issued = cap->implemented = CEPH_CAP_PIN; in handle_cap_grant()
3570 if (ceph_seq_cmp(seq, cap->seq) <= 0) { in handle_cap_grant()
3571 WARN_ON(cap != ci->i_auth_cap); in handle_cap_grant()
3572 WARN_ON(cap->cap_id != le64_to_cpu(grant->cap_id)); in handle_cap_grant()
3573 seq = cap->seq; in handle_cap_grant()
3574 newcaps |= cap->issued; in handle_cap_grant()
3578 cap->cap_gen = atomic_read(&session->s_cap_gen); in handle_cap_grant()
3579 cap->seq = seq; in handle_cap_grant()
3581 __check_cap_issue(ci, cap, newcaps); in handle_cap_grant()
3675 if (ci->i_auth_cap == cap && (newcaps & CEPH_CAP_ANY_FILE_WR)) { in handle_cap_grant()
3697 (wanted & ~(cap->mds_wanted | newcaps))) { in handle_cap_grant()
3712 if (cap->issued & ~newcaps) { in handle_cap_grant()
3713 int revoking = cap->issued & ~newcaps; in handle_cap_grant()
3716 ceph_cap_string(cap->issued), ceph_cap_string(newcaps), in handle_cap_grant()
3726 } else if (cap == ci->i_auth_cap) { in handle_cap_grant()
3732 if (~cap->issued & newcaps) in handle_cap_grant()
3734 cap->issued = newcaps; in handle_cap_grant()
3735 cap->implemented |= newcaps; in handle_cap_grant()
3736 } else if (cap->issued == newcaps) { in handle_cap_grant()
3738 ceph_cap_string(cap->issued), in handle_cap_grant()
3741 doutc(cl, "grant: %s -> %s\n", ceph_cap_string(cap->issued), in handle_cap_grant()
3744 if (cap == ci->i_auth_cap && in handle_cap_grant()
3745 __ceph_caps_revoking_other(ci, cap, newcaps)) in handle_cap_grant()
3748 cap->issued = newcaps; in handle_cap_grant()
3749 cap->implemented |= newcaps; /* add bits only, to in handle_cap_grant()
3754 BUG_ON(cap->issued & ~cap->implemented); in handle_cap_grant()
3758 cap->mds_wanted = 0; in handle_cap_grant()
3760 if (cap == ci->i_auth_cap) in handle_cap_grant()
3775 if (ci->i_auth_cap == cap) { in handle_cap_grant()
3827 struct ceph_cap *cap) in handle_cap_flush_ack() argument
4085 struct ceph_cap *cap, *tcap, *new_cap = NULL; in handle_cap_export() local
4108 cap = __get_cap_for_mds(ci, mds); in handle_cap_export()
4109 if (!cap || cap->cap_id != le64_to_cpu(ex->cap_id)) in handle_cap_export()
4113 ceph_remove_cap(mdsc, cap, false); in handle_cap_export()
4122 issued = cap->issued; in handle_cap_export()
4123 if (issued != cap->implemented) in handle_cap_export()
4128 cap->seq, cap->mseq, in handle_cap_export()
4130 ceph_cap_string(cap->implemented)); in handle_cap_export()
4145 if (cap == ci->i_auth_cap) { in handle_cap_export()
4150 ceph_remove_cap(mdsc, cap, false); in handle_cap_export()
4154 int flag = (cap == ci->i_auth_cap) ? CEPH_CAP_FLAG_AUTH : 0; in handle_cap_export()
4167 ceph_remove_cap(mdsc, cap, false); in handle_cap_export()
4221 struct ceph_cap *cap, *ocap, *new_cap = NULL; in handle_cap_import() local
4244 cap = __get_cap_for_mds(ci, mds); in handle_cap_import()
4245 if (!cap) { in handle_cap_import()
4252 cap = new_cap; in handle_cap_import()
4285 *target_cap = cap; in handle_cap_import()
4347 struct ceph_cap *cap; in ceph_handle_caps() local
4516 &cap, &extra_info.issued); in ceph_handle_caps()
4517 handle_cap_grant(inode, session, cap, in ceph_handle_caps()
4526 cap = __get_cap_for_mds(ceph_inode(inode), session->s_mds); in ceph_handle_caps()
4527 if (!cap) { in ceph_handle_caps()
4549 handle_cap_grant(inode, session, cap, in ceph_handle_caps()
4555 h, session, cap); in ceph_handle_caps()
4595 cap = ceph_get_cap(mdsc, NULL); in ceph_handle_caps()
4596 cap->cap_ino = vino.ino; in ceph_handle_caps()
4597 cap->queue_release = 1; in ceph_handle_caps()
4598 cap->cap_id = le64_to_cpu(h->cap_id); in ceph_handle_caps()
4599 cap->mseq = mseq; in ceph_handle_caps()
4600 cap->seq = seq; in ceph_handle_caps()
4601 cap->issue_seq = seq; in ceph_handle_caps()
4603 __ceph_queue_cap_release(session, cap); in ceph_handle_caps()
4860 struct ceph_cap *cap; in ceph_encode_inode_release() local
4876 cap = __get_cap_for_mds(ci, mds); in ceph_encode_inode_release()
4877 if (cap && __cap_is_valid(cap)) { in ceph_encode_inode_release()
4878 unless &= cap->issued; in ceph_encode_inode_release()
4890 if (force || (cap->issued & drop)) { in ceph_encode_inode_release()
4891 if (cap->issued & drop) { in ceph_encode_inode_release()
4895 ceph_vinop(inode), cap, in ceph_encode_inode_release()
4896 ceph_cap_string(cap->issued), in ceph_encode_inode_release()
4897 ceph_cap_string(cap->issued & ~drop), in ceph_encode_inode_release()
4898 ceph_cap_string(cap->mds_wanted), in ceph_encode_inode_release()
4901 cap->issued &= ~drop; in ceph_encode_inode_release()
4902 cap->implemented &= ~drop; in ceph_encode_inode_release()
4903 cap->mds_wanted = wanted; in ceph_encode_inode_release()
4904 if (cap == ci->i_auth_cap && in ceph_encode_inode_release()
4909 inode, ceph_vinop(inode), cap, in ceph_encode_inode_release()
4910 ceph_cap_string(cap->issued)); in ceph_encode_inode_release()
4914 rel->cap_id = cpu_to_le64(cap->cap_id); in ceph_encode_inode_release()
4915 rel->seq = cpu_to_le32(cap->seq); in ceph_encode_inode_release()
4916 rel->issue_seq = cpu_to_le32(cap->issue_seq); in ceph_encode_inode_release()
4917 rel->mseq = cpu_to_le32(cap->mseq); in ceph_encode_inode_release()
4918 rel->caps = cpu_to_le32(cap->implemented); in ceph_encode_inode_release()
4919 rel->wanted = cpu_to_le32(cap->mds_wanted); in ceph_encode_inode_release()
4926 inode, ceph_vinop(inode), cap, in ceph_encode_inode_release()
4927 ceph_cap_string(cap->issued)); in ceph_encode_inode_release()
5024 int ceph_purge_inode_cap(struct inode *inode, struct ceph_cap *cap, bool *invalidate) in ceph_purge_inode_cap() argument
5037 cap, ci, inode, ceph_vinop(inode)); in ceph_purge_inode_cap()
5039 is_auth = (cap == ci->i_auth_cap); in ceph_purge_inode_cap()
5040 __ceph_remove_cap(cap, false); in ceph_purge_inode_cap()