]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
messages: add MFSMapUser
authorYan, Zheng <zyan@redhat.com>
Wed, 6 Apr 2016 12:59:22 +0000 (20:59 +0800)
committerYan, Zheng <zyan@redhat.com>
Fri, 10 Jun 2016 01:25:07 +0000 (09:25 +0800)
For mon clients that subscribe to 'fsmap.user'

Signed-off-by: Yan, Zheng <zyan@redhat.com>
src/include/ceph_fs.h
src/messages/MFSMapUser.h [new file with mode: 0644]
src/messages/Makefile.am
src/msg/Message.cc

index 70f83e3d2b9947041254baf04914def5280069c8..afe3e3618ab40a90f62724e9152215ccbeb7796b 100644 (file)
@@ -133,6 +133,8 @@ struct ceph_dir_layout {
 
 /* FSMap subscribers (see all MDS clusters at once) */
 #define CEPH_MSG_FS_MAP                 45
+/* FSMapUser subscribers (get MDS clusters name->ID mapping) */
+#define CEPH_MSG_FS_MAP_USER           103
 
 
 /* watch-notify operations */
diff --git a/src/messages/MFSMapUser.h b/src/messages/MFSMapUser.h
new file mode 100644 (file)
index 0000000..ae222c2
--- /dev/null
@@ -0,0 +1,59 @@
+// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
+// vim: ts=8 sw=2 smarttab
+/*
+ * Ceph - scalable distributed file system
+ *
+ * Copyright (C) 2004-2006 Sage Weil <sage@newdream.net>
+ *
+ * This is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License version 2.1, as published by the Free Software
+ * Foundation.  See file COPYING.
+ */
+
+
+#ifndef CEPH_MFSMAPCOMPACT_H
+#define CEPH_MFSMAPCOMPACT_H
+
+#include "msg/Message.h"
+#include "mds/FSMapUser.h"
+#include "include/ceph_features.h"
+
+class MFSMapUser : public Message {
+ public:
+  epoch_t epoch;
+
+  version_t get_epoch() const { return epoch; }
+  const FSMapUser & get_fsmap() { return fsmap; }
+
+  MFSMapUser() :
+    Message(CEPH_MSG_FS_MAP_USER), epoch(0) {}
+  MFSMapUser(const uuid_d &f, const FSMapUser &fsmap_) :
+    Message(CEPH_MSG_FS_MAP_USER), epoch(fsmap_.epoch)
+  {
+    fsmap = fsmap_;
+  }
+private:
+  FSMapUser fsmap;
+
+  ~MFSMapUser() {}
+
+public:
+  const char *get_type_name() const { return "fsmap.user"; }
+  void print(ostream& out) const {
+    out << "fsmap.user(e " << epoch << ")";
+  }
+
+  // marshalling
+  void decode_payload() {
+    bufferlist::iterator p = payload.begin();
+    ::decode(epoch, p);
+    ::decode(fsmap, p);
+  }
+  void encode_payload(uint64_t features) {
+    ::encode(epoch, payload);
+    ::encode(fsmap, payload, features);
+  }
+};
+
+#endif
index 0f4257bd487c228b909837b5678dce7366174df8..0f74e15f1fec7b6687de55463c33997a49577fd1 100644 (file)
@@ -49,6 +49,7 @@ noinst_HEADERS += \
        messages/MMDSFragmentNotify.h \
        messages/MMDSMap.h \
        messages/MFSMap.h \
+       messages/MFSMapUser.h \
        messages/MMDSOpenIno.h \
        messages/MMDSOpenInoReply.h \
        messages/MMDSResolve.h \
index f84004bd7b177447156eb18cf1604d09ac2a9535..010caf3d73a6c248b02337936b7c10e8742899f7 100644 (file)
@@ -112,6 +112,7 @@ using namespace std;
 
 #include "messages/MMDSMap.h"
 #include "messages/MFSMap.h"
+#include "messages/MFSMapUser.h"
 #include "messages/MMDSBeacon.h"
 #include "messages/MMDSLoadTargets.h"
 #include "messages/MMDSResolve.h"
@@ -578,6 +579,9 @@ Message *decode_message(CephContext *cct, int crcflags,
   case CEPH_MSG_FS_MAP:
     m = new MFSMap;
     break;
+  case CEPH_MSG_FS_MAP_USER:
+    m = new MFSMapUser;
+    break;
   case MSG_MDS_BEACON:
     m = new MMDSBeacon;
     break;