initial code repo
[stor4nfv.git] / src / ceph / src / rbd_replay / PendingIO.hpp
diff --git a/src/ceph/src/rbd_replay/PendingIO.hpp b/src/ceph/src/rbd_replay/PendingIO.hpp
new file mode 100644 (file)
index 0000000..3942d5f
--- /dev/null
@@ -0,0 +1,64 @@
+// -*- 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) 2014 Adam Crume <adamcrume@gmail.com>
+ *
+ * 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 _INCLUDED_RBD_REPLAY_PENDINGIO_HPP
+#define _INCLUDED_RBD_REPLAY_PENDINGIO_HPP
+
+#include <boost/enable_shared_from_this.hpp>
+#include "actions.hpp"
+
+/// Do not call outside of rbd_replay::PendingIO.
+extern "C"
+void rbd_replay_pending_io_callback(librbd::completion_t cb, void *arg);
+
+namespace rbd_replay {
+
+/**
+   A PendingIO is an I/O operation that has been started but not completed.
+*/
+class PendingIO : public boost::enable_shared_from_this<PendingIO> {
+public:
+  typedef boost::shared_ptr<PendingIO> ptr;
+
+  PendingIO(action_id_t id,
+            ActionCtx &worker);
+
+  ~PendingIO();
+
+  action_id_t id() const {
+    return m_id;
+  }
+
+  ceph::bufferlist &bufferlist() {
+    return m_bl;
+  }
+
+  librbd::RBD::AioCompletion &completion() {
+    return *m_completion;
+  }
+
+private:
+  void completed(librbd::completion_t cb);
+
+  friend void ::rbd_replay_pending_io_callback(librbd::completion_t cb, void *arg);
+
+  const action_id_t m_id;
+  ceph::bufferlist m_bl;
+  librbd::RBD::AioCompletion *m_completion;
+  ActionCtx &m_worker;
+};
+
+}
+
+#endif