// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab #ifndef CEPH_CLIENT_METASESSION_H #define CEPH_CLIENT_METASESSION_H #include "include/types.h" #include "include/utime.h" #include "include/xlist.h" #include "mds/MDSMap.h" #include "mds/mdstypes.h" #include "messages/MClientCapRelease.h" struct Cap; struct Inode; struct CapSnap; struct MetaRequest; struct MetaSession { mds_rank_t mds_num; ConnectionRef con; version_t seq; uint64_t cap_gen; utime_t cap_ttl, last_cap_renew_request; uint64_t cap_renew_seq; entity_addrvec_t addrs; feature_bitset_t mds_features; enum { STATE_NEW, // Unused STATE_OPENING, STATE_OPEN, STATE_CLOSING, STATE_CLOSED, STATE_STALE, } state; enum { RECLAIM_NULL, RECLAIMING, RECLAIM_OK, RECLAIM_FAIL, } reclaim_state; int mds_state; bool readonly; list waiting_for_open; xlist caps; xlist flushing_caps; xlist requests; xlist unsafe_requests; std::set flushing_caps_tids; MClientCapRelease::ref release; MetaSession(mds_rank_t mds_num, ConnectionRef con, const entity_addrvec_t& addrs) : mds_num(mds_num), con(con), seq(0), cap_gen(0), cap_renew_seq(0), addrs(addrs), state(STATE_OPENING), reclaim_state(RECLAIM_NULL), mds_state(MDSMap::STATE_NULL), readonly(false) {} const char *get_state_name() const; void dump(Formatter *f) const; void enqueue_cap_release(inodeno_t ino, uint64_t cap_id, ceph_seq_t iseq, ceph_seq_t mseq, epoch_t osd_barrier); }; #endif