2019-08-02 01:53:25 +08:00
|
|
|
//===-- basic.cpp -----------------------------------------------*- C++ -*-===//
|
[GWP-ASan] Core Guarded Pool Allocator [4].
Summary:
See D60593 for further information.
This patch introduces the core of GWP-ASan, being the guarded pool allocator. This class contains the logic for creating and maintaining allocations in the guarded pool. Its public interface is to be utilised by supporting allocators in order to provide sampled guarded allocation behaviour.
This patch also contains basic functionality tests of the allocator as unittests. The error-catching behaviour will be tested in upcoming patches that use Scudo as an implementing allocator.
Reviewers: vlad.tsyrklevich, eugenis, jfb
Reviewed By: vlad.tsyrklevich
Subscribers: dexonsmith, kubamracek, mgorny, cryptoad, jfb, #sanitizers, llvm-commits, morehouse
Tags: #sanitizers, #llvm
Differential Revision: https://reviews.llvm.org/D62872
llvm-svn: 362636
2019-06-06 03:42:48 +08:00
|
|
|
//
|
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "gwp_asan/tests/harness.h"
|
|
|
|
|
|
|
|
TEST_F(CustomGuardedPoolAllocator, BasicAllocation) {
|
|
|
|
InitNumSlots(1);
|
|
|
|
void *Ptr = GPA.allocate(1);
|
|
|
|
EXPECT_NE(nullptr, Ptr);
|
|
|
|
EXPECT_TRUE(GPA.pointerIsMine(Ptr));
|
|
|
|
EXPECT_EQ(1u, GPA.getSize(Ptr));
|
|
|
|
GPA.deallocate(Ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(DefaultGuardedPoolAllocator, NullptrIsNotMine) {
|
|
|
|
EXPECT_FALSE(GPA.pointerIsMine(nullptr));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CustomGuardedPoolAllocator, SizedAllocations) {
|
|
|
|
InitNumSlots(1);
|
|
|
|
|
|
|
|
std::size_t MaxAllocSize = GPA.maximumAllocationSize();
|
|
|
|
EXPECT_TRUE(MaxAllocSize > 0);
|
|
|
|
|
|
|
|
for (unsigned AllocSize = 1; AllocSize <= MaxAllocSize; AllocSize <<= 1) {
|
|
|
|
void *Ptr = GPA.allocate(AllocSize);
|
|
|
|
EXPECT_NE(nullptr, Ptr);
|
|
|
|
EXPECT_TRUE(GPA.pointerIsMine(Ptr));
|
|
|
|
EXPECT_EQ(AllocSize, GPA.getSize(Ptr));
|
|
|
|
GPA.deallocate(Ptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(DefaultGuardedPoolAllocator, TooLargeAllocation) {
|
|
|
|
EXPECT_EQ(nullptr, GPA.allocate(GPA.maximumAllocationSize() + 1));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CustomGuardedPoolAllocator, AllocAllSlots) {
|
|
|
|
constexpr unsigned kNumSlots = 128;
|
|
|
|
InitNumSlots(kNumSlots);
|
|
|
|
void *Ptrs[kNumSlots];
|
|
|
|
for (unsigned i = 0; i < kNumSlots; ++i) {
|
|
|
|
Ptrs[i] = GPA.allocate(1);
|
|
|
|
EXPECT_NE(nullptr, Ptrs[i]);
|
|
|
|
EXPECT_TRUE(GPA.pointerIsMine(Ptrs[i]));
|
|
|
|
}
|
|
|
|
|
|
|
|
// This allocation should fail as all the slots are used.
|
|
|
|
void *Ptr = GPA.allocate(1);
|
|
|
|
EXPECT_EQ(nullptr, Ptr);
|
|
|
|
EXPECT_FALSE(GPA.pointerIsMine(nullptr));
|
|
|
|
|
|
|
|
for (unsigned i = 0; i < kNumSlots; ++i)
|
|
|
|
GPA.deallocate(Ptrs[i]);
|
|
|
|
}
|