1 // Copyright 2020 The Pigweed Authors
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4 // use this file except in compliance with the License. You may obtain a copy of
5 // the License at
6 //
7 // https://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11 // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12 // License for the specific language governing permissions and limitations under
13 // the License.
14
15 #include "pw_malloc_freelist/freelist_malloc.h"
16
17 #include <memory>
18 #include <span>
19
20 #include "gtest/gtest.h"
21 #include "pw_allocator/freelist_heap.h"
22
23 namespace pw::allocator {
24
TEST(FreeListMalloc,ReplacingMalloc)25 TEST(FreeListMalloc, ReplacingMalloc) {
26 constexpr size_t kAllocSize = 256;
27 constexpr size_t kReallocSize = 512;
28 constexpr size_t kCallocNum = 4;
29 constexpr size_t kCallocSize = 64;
30 constexpr size_t zero = 0;
31
32 auto deleter = [](void* ptr) { free(ptr); };
33
34 std::unique_ptr<void, decltype(deleter)> ptr1(malloc(kAllocSize), deleter);
35 const FreeListHeap::HeapStats& freelist_heap_stats =
36 pw_freelist_heap->heap_stats();
37 ASSERT_NE(ptr1.get(), nullptr);
38 EXPECT_EQ(freelist_heap_stats.bytes_allocated, kAllocSize);
39 EXPECT_EQ(freelist_heap_stats.cumulative_allocated, kAllocSize);
40 EXPECT_EQ(freelist_heap_stats.cumulative_freed, zero);
41
42 std::unique_ptr<void, decltype(deleter)> ptr2(
43 realloc(ptr1.release(), kReallocSize), deleter);
44 ASSERT_NE(ptr2.get(), nullptr);
45 EXPECT_EQ(freelist_heap_stats.bytes_allocated, kReallocSize);
46 EXPECT_EQ(freelist_heap_stats.cumulative_allocated,
47 kAllocSize + kReallocSize);
48 EXPECT_EQ(freelist_heap_stats.cumulative_freed, kAllocSize);
49
50 std::unique_ptr<void, decltype(deleter)> ptr3(calloc(kCallocNum, kCallocSize),
51 deleter);
52 ASSERT_NE(ptr3.get(), nullptr);
53 EXPECT_EQ(freelist_heap_stats.bytes_allocated,
54 kReallocSize + kCallocNum * kCallocSize);
55 EXPECT_EQ(freelist_heap_stats.cumulative_allocated,
56 kAllocSize + kReallocSize + kCallocNum * kCallocSize);
57 EXPECT_EQ(freelist_heap_stats.cumulative_freed, kAllocSize);
58 free(ptr2.release());
59 EXPECT_EQ(freelist_heap_stats.bytes_allocated, kCallocNum * kCallocSize);
60 EXPECT_EQ(freelist_heap_stats.cumulative_allocated,
61 kAllocSize + kReallocSize + kCallocNum * kCallocSize);
62 EXPECT_EQ(freelist_heap_stats.cumulative_freed, kAllocSize + kReallocSize);
63 free(ptr3.release());
64 EXPECT_EQ(freelist_heap_stats.bytes_allocated, zero);
65 EXPECT_EQ(freelist_heap_stats.cumulative_allocated,
66 kAllocSize + kReallocSize + kCallocNum * kCallocSize);
67 EXPECT_EQ(freelist_heap_stats.cumulative_freed,
68 kAllocSize + kReallocSize + kCallocNum * kCallocSize);
69 }
70
71 } // namespace pw::allocator
72