bmalloc: Pathological madvise churn on the free(malloc(x)) benchmark
[WebKit-https.git] / Source / bmalloc / bmalloc / SegregatedFreeList.h
1 /*
2  * Copyright (C) 2014, 2015 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
24  */
25
26 #ifndef SegregatedFreeList_h
27 #define SegregatedFreeList_h
28
29 #include "FreeList.h"
30 #include <array>
31
32 namespace bmalloc {
33
34 class SegregatedFreeList {
35 public:
36     SegregatedFreeList(Owner);
37
38     void insert(const LargeObject&);
39
40     // Returns a reasonable fit for the provided size, or LargeObject() if no fit
41     // is found. May return LargeObject() spuriously if searching takes too long.
42     // Incrementally removes stale items from the free list while searching.
43     // Does not eagerly remove the returned object from the free list.
44     LargeObject take(size_t);
45
46     // Returns a reasonable fit for the provided alignment and size, or
47     // a reasonable fit for the provided unaligned size, or LargeObject() if no
48     // fit is found. May return LargeObject() spuriously if searching takes too
49     // long. Incrementally removes stale items from the free list while
50     // searching. Does not eagerly remove the returned object from the free list.
51     LargeObject take(size_t alignment, size_t, size_t unalignedSize);
52
53     // Returns an unreasonable fit for the provided size, or LargeObject() if no
54     // fit is found. Never returns LargeObject() spuriously. Incrementally
55     // removes stale items from the free list while searching. Eagerly removes
56     // the returned object from the free list.
57     LargeObject takeGreedy();
58
59 private:
60     FreeList& select(size_t);
61
62     Owner m_owner;
63     std::array<FreeList, 19> m_freeLists;
64 };
65
66 } // namespace bmalloc
67
68 #endif // SegregatedFreeList_h