.. index:: pair: MVFF pool class; design single: pool class; MVFF design .. _design-poolmvff: MVFF pool class =============== .. mps:prefix:: design.mps.poolmvff pair: MVFF pool class; design single: pool class; MVFF design Introduction ------------ :mps:tag:`intro` This is the design of the MVFF (Manual Variable First-Fit) pool class. This pool implements a first (or last) fit policy for variable-sized manually-managed objects, with control over first/last, segment preference high/low, and slot fit low/high. The pool was created in a response to a belief that the ScriptWorks EPDL/EPDR's first fit policy is beneficial for some classes of client behaviour, but the performance of a linear free list was unacceptable. Overview -------- :mps:tag:`over` This pool implements certain variants of the address-ordered first-fit policy. The implementation allows allocation across segment boundaries. :mps:tag:`over.buffer` Buffered allocation is also supported, but in that case, the buffer-filling policy is worst-fit. Buffered and unbuffered allocation can be used at the same time, but in that case, the first ap must be created before any allocations. :mps:tag:`over.buffer.class` The pool uses the simplest buffer class, :c:type:`BufferClass`. This is appropriate since these buffers don't attach to segments, and hence don't constrain buffered regions to lie within segment boundaries. Methods ------- :mps:tag:`method.buffer` The buffer methods implement a worst-fit fill strategy. Implementation -------------- :mps:tag:`impl.alloc_list` The pool stores the address ranges that it has acquired from the arena in a CBS (see design.mps.cbs_). :mps:tag:`impl.free-list` The pool stores its free list in a CBS (see design.mps.cbs_), failing over in emergencies to a Freelist (see design.mps.freelist_) when the CBS cannot allocate new control structures. This is the reason for the alignment restriction above. .. _design.mps.cbs: cbs .. _design.mps.freelist: freelist Details ------- :mps:tag:`design.acquire-size` When acquiring memory from the arena, we use ``extendBy`` as the unit of allocation unless the object won't fit, in which case we use the object size (in both cases we align up to the arena alignment). :mps:tag:`design.acquire-fail` If allocating ``extendBy``, we try again with an aligned size just large enough for the object we're allocating. This is in response to request.mps.170186_. .. _request.mps.170186: https://info.ravenbrook.com/project/mps/import/2001-11-05/mmprevol/request/mps/170186