5#include "core/fxcrt/fx_memory.h"
10#include "build/build_config.h"
11#include "core/fxcrt/compiler_specific.h"
12#include "testing/gtest/include/gtest/gtest.h"
14#if defined(PDF_USE_PARTITION_ALLOC)
15#include "partition_alloc/partition_address_space.h"
20constexpr size_t kMaxByteAlloc = std::numeric_limits<size_t>::max();
21constexpr size_t kMaxIntAlloc = kMaxByteAlloc /
sizeof(
int);
22constexpr size_t kOverflowIntAlloc = kMaxIntAlloc + 100;
23constexpr size_t kWidth = 640;
24constexpr size_t kOverflowIntAlloc2D = kMaxIntAlloc / kWidth + 10;
25constexpr size_t kCloseToMaxIntAlloc = kMaxIntAlloc - 100;
26constexpr size_t kCloseToMaxByteAlloc = kMaxByteAlloc - 100;
31 uint8_t* ptr = FX_Alloc(uint8_t, 0);
32 uint8_t* ptr2 = FX_Alloc(uint8_t, 0);
40 EXPECT_DEATH_IF_SUPPORTED((
void)FX_Alloc(
int, kCloseToMaxIntAlloc),
"");
42 int* ptr = FX_Alloc(
int, 1);
44 EXPECT_DEATH_IF_SUPPORTED((
void)FX_Realloc(
int, ptr, kCloseToMaxIntAlloc),
53 EXPECT_DEATH_IF_SUPPORTED(ptr = FX_Alloc(
int, kOverflowIntAlloc),
"") << ptr;
55 ptr = FX_Alloc(
int, 1);
57 EXPECT_DEATH_IF_SUPPORTED((
void)FX_Realloc(
int, ptr, kOverflowIntAlloc),
"");
65 EXPECT_DEATH_IF_SUPPORTED(ptr = FX_Alloc2D(
int, kWidth, kOverflowIntAlloc2D),
71 EXPECT_FALSE(FX_TryAlloc(
int, kCloseToMaxIntAlloc));
73 int* ptr = FX_Alloc(
int, 1);
75 EXPECT_FALSE(FX_TryRealloc(
int, ptr, kCloseToMaxIntAlloc));
80 int* ptr = FX_TryAllocUninit(
int, 4);
84 ptr = FX_TryAllocUninit2D(
int, 4, 4);
90 EXPECT_FALSE(FX_TryAllocUninit(
int, kCloseToMaxIntAlloc));
91 EXPECT_FALSE(FX_TryAllocUninit2D(
int, kWidth, kOverflowIntAlloc2D));
94#if !defined(COMPILER_GCC)
98 int* ptr = (
int*)calloc(
sizeof(
int), kOverflowIntAlloc);
99 EXPECT_FALSE(ptr) << ptr;
101 ptr = FX_Alloc(
int, 1);
104 EXPECT_FALSE(FX_TryRealloc(
int, ptr, kOverflowIntAlloc));
105 EXPECT_EQ(1492, *ptr);
111 EXPECT_FALSE(FXMEM_DefaultAlloc(kCloseToMaxByteAlloc));
113 void* ptr = FXMEM_DefaultAlloc(1);
115 EXPECT_FALSE(FXMEM_DefaultRealloc(ptr, kCloseToMaxByteAlloc));
120 uint8_t* ptr = FX_Alloc(uint8_t, 32);
122 for (size_t i = 0; i < 32; ++i) {
130 static_assert(std::numeric_limits<size_t>::max() % 2 == 1,
131 "numeric limit must be odd for this test");
136 size_t sbig = std::numeric_limits<size_t>::max() - 2;
137 EXPECT_EQ(0u, FxAlignToBoundary<2>(s0));
138 EXPECT_EQ(2u, FxAlignToBoundary<2>(s1));
139 EXPECT_EQ(2u, FxAlignToBoundary<2>(s2));
140 EXPECT_EQ(std::numeric_limits<size_t>::max() - 1, FxAlignToBoundary<2>(sbig));
146 EXPECT_EQ(0, FxAlignToBoundary<512>(i0));
147 EXPECT_EQ(512, FxAlignToBoundary<512>(i511));
148 EXPECT_EQ(512, FxAlignToBoundary<512>(i512));
149 EXPECT_EQ(-512, FxAlignToBoundary<512>(ineg));
152#if defined(PDF_USE_PARTITION_ALLOC)
153#if PA_BUILDFLAG(USE_PARTITION_ALLOC_AS_MALLOC) &&
154 PA_BUILDFLAG(HAS_64_BIT_POINTERS)
155TEST(FxMemory, NewOperatorResultIsPA) {
156 auto obj = std::make_unique<
double>(4.0);
157 EXPECT_TRUE(partition_alloc::IsManagedByPartitionAlloc(
158 reinterpret_cast<uintptr_t>(obj.get())));
159#if PA_BUILDFLAG(ENABLE_BACKUP_REF_PTR_SUPPORT)
160 EXPECT_TRUE(partition_alloc::IsManagedByPartitionAllocBRPPool(
161 reinterpret_cast<uintptr_t>(obj.get())));
165TEST(FxMemory, MallocResultIsPA) {
166 void* obj = malloc(16);
167 EXPECT_TRUE(partition_alloc::IsManagedByPartitionAlloc(
168 reinterpret_cast<uintptr_t>(obj)));
169#if PA_BUILDFLAG(ENABLE_BACKUP_REF_PTR_SUPPORT)
170 EXPECT_TRUE(partition_alloc::IsManagedByPartitionAllocBRPPool(
171 reinterpret_cast<uintptr_t>(obj)));
176TEST(FxMemory, StackObjectIsNotPA) {
178 EXPECT_FALSE(partition_alloc::IsManagedByPartitionAlloc(
179 reinterpret_cast<uintptr_t>(&x)));
180#if PA_BUILDFLAG(ENABLE_BACKUP_REF_PTR_SUPPORT)
181 EXPECT_FALSE(partition_alloc::IsManagedByPartitionAllocBRPPool(
182 reinterpret_cast<uintptr_t>(&x)));
#define UNSAFE_BUFFERS(...)
TEST(FXCRYPT, MD5GenerateEmtpyData)
void FXMEM_DefaultFree(void *pointer)