xref: /llvm-project/compiler-rt/lib/tsan/tests/unit/tsan_dense_alloc_test.cpp (revision aff73487c986b519aac1e0b7fee6d7bef72e4002)
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 Weber TEST(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