Lines Matching refs:capsnap

1422 		struct ceph_cap_snap *capsnap;  in __prep_cap()  local
1423 list_for_each_entry_reverse(capsnap, &ci->i_cap_snaps, ci_item) { in __prep_cap()
1424 if (capsnap->cap_flush.tid) in __prep_cap()
1426 if (capsnap->need_flush) { in __prep_cap()
1465 struct ceph_cap_snap *capsnap, in __send_flush_snap() argument
1478 arg.follows = capsnap->follows; in __send_flush_snap()
1479 arg.flush_tid = capsnap->cap_flush.tid; in __send_flush_snap()
1482 arg.size = capsnap->size; in __send_flush_snap()
1484 arg.xattr_version = capsnap->xattr_version; in __send_flush_snap()
1485 arg.xattr_buf = capsnap->xattr_blob; in __send_flush_snap()
1488 arg.atime = capsnap->atime; in __send_flush_snap()
1489 arg.mtime = capsnap->mtime; in __send_flush_snap()
1490 arg.ctime = capsnap->ctime; in __send_flush_snap()
1491 arg.btime = capsnap->btime; in __send_flush_snap()
1492 arg.change_attr = capsnap->change_attr; in __send_flush_snap()
1495 arg.caps = capsnap->issued; in __send_flush_snap()
1497 arg.dirty = capsnap->dirty; in __send_flush_snap()
1502 arg.time_warp_seq = capsnap->time_warp_seq; in __send_flush_snap()
1504 arg.uid = capsnap->uid; in __send_flush_snap()
1505 arg.gid = capsnap->gid; in __send_flush_snap()
1506 arg.mode = capsnap->mode; in __send_flush_snap()
1508 arg.inline_data = capsnap->inline_data; in __send_flush_snap()
1533 struct ceph_cap_snap *capsnap; in __ceph_flush_snaps() local
1539 list_for_each_entry(capsnap, &ci->i_cap_snaps, ci_item) { in __ceph_flush_snaps()
1544 if (capsnap->dirty_pages || capsnap->writing) in __ceph_flush_snaps()
1548 BUG_ON(!capsnap->need_flush); in __ceph_flush_snaps()
1551 if (capsnap->cap_flush.tid > 0) { in __ceph_flush_snaps()
1552 dout(" already flushed %p, skipping\n", capsnap); in __ceph_flush_snaps()
1557 capsnap->cap_flush.tid = ++mdsc->last_cap_flush_tid; in __ceph_flush_snaps()
1558 list_add_tail(&capsnap->cap_flush.g_list, in __ceph_flush_snaps()
1568 list_add_tail(&capsnap->cap_flush.i_list, in __ceph_flush_snaps()
1572 first_tid = capsnap->cap_flush.tid; in __ceph_flush_snaps()
1573 last_tid = capsnap->cap_flush.tid; in __ceph_flush_snaps()
1601 capsnap = container_of(cf, struct ceph_cap_snap, cap_flush); in __ceph_flush_snaps()
1602 refcount_inc(&capsnap->nref); in __ceph_flush_snaps()
1606 inode, capsnap, cf->tid, ceph_cap_string(capsnap->dirty)); in __ceph_flush_snaps()
1608 ret = __send_flush_snap(inode, session, capsnap, cap->mseq, in __ceph_flush_snaps()
1613 ceph_vinop(inode), cf->tid, capsnap->follows); in __ceph_flush_snaps()
1616 ceph_put_cap_snap(capsnap); in __ceph_flush_snaps()
2458 struct ceph_cap_snap *capsnap = in __kick_flushing_caps() local
2462 inode, capsnap, cf->tid, in __kick_flushing_caps()
2463 ceph_cap_string(capsnap->dirty)); in __kick_flushing_caps()
2465 refcount_inc(&capsnap->nref); in __kick_flushing_caps()
2468 ret = __send_flush_snap(inode, session, capsnap, cap->mseq, in __kick_flushing_caps()
2475 capsnap->follows); in __kick_flushing_caps()
2478 ceph_put_cap_snap(capsnap); in __kick_flushing_caps()
3001 struct ceph_cap_snap *capsnap) in ceph_try_drop_cap_snap() argument
3003 if (!capsnap->need_flush && in ceph_try_drop_cap_snap()
3004 !capsnap->writing && !capsnap->dirty_pages) { in ceph_try_drop_cap_snap()
3006 capsnap, capsnap->follows); in ceph_try_drop_cap_snap()
3007 BUG_ON(capsnap->cap_flush.tid > 0); in ceph_try_drop_cap_snap()
3008 ceph_put_snap_context(capsnap->context); in ceph_try_drop_cap_snap()
3009 if (!list_is_last(&capsnap->ci_item, &ci->i_cap_snaps)) in ceph_try_drop_cap_snap()
3012 list_del(&capsnap->ci_item); in ceph_try_drop_cap_snap()
3013 ceph_put_cap_snap(capsnap); in ceph_try_drop_cap_snap()
3080 struct ceph_cap_snap *capsnap = in __ceph_put_cap_refs() local
3085 capsnap->writing = 0; in __ceph_put_cap_refs()
3086 if (ceph_try_drop_cap_snap(ci, capsnap)) in __ceph_put_cap_refs()
3089 else if (__ceph_finish_cap_snap(ci, capsnap)) in __ceph_put_cap_refs()
3146 struct ceph_cap_snap *capsnap = NULL; in ceph_put_wrbuffer_cap_refs() local
3176 list_for_each_entry(capsnap, &ci->i_cap_snaps, ci_item) { in ceph_put_wrbuffer_cap_refs()
3177 if (capsnap->context == snapc) { in ceph_put_wrbuffer_cap_refs()
3192 capsnap->dirty_pages -= nr; in ceph_put_wrbuffer_cap_refs()
3193 if (capsnap->dirty_pages == 0) { in ceph_put_wrbuffer_cap_refs()
3195 if (!capsnap->writing) { in ceph_put_wrbuffer_cap_refs()
3196 if (ceph_try_drop_cap_snap(ci, capsnap)) { in ceph_put_wrbuffer_cap_refs()
3206 inode, capsnap, capsnap->context->seq, in ceph_put_wrbuffer_cap_refs()
3207 ci->i_wrbuffer_ref+nr, capsnap->dirty_pages + nr, in ceph_put_wrbuffer_cap_refs()
3208 ci->i_wrbuffer_ref, capsnap->dirty_pages, in ceph_put_wrbuffer_cap_refs()
3684 void __ceph_remove_capsnap(struct inode *inode, struct ceph_cap_snap *capsnap, in __ceph_remove_capsnap() argument
3693 dout("removing capsnap %p, inode %p ci %p\n", capsnap, inode, ci); in __ceph_remove_capsnap()
3695 list_del_init(&capsnap->ci_item); in __ceph_remove_capsnap()
3696 ret = __detach_cap_flush_from_ci(ci, &capsnap->cap_flush); in __ceph_remove_capsnap()
3704 ret = __detach_cap_flush_from_mdsc(mdsc, &capsnap->cap_flush); in __ceph_remove_capsnap()
3710 void ceph_remove_capsnap(struct inode *inode, struct ceph_cap_snap *capsnap, in ceph_remove_capsnap() argument
3717 WARN_ON_ONCE(capsnap->dirty_pages || capsnap->writing); in ceph_remove_capsnap()
3718 __ceph_remove_capsnap(inode, capsnap, wake_ci, wake_mdsc); in ceph_remove_capsnap()
3734 struct ceph_cap_snap *capsnap; in handle_cap_flushsnap_ack() local
3743 list_for_each_entry(capsnap, &ci->i_cap_snaps, ci_item) { in handle_cap_flushsnap_ack()
3744 if (capsnap->follows == follows) { in handle_cap_flushsnap_ack()
3745 if (capsnap->cap_flush.tid != flush_tid) { in handle_cap_flushsnap_ack()
3747 " %lld\n", capsnap, follows, in handle_cap_flushsnap_ack()
3748 flush_tid, capsnap->cap_flush.tid); in handle_cap_flushsnap_ack()
3755 capsnap, capsnap->follows); in handle_cap_flushsnap_ack()
3759 ceph_remove_capsnap(inode, capsnap, &wake_ci, &wake_mdsc); in handle_cap_flushsnap_ack()
3763 ceph_put_snap_context(capsnap->context); in handle_cap_flushsnap_ack()
3764 ceph_put_cap_snap(capsnap); in handle_cap_flushsnap_ack()