15de29a4bSNico Weber //===-- tsan_dense_alloc_test.cpp -----------------------------------------===// 25de29a4bSNico Weber // 35de29a4bSNico Weber // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 45de29a4bSNico Weber // See https://llvm.org/LICENSE.txt for license information. 55de29a4bSNico Weber // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 65de29a4bSNico Weber // 75de29a4bSNico Weber //===----------------------------------------------------------------------===// 85de29a4bSNico Weber // 95de29a4bSNico Weber // This file is a part of ThreadSanitizer (TSan), a race detector. 105de29a4bSNico Weber // 115de29a4bSNico Weber //===----------------------------------------------------------------------===// 125de29a4bSNico Weber #include "tsan_dense_alloc.h" 135de29a4bSNico Weber #include "tsan_rtl.h" 145de29a4bSNico Weber #include "tsan_mman.h" 155de29a4bSNico Weber #include "gtest/gtest.h" 165de29a4bSNico Weber 175de29a4bSNico Weber #include <stdlib.h> 185de29a4bSNico Weber #include <stdint.h> 195de29a4bSNico Weber #include <map> 205de29a4bSNico Weber 215de29a4bSNico Weber namespace __tsan { 225de29a4bSNico Weber TEST(DenseSlabAlloc,Basic)235de29a4bSNico WeberTEST(DenseSlabAlloc, Basic) { 24*aff73487SDmitry Vyukov typedef u64 T; 25*aff73487SDmitry Vyukov typedef DenseSlabAlloc<T, 128, 128> Alloc; 265de29a4bSNico Weber typedef Alloc::Cache Cache; 275de29a4bSNico Weber typedef Alloc::IndexT IndexT; 28*aff73487SDmitry Vyukov const T N = 1000; 295de29a4bSNico Weber 30*aff73487SDmitry Vyukov Alloc alloc("test"); 315de29a4bSNico Weber Cache cache; 325de29a4bSNico Weber alloc.InitCache(&cache); 335de29a4bSNico Weber 345de29a4bSNico Weber IndexT blocks[N]; 355de29a4bSNico Weber for (int ntry = 0; ntry < 3; ntry++) { 36*aff73487SDmitry Vyukov for (T i = 0; i < N; i++) { 375de29a4bSNico Weber IndexT idx = alloc.Alloc(&cache); 385de29a4bSNico Weber blocks[i] = idx; 395de29a4bSNico Weber EXPECT_NE(idx, 0U); 40*aff73487SDmitry Vyukov T *v = alloc.Map(idx); 415de29a4bSNico Weber *v = i; 425de29a4bSNico Weber } 435de29a4bSNico Weber 44*aff73487SDmitry Vyukov for (T i = 0; i < N; i++) { 455de29a4bSNico Weber IndexT idx = blocks[i]; 46*aff73487SDmitry Vyukov T *v = alloc.Map(idx); 475de29a4bSNico Weber EXPECT_EQ(*v, i); 485de29a4bSNico Weber alloc.Free(&cache, idx); 495de29a4bSNico Weber } 505de29a4bSNico Weber 515de29a4bSNico Weber alloc.FlushCache(&cache); 525de29a4bSNico Weber } 535de29a4bSNico Weber } 545de29a4bSNico Weber 555de29a4bSNico Weber } // namespace __tsan 56