blob: 138a5df77f7291deb3f0d6dd523e9e70608b137f [file] [log] [blame]
buzbee862a7602013-04-05 10:58:54 -07001/*
2 * Copyright (C) 2011 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Nicolas Geoffray0e336432014-02-26 18:24:38 +000017#include "arena_bit_vector.h"
buzbee862a7602013-04-05 10:58:54 -070018
David Sehr1979c642018-04-26 14:41:18 -070019#include "allocator.h"
20#include "arena_allocator.h"
Mathieu Chartierb666f482015-02-18 14:33:14 -080021
buzbee862a7602013-04-05 10:58:54 -070022namespace art {
23
Vladimir Markof6a35de2016-03-21 12:01:50 +000024template <bool kCount>
25class ArenaBitVectorAllocatorKindImpl;
26
27template <>
28class ArenaBitVectorAllocatorKindImpl<false> {
Brian Carlstrom413e89f2013-10-21 23:53:49 -070029 public:
Vladimir Markof6a35de2016-03-21 12:01:50 +000030 // Not tracking allocations, ignore the supplied kind and arbitrarily provide kArenaAllocSTL.
31 explicit ArenaBitVectorAllocatorKindImpl(ArenaAllocKind kind ATTRIBUTE_UNUSED) {}
32 ArenaBitVectorAllocatorKindImpl(const ArenaBitVectorAllocatorKindImpl&) = default;
33 ArenaBitVectorAllocatorKindImpl& operator=(const ArenaBitVectorAllocatorKindImpl&) = default;
34 ArenaAllocKind Kind() { return kArenaAllocGrowableBitMap; }
35};
36
37template <bool kCount>
38class ArenaBitVectorAllocatorKindImpl {
39 public:
40 explicit ArenaBitVectorAllocatorKindImpl(ArenaAllocKind kind) : kind_(kind) { }
41 ArenaBitVectorAllocatorKindImpl(const ArenaBitVectorAllocatorKindImpl&) = default;
42 ArenaBitVectorAllocatorKindImpl& operator=(const ArenaBitVectorAllocatorKindImpl&) = default;
43 ArenaAllocKind Kind() { return kind_; }
44
45 private:
46 ArenaAllocKind kind_;
47};
48
49using ArenaBitVectorAllocatorKind =
50 ArenaBitVectorAllocatorKindImpl<kArenaAllocatorCountAllocations>;
51
52template <typename ArenaAlloc>
Roland Levillainbbc6e7e2018-08-24 16:58:47 +010053class ArenaBitVectorAllocator final : public Allocator, private ArenaBitVectorAllocatorKind {
Vladimir Markof6a35de2016-03-21 12:01:50 +000054 public:
Vladimir Marko69d310e2017-10-09 14:12:23 +010055 static ArenaBitVectorAllocator* Create(ArenaAlloc* allocator, ArenaAllocKind kind) {
56 void* storage = allocator->template Alloc<ArenaBitVectorAllocator>(kind);
57 return new (storage) ArenaBitVectorAllocator(allocator, kind);
Vladimir Markof6a35de2016-03-21 12:01:50 +000058 }
59
60 ~ArenaBitVectorAllocator() {
61 LOG(FATAL) << "UNREACHABLE";
62 UNREACHABLE();
63 }
Brian Carlstrom413e89f2013-10-21 23:53:49 -070064
Andreas Gampefa6a1b02018-09-07 08:11:55 -070065 void* Alloc(size_t size) override {
Vladimir Marko69d310e2017-10-09 14:12:23 +010066 return allocator_->Alloc(size, this->Kind());
Brian Carlstrom413e89f2013-10-21 23:53:49 -070067 }
68
Andreas Gampefa6a1b02018-09-07 08:11:55 -070069 void Free(void*) override {} // Nop.
Brian Carlstrom413e89f2013-10-21 23:53:49 -070070
Brian Carlstrom413e89f2013-10-21 23:53:49 -070071 private:
Vladimir Marko69d310e2017-10-09 14:12:23 +010072 ArenaBitVectorAllocator(ArenaAlloc* allocator, ArenaAllocKind kind)
73 : ArenaBitVectorAllocatorKind(kind), allocator_(allocator) { }
Vladimir Markof6a35de2016-03-21 12:01:50 +000074
Vladimir Marko69d310e2017-10-09 14:12:23 +010075 ArenaAlloc* const allocator_;
Vladimir Markof6a35de2016-03-21 12:01:50 +000076
Brian Carlstrom413e89f2013-10-21 23:53:49 -070077 DISALLOW_COPY_AND_ASSIGN(ArenaBitVectorAllocator);
78};
buzbee862a7602013-04-05 10:58:54 -070079
Vladimir Marko69d310e2017-10-09 14:12:23 +010080ArenaBitVector::ArenaBitVector(ArenaAllocator* allocator,
Vladimir Markof6a35de2016-03-21 12:01:50 +000081 unsigned int start_bits,
82 bool expandable,
83 ArenaAllocKind kind)
84 : BitVector(start_bits,
85 expandable,
Vladimir Marko69d310e2017-10-09 14:12:23 +010086 ArenaBitVectorAllocator<ArenaAllocator>::Create(allocator, kind)) {
Vladimir Markobfea9c22014-01-17 17:49:33 +000087}
88
Vladimir Marko69d310e2017-10-09 14:12:23 +010089ArenaBitVector::ArenaBitVector(ScopedArenaAllocator* allocator,
Vladimir Markof6a35de2016-03-21 12:01:50 +000090 unsigned int start_bits,
91 bool expandable,
92 ArenaAllocKind kind)
93 : BitVector(start_bits,
94 expandable,
Vladimir Marko69d310e2017-10-09 14:12:23 +010095 ArenaBitVectorAllocator<ScopedArenaAllocator>::Create(allocator, kind)) {
Ian Rogersb48b9eb2014-02-28 16:20:21 -080096}
buzbee862a7602013-04-05 10:58:54 -070097
buzbee862a7602013-04-05 10:58:54 -070098} // namespace art