]>
git.proxmox.com Git - ceph.git/blob - ceph/src/tools/rbd_mirror/image_replayer/GetMirrorImageIdRequest.cc
1 // -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
2 // vim: ts=8 sw=2 smarttab
4 #include "tools/rbd_mirror/image_replayer/GetMirrorImageIdRequest.h"
5 #include "include/rados/librados.hpp"
6 #include "cls/rbd/cls_rbd_client.h"
7 #include "common/debug.h"
8 #include "common/errno.h"
9 #include "librbd/ImageCtx.h"
10 #include "librbd/Utils.h"
12 #define dout_context g_ceph_context
13 #define dout_subsys ceph_subsys_rbd_mirror
15 #define dout_prefix *_dout << "rbd::mirror::image_replayer::" \
16 << "GetMirrorImageIdRequest: " << this << " " \
21 namespace image_replayer
{
23 using librbd::util::create_rados_callback
;
26 void GetMirrorImageIdRequest
<I
>::send() {
32 void GetMirrorImageIdRequest
<I
>::get_image_id() {
35 // attempt to cross-reference a image id by the global image id
36 librados::ObjectReadOperation op
;
37 librbd::cls_client::mirror_image_get_image_id_start(&op
, m_global_image_id
);
39 librados::AioCompletion
*aio_comp
= create_rados_callback
<
40 GetMirrorImageIdRequest
<I
>,
41 &GetMirrorImageIdRequest
<I
>::handle_get_image_id
>(
43 int r
= m_io_ctx
.aio_operate(RBD_MIRRORING
, aio_comp
, &op
, &m_out_bl
);
49 void GetMirrorImageIdRequest
<I
>::handle_get_image_id(int r
) {
51 auto iter
= m_out_bl
.cbegin();
52 r
= librbd::cls_client::mirror_image_get_image_id_finish(
56 dout(20) << "r=" << r
<< ", "
57 << "image_id=" << *m_image_id
<< dendl
;
61 dout(10) << "global image " << m_global_image_id
<< " not registered"
64 derr
<< "failed to retrieve image id: " << cpp_strerror(r
) << dendl
;
74 void GetMirrorImageIdRequest
<I
>::finish(int r
) {
75 dout(20) << "r=" << r
<< dendl
;
77 m_on_finish
->complete(r
);
81 } // namespace image_replayer
85 template class rbd::mirror::image_replayer::GetMirrorImageIdRequest
<librbd::ImageCtx
>;