From ab9bd2430f0637ae5796cd3b2a0d28578d2fb4e7 Mon Sep 17 00:00:00 2001 From: Radoslaw Zarzynski Date: Sat, 3 Dec 2022 21:24:56 +0000 Subject: [PATCH] osd: fix intersecion of green threads and interuptible Signed-off-by: Radoslaw Zarzynski --- src/osd/SnapMapper.cc | 33 +++++++++++++++++++++++++++------ 1 file changed, 27 insertions(+), 6 deletions(-) diff --git a/src/osd/SnapMapper.cc b/src/osd/SnapMapper.cc index ff130b99700..dfa534e3ada 100644 --- a/src/osd/SnapMapper.cc +++ b/src/osd/SnapMapper.cc @@ -80,12 +80,24 @@ const char *SnapMapper::PURGED_SNAP_PREFIX = "PSN_"; */ #ifdef WITH_SEASTAR +#include "crimson/common/log.h" +#include "crimson/osd/pg_interval_interrupt_condition.h" + template + using interruptible_future = + ::crimson::interruptible::interruptible_future< + ::crimson::osd::IOInterruptCondition, ValuesT>; + using interruptor = + ::crimson::interruptible::interruptor< + ::crimson::osd::IOInterruptCondition>; + +#define CRIMSON_DEBUG(FMT_MSG, ...) crimson::get_logger(ceph_subsys_).debug(FMT_MSG, ##__VA_ARGS__) int OSDriver::get_keys( const std::set &keys, std::map *out) { + CRIMSON_DEBUG("OSDriver::{}:{}", __func__, __LINE__); using crimson::os::FuturizedStore; - return os->omap_get_values( + return interruptible_future{os->omap_get_values( ch, hoid, keys ).safe_then([out] (FuturizedStore::omap_values_t&& vals) { // just the difference in comparator (`std::less<>` in omap_values_t`) @@ -94,36 +106,44 @@ int OSDriver::get_keys( }, FuturizedStore::read_errorator::all_same_way([] (auto& e) { assert(e.value() > 0); return -e.value(); - })).get(); // this requires seastar::thread + }))}.get(); // this requires seastar::thread + CRIMSON_DEBUG("OSDriver::{}:{}", __func__, __LINE__); } int OSDriver::get_next( const std::string &key, std::pair *next) { + CRIMSON_DEBUG("OSDriver::{}:{}", __func__, __LINE__); using crimson::os::FuturizedStore; - return os->omap_get_values( + return interruptible_future{os->omap_get_values( ch, hoid, key ).safe_then_unpack([&key, next] (bool, FuturizedStore::omap_values_t&& vals) { + CRIMSON_DEBUG("OSDriver::{}:{}", "get_next", __LINE__); if (auto nit = std::begin(vals); nit == std::end(vals)) { + CRIMSON_DEBUG("OSDriver::{}:{}", "get_next", __LINE__); return -ENOENT; } else { + CRIMSON_DEBUG("OSDriver::{}:{}", "get_next", __LINE__); assert(nit->first > key); *next = *nit; return 0; } }, FuturizedStore::read_errorator::all_same_way([] { + CRIMSON_DEBUG("OSDriver::{}:{}", "get_next", __LINE__); return -EINVAL; - })).get(); // this requires seastar::thread + }))}.get(); // this requires seastar::thread + CRIMSON_DEBUG("OSDriver::{}:{}", __func__, __LINE__); } int OSDriver::get_next_or_current( const std::string &key, std::pair *next_or_current) { + CRIMSON_DEBUG("OSDriver::{}:{}", __func__, __LINE__); using crimson::os::FuturizedStore; // let's try to get current first - return os->omap_get_values( + return interruptible_future{os->omap_get_values( ch, hoid, FuturizedStore::omap_keys_t{key} ).safe_then([&key, next_or_current] (FuturizedStore::omap_values_t&& vals) { assert(vals.size() == 1); @@ -133,7 +153,8 @@ int OSDriver::get_next_or_current( [next_or_current, &key, this] { // no current, try next return get_next(key, next_or_current); - })).get(); // this requires seastar::thread + }))}.get(); // this requires seastar::thread + CRIMSON_DEBUG("OSDriver::{}:{}", __func__, __LINE__); } #else int OSDriver::get_keys(