> > +void mem_pool_combine(struct mem_pool *dst, struct mem_pool *src) {
> > +   struct mp_block *p;
> > +
> > +   /* Append the blocks from src to dst */
> > +   if (dst->mp_block && src->mp_block) {
> > +           /*
> > +            * src and dst have blocks, append
> > +            * blocks from src to dst.
> > +            */
> > +           p = dst->mp_block;
> > +           while (p->next_block)
> > +                   p = p->next_block;
> > +
> > +           p->next_block = src->mp_block;
> 
> Just being curious, but does this interact with the "we carve out only from 
> the
> first block" done in step 4/8?  The remaining unused space in the first block 
> in
> the src pool would be wasted, which may not be such a big deal and may not
> even be worth comparing the available space in two blocks and picking a larger
> one.  But we do want to decide _after_ thinking things through nevertheless.

Good question - and this is something I had thought about.

In the context of current usage, this function is currently not
used frequently. It is only used in split index with
move_cache_to_base_index and remove_split_index. In either case,
the cache_entries should already be loaded into memory, and I
don't expect a big enough difference in the amount of left over
space to make a meaningful difference.

In the general case I could see this being a bigger case.

For now, I thought the logic as is was an appropriate tradeoff. I
don't think it would be complicated to do something smarter here,
but I also didn't see much benefit in current usage. If we prefer
something else here, I can update this logic.

Reply via email to