xo-alloc2: + Allocator.expand() + streamlining _Any
This commit is contained in:
parent
e0dd9d2a1c
commit
12ade26a79
8 changed files with 167 additions and 18 deletions
|
|
@ -59,6 +59,11 @@ namespace xo {
|
|||
**/
|
||||
virtual bool contains(Copaque d, const void * p) const = 0;
|
||||
|
||||
/** expand committed space in arena @p d
|
||||
* to size at least @p z
|
||||
* In practice will round up to a multiple of hugepage size (2MB)
|
||||
**/
|
||||
virtual bool expand(Opaque d, std::size_t z) const = 0;
|
||||
/** allocate @p z bytes of memory from allocator @p d. **/
|
||||
virtual std::byte * alloc(Opaque d, std::size_t z) const = 0;
|
||||
/** reset allocator @p d to empty state **/
|
||||
|
|
|
|||
|
|
@ -21,22 +21,30 @@ namespace xo {
|
|||
}
|
||||
|
||||
namespace mm {
|
||||
/** @class IAllocator_Any
|
||||
* @brief Allocator implementation for variant instance.
|
||||
**/
|
||||
struct IAllocator_Any : public AAllocator {
|
||||
//using Impl = IAllocator_ImplType<xo::facet::DVariantPlaceholder>;
|
||||
|
||||
// from AAllocator
|
||||
int32_t _typeseq() const override { return s_typeseq; }
|
||||
|
||||
const std::string & name(Copaque) const override { assert(false); static std::string * x; return *x; }
|
||||
std::size_t reserved(Copaque) const override { assert(false); return 0ul; }
|
||||
std::size_t size(Copaque) const override { assert(false); return 0ul; }
|
||||
std::size_t committed(Copaque) const override { assert(false); return 0ul; }
|
||||
bool contains(Copaque, const void *) const override { assert(false); return false; }
|
||||
[[noreturn]] const std::string & name(Copaque) const override { _fatal(); }
|
||||
[[noreturn]] std::size_t reserved(Copaque) const override { _fatal(); }
|
||||
[[noreturn]] std::size_t size(Copaque) const override { _fatal(); }
|
||||
[[noreturn]] std::size_t committed(Copaque) const override { _fatal(); }
|
||||
[[noreturn]] bool contains(Copaque, const void *) const override { _fatal(); }
|
||||
|
||||
std::byte * alloc(Opaque, std::size_t) const override { assert(false); return nullptr; }
|
||||
void clear(Opaque) const override { assert(false); }
|
||||
void destruct_data(Opaque) const override { assert(false); }
|
||||
[[noreturn]] bool expand(Opaque, std::size_t) const override { _fatal(); }
|
||||
[[noreturn]] std::byte * alloc(Opaque, std::size_t) const override { _fatal(); }
|
||||
[[noreturn]] void clear(Opaque) const override { _fatal(); }
|
||||
[[noreturn]] void destruct_data(Opaque) const override { _fatal(); }
|
||||
|
||||
private:
|
||||
[[noreturn]] static void _fatal();
|
||||
|
||||
public:
|
||||
static int32_t s_typeseq;
|
||||
static bool _valid;
|
||||
};
|
||||
|
|
|
|||
|
|
@ -21,12 +21,25 @@ namespace xo {
|
|||
}
|
||||
|
||||
namespace mm {
|
||||
/* changes here coordinate with:
|
||||
* AAllocator AAllocator.hpp
|
||||
* IAllocator_Any IAllocator_Any.hpp
|
||||
* IAllocator_Xfer IAllocator_Xfer.hpp
|
||||
* RAllocator RAllocator.hpp
|
||||
*/
|
||||
struct IAllocator_DArena {
|
||||
static const std::string & name(const DArena &);
|
||||
static std::size_t reserved(const DArena &);
|
||||
static std::size_t size(const DArena &);
|
||||
static std::size_t committed(const DArena &);
|
||||
static bool contains(const DArena &, const void * p);
|
||||
|
||||
/** expand committed space in arena @p d
|
||||
* to size at least @p z
|
||||
* In practice will round up to a multiple of @ref page_z_.
|
||||
**/
|
||||
static bool expand(DArena & d, std::size_t z);
|
||||
|
||||
static std::byte * alloc(const DArena &, std::size_t z);
|
||||
static void clear(DArena &);
|
||||
static void destruct_data(DArena &);
|
||||
|
|
|
|||
|
|
@ -10,6 +10,9 @@
|
|||
namespace xo {
|
||||
namespace mm {
|
||||
/** @class IAllocator_Xfer
|
||||
*
|
||||
* Adapts typed allocator implementation @tparam IAllocator_DRepr
|
||||
* to type-erased @ref AAllocator interface
|
||||
**/
|
||||
template <typename DRepr, typename IAllocator_DRepr>
|
||||
struct IAllocator_Xfer : public AAllocator {
|
||||
|
|
@ -17,18 +20,38 @@ namespace xo {
|
|||
using Impl = IAllocator_DRepr;
|
||||
|
||||
static const DRepr & _dcast(Copaque d) { return *(const DRepr *)d; }
|
||||
static DRepr & _dcast(Opaque d) { return *(DRepr *)d; }
|
||||
|
||||
// from AAllocator
|
||||
int32_t _typeseq() const override { return s_typeseq; }
|
||||
const std::string & name(Copaque d) const override { return Impl::name(_dcast(d)); }
|
||||
std::size_t reserved(Copaque d) const override { return Impl::reserved(*(DRepr*)d); }
|
||||
std::size_t size(Copaque d) const override { return Impl::size(*(DRepr*)d); }
|
||||
std::size_t committed(Copaque d) const override { return Impl::committed(*(DRepr*)d); }
|
||||
bool contains(Copaque d, const void * p) const override { return Impl::contains(*(DRepr*)d, p); }
|
||||
const std::string & name(Copaque d) const override {
|
||||
return Impl::name(_dcast(d));
|
||||
}
|
||||
std::size_t reserved(Copaque d) const override {
|
||||
return Impl::reserved(_dcast(d));
|
||||
}
|
||||
std::size_t size(Copaque d) const override {
|
||||
return Impl::size(_dcast(d));
|
||||
}
|
||||
std::size_t committed(Copaque d) const override {
|
||||
return Impl::committed(_dcast(d));
|
||||
}
|
||||
bool contains(Copaque d, const void * p) const override {
|
||||
return Impl::contains(_dcast(d), p);
|
||||
}
|
||||
|
||||
std::byte * alloc(Opaque d, std::size_t z) const override { return Impl::alloc(*(DRepr*)d, z); }
|
||||
void clear(Opaque d) const override { return Impl::clear(*(DRepr*)d); }
|
||||
void destruct_data(Opaque d) const override { return Impl::destruct_data(*(DRepr*)d); }
|
||||
bool expand(Opaque d, std::size_t z) const override {
|
||||
return Impl::expand(_dcast(d), z);
|
||||
}
|
||||
std::byte * alloc(Opaque d, std::size_t z) const override {
|
||||
return Impl::alloc(*(DRepr*)d, z);
|
||||
}
|
||||
void clear(Opaque d) const override {
|
||||
return Impl::clear(*(DRepr*)d);
|
||||
}
|
||||
void destruct_data(Opaque d) const override {
|
||||
return Impl::destruct_data(*(DRepr*)d);
|
||||
}
|
||||
|
||||
static int32_t s_typeseq;
|
||||
static bool _valid;
|
||||
|
|
|
|||
|
|
@ -28,6 +28,7 @@ namespace xo {
|
|||
size_type size() const { return O::iface()->size(O::data()); }
|
||||
size_type committed() const { return O::iface()->committed(O::data()); }
|
||||
bool contains(const void * p) const { return O::iface()->contains(O::data(), p); }
|
||||
bool expand(size_type z) { return O::iface()->expand(O::data(), z); }
|
||||
std::byte * alloc(size_type z) { return O::iface()->alloc(O::data(), z); }
|
||||
|
||||
static bool _valid;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue