1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2013 The Android Open Source Project 3*795d594fSAndroid Build Coastguard Worker * 4*795d594fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*795d594fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*795d594fSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*795d594fSAndroid Build Coastguard Worker * 8*795d594fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*795d594fSAndroid Build Coastguard Worker * 10*795d594fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*795d594fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*795d594fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*795d594fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*795d594fSAndroid Build Coastguard Worker * limitations under the License. 15*795d594fSAndroid Build Coastguard Worker */ 16*795d594fSAndroid Build Coastguard Worker 17*795d594fSAndroid Build Coastguard Worker #ifndef ART_COMPILER_UTILS_DEDUPE_SET_H_ 18*795d594fSAndroid Build Coastguard Worker #define ART_COMPILER_UTILS_DEDUPE_SET_H_ 19*795d594fSAndroid Build Coastguard Worker 20*795d594fSAndroid Build Coastguard Worker #include <stdint.h> 21*795d594fSAndroid Build Coastguard Worker #include <memory> 22*795d594fSAndroid Build Coastguard Worker #include <string> 23*795d594fSAndroid Build Coastguard Worker 24*795d594fSAndroid Build Coastguard Worker #include "base/macros.h" 25*795d594fSAndroid Build Coastguard Worker 26*795d594fSAndroid Build Coastguard Worker namespace art HIDDEN { 27*795d594fSAndroid Build Coastguard Worker 28*795d594fSAndroid Build Coastguard Worker class Thread; 29*795d594fSAndroid Build Coastguard Worker 30*795d594fSAndroid Build Coastguard Worker // A set of Keys that support a HashFunc returning HashType. Used to find duplicates of Key in the 31*795d594fSAndroid Build Coastguard Worker // Add method. The data-structure is thread-safe through the use of internal locks, it also 32*795d594fSAndroid Build Coastguard Worker // supports the lock being sharded. 33*795d594fSAndroid Build Coastguard Worker template <typename InKey, 34*795d594fSAndroid Build Coastguard Worker typename StoreKey, 35*795d594fSAndroid Build Coastguard Worker typename Alloc, 36*795d594fSAndroid Build Coastguard Worker typename HashType, 37*795d594fSAndroid Build Coastguard Worker typename HashFunc, 38*795d594fSAndroid Build Coastguard Worker HashType kShard = 1> 39*795d594fSAndroid Build Coastguard Worker class DedupeSet { 40*795d594fSAndroid Build Coastguard Worker public: 41*795d594fSAndroid Build Coastguard Worker // Add a new key to the dedupe set if not present. Return the equivalent deduplicated stored key. 42*795d594fSAndroid Build Coastguard Worker const StoreKey* Add(Thread* self, const InKey& key); 43*795d594fSAndroid Build Coastguard Worker 44*795d594fSAndroid Build Coastguard Worker DedupeSet(const char* set_name, const Alloc& alloc); 45*795d594fSAndroid Build Coastguard Worker 46*795d594fSAndroid Build Coastguard Worker ~DedupeSet(); 47*795d594fSAndroid Build Coastguard Worker 48*795d594fSAndroid Build Coastguard Worker size_t Size(Thread* self) const; 49*795d594fSAndroid Build Coastguard Worker 50*795d594fSAndroid Build Coastguard Worker std::string DumpStats(Thread* self) const; 51*795d594fSAndroid Build Coastguard Worker 52*795d594fSAndroid Build Coastguard Worker private: 53*795d594fSAndroid Build Coastguard Worker struct Stats; 54*795d594fSAndroid Build Coastguard Worker class Shard; 55*795d594fSAndroid Build Coastguard Worker 56*795d594fSAndroid Build Coastguard Worker std::unique_ptr<Shard> shards_[kShard]; 57*795d594fSAndroid Build Coastguard Worker uint64_t hash_time_; 58*795d594fSAndroid Build Coastguard Worker 59*795d594fSAndroid Build Coastguard Worker DISALLOW_COPY_AND_ASSIGN(DedupeSet); 60*795d594fSAndroid Build Coastguard Worker }; 61*795d594fSAndroid Build Coastguard Worker 62*795d594fSAndroid Build Coastguard Worker } // namespace art 63*795d594fSAndroid Build Coastguard Worker 64*795d594fSAndroid Build Coastguard Worker #endif // ART_COMPILER_UTILS_DEDUPE_SET_H_ 65