/* * Copyright (C) 2015-present ScyllaDB */ /* * SPDX-License-Identifier: AGPL-3.0-or-later */ #include "large_bitset.hh" #include #include #include #include "seastarx.hh" using namespace seastar; large_bitset::large_bitset(size_t nr_bits) : _nr_bits(nr_bits) { assert(thread::running_in_thread()); const size_t orig_nr_ints = align_up(nr_bits, bits_per_int()) / bits_per_int(); auto nr_ints = orig_nr_ints; while (nr_ints) { nr_ints = _storage.reserve_partial(nr_ints); if (need_preempt()) { thread::yield(); } } nr_ints = orig_nr_ints; while (nr_ints) { _storage.push_back(0); --nr_ints; if (need_preempt()) { thread::yield(); } } } void large_bitset::clear() { assert(thread::running_in_thread()); for (auto&& pos: _storage) { pos = 0; if (need_preempt()) { thread::yield(); } } }