#include "librbd/ImageCtx.h"
#include "librbd/Utils.h"
#include "librbd/io/AioCompletion.h"
+#include "librbd/io/ImageDispatchSpec.h"
#include "librbd/io/ImageRequest.h"
#include "librbd/io/ReadResult.h"
+#undef dout_subsys
#define dout_subsys ceph_subsys_rbd
#undef dout_prefix
#define dout_prefix *_dout << "librbd::ImageWriteback: " << __func__ << ": "
ImageCtx *image_ctx = util::get_image_ctx(&m_image_ctx);
auto aio_comp = io::AioCompletion::create_and_start(
on_finish, image_ctx, io::AIO_TYPE_READ);
- io::ImageReadRequest<> req(*image_ctx, aio_comp, std::move(image_extents),
- io::ReadResult{bl}, fadvise_flags, {});
- req.set_bypass_image_cache();
- req.send();
+ ZTracer::Trace trace;
+ auto req = io::ImageDispatchSpec::create_read(
+ *image_ctx, io::IMAGE_DISPATCH_LAYER_WRITEBACK_CACHE, aio_comp,
+ std::move(image_extents), io::ReadResult{bl},
+ image_ctx->get_data_io_context(),
+ fadvise_flags, 0, trace);
+ req->send();
}
template <typename I>
ImageCtx *image_ctx = util::get_image_ctx(&m_image_ctx);
auto aio_comp = io::AioCompletion::create_and_start(
on_finish, image_ctx, io::AIO_TYPE_WRITE);
- io::ImageWriteRequest<> req(*image_ctx, aio_comp, std::move(image_extents),
- std::move(bl), fadvise_flags, {});
- req.set_bypass_image_cache();
- req.send();
+ ZTracer::Trace trace;
+ auto req = io::ImageDispatchSpec::create_write(
+ *image_ctx, io::IMAGE_DISPATCH_LAYER_WRITEBACK_CACHE, aio_comp,
+ std::move(image_extents), std::move(bl),
+ image_ctx->get_data_io_context(), fadvise_flags, trace);
+ req->send();
}
template <typename I>
void ImageWriteback<I>::aio_discard(uint64_t offset, uint64_t length,
- uint32_t discard_granularity_bytes,
+ uint32_t discard_granularity_bytes,
Context *on_finish) {
CephContext *cct = m_image_ctx.cct;
ldout(cct, 20) << "offset=" << offset << ", "
ImageCtx *image_ctx = util::get_image_ctx(&m_image_ctx);
auto aio_comp = io::AioCompletion::create_and_start(
on_finish, image_ctx, io::AIO_TYPE_DISCARD);
- io::ImageDiscardRequest<> req(*image_ctx, aio_comp, {{offset, length}},
- discard_granularity_bytes, {});
- req.set_bypass_image_cache();
- req.send();
+ ZTracer::Trace trace;
+ auto req = io::ImageDispatchSpec::create_discard(
+ *image_ctx, io::IMAGE_DISPATCH_LAYER_WRITEBACK_CACHE, aio_comp, offset,
+ length, discard_granularity_bytes,
+ image_ctx->get_data_io_context(), trace);
+ req->send();
}
template <typename I>
-void ImageWriteback<I>::aio_flush(Context *on_finish) {
+void ImageWriteback<I>::aio_flush(io::FlushSource flush_source,
+ Context *on_finish) {
CephContext *cct = m_image_ctx.cct;
ldout(cct, 20) << "on_finish=" << on_finish << dendl;
ImageCtx *image_ctx = util::get_image_ctx(&m_image_ctx);
auto aio_comp = io::AioCompletion::create_and_start(
on_finish, image_ctx, io::AIO_TYPE_FLUSH);
- io::ImageFlushRequest<> req(*image_ctx, aio_comp, io::FLUSH_SOURCE_INTERNAL, {});
- req.set_bypass_image_cache();
- req.send();
+
+ ZTracer::Trace trace;
+ auto req = io::ImageDispatchSpec::create_flush(
+ *image_ctx, io::IMAGE_DISPATCH_LAYER_WRITEBACK_CACHE, aio_comp,
+ flush_source, trace);
+ req->send();
}
template <typename I>
ImageCtx *image_ctx = util::get_image_ctx(&m_image_ctx);
auto aio_comp = io::AioCompletion::create_and_start(
on_finish, image_ctx, io::AIO_TYPE_WRITESAME);
- io::ImageWriteSameRequest<> req(*image_ctx, aio_comp, {{offset, length}},
- std::move(bl), fadvise_flags, {});
- req.set_bypass_image_cache();
- req.send();
+ ZTracer::Trace trace;
+ auto req = io::ImageDispatchSpec::create_write_same(
+ *image_ctx, io::IMAGE_DISPATCH_LAYER_WRITEBACK_CACHE, aio_comp, offset,
+ length, std::move(bl), image_ctx->get_data_io_context(),
+ fadvise_flags, trace);
+ req->send();
}
template <typename I>
ImageCtx *image_ctx = util::get_image_ctx(&m_image_ctx);
auto aio_comp = io::AioCompletion::create_and_start(
on_finish, image_ctx, io::AIO_TYPE_COMPARE_AND_WRITE);
- io::ImageCompareAndWriteRequest<> req(*image_ctx, aio_comp,
- std::move(image_extents),
- std::move(cmp_bl), std::move(bl),
- mismatch_offset, fadvise_flags, {});
- req.set_bypass_image_cache();
- req.send();
+ ZTracer::Trace trace;
+ auto req = io::ImageDispatchSpec::create_compare_and_write(
+ *image_ctx, io::IMAGE_DISPATCH_LAYER_WRITEBACK_CACHE, aio_comp,
+ std::move(image_extents), std::move(cmp_bl), std::move(bl),
+ mismatch_offset, image_ctx->get_data_io_context(),
+ fadvise_flags, trace);
+ req->send();
}
} // namespace cache