diff options
author | Yabin Cui <yabinc@google.com> | 2016-05-24 18:23:33 -0700 |
---|---|---|
committer | Yabin Cui <yabinc@google.com> | 2016-05-24 20:01:26 -0700 |
commit | b64a86327afe2b77dab7d724d363386c674163b6 (patch) | |
tree | 02c9eeac321ed483d2b4272d5c9070b7ed10421b /simpleperf/SampleComparator.h | |
parent | d603e616b917c098bf6b050138e7b7ce6054c07e (diff) | |
download | extras-b64a86327afe2b77dab7d724d363386c674163b6.tar.gz |
simpleperf: refactor SampleTree for reuse.
By moving most function in report command into template classes, it
allows other report commands to reuse the code.
Bug: 27403614
Change-Id: I3d35b3a34d48c5c043ba4257a52eaf0961c12bca
Diffstat (limited to 'simpleperf/SampleComparator.h')
-rw-r--r-- | simpleperf/SampleComparator.h | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/simpleperf/SampleComparator.h b/simpleperf/SampleComparator.h new file mode 100644 index 00000000..8f9b2e4b --- /dev/null +++ b/simpleperf/SampleComparator.h @@ -0,0 +1,104 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef SIMPLE_PERF_SAMPLE_COMPARATOR_H_ +#define SIMPLE_PERF_SAMPLE_COMPARATOR_H_ + +#include <string.h> + +#include <vector> + +// The compare functions below are used to compare two samples by their item +// content. + +template <typename T> +int Compare(const T& a, const T& b) { + if (a != b) { + return a < b ? -1 : 1; + } + return 0; +} + +#define BUILD_COMPARE_VALUE_FUNCTION(function_name, compare_part) \ + template <typename EntryT> \ + int function_name(const EntryT* sample1, const EntryT* sample2) { \ + return Compare(sample1->compare_part, sample2->compare_part); \ + } + +#define BUILD_COMPARE_VALUE_FUNCTION_REVERSE(function_name, compare_part) \ + template <typename EntryT> \ + int function_name(const EntryT* sample1, const EntryT* sample2) { \ + return Compare(sample2->compare_part, sample1->compare_part); \ + } + +#define BUILD_COMPARE_STRING_FUNCTION(function_name, compare_part) \ + template <typename EntryT> \ + int function_name(const EntryT* sample1, const EntryT* sample2) { \ + return strcmp(sample1->compare_part, sample2->compare_part); \ + } + +BUILD_COMPARE_VALUE_FUNCTION(ComparePid, thread->pid); +BUILD_COMPARE_VALUE_FUNCTION(CompareTid, thread->tid); +BUILD_COMPARE_VALUE_FUNCTION_REVERSE(CompareSampleCount, sample_count); +BUILD_COMPARE_STRING_FUNCTION(CompareComm, thread_comm); +BUILD_COMPARE_STRING_FUNCTION(CompareDso, map->dso->Path().c_str()); +BUILD_COMPARE_STRING_FUNCTION(CompareSymbol, symbol->DemangledName()); +BUILD_COMPARE_STRING_FUNCTION(CompareDsoFrom, + branch_from.map->dso->Path().c_str()); +BUILD_COMPARE_STRING_FUNCTION(CompareSymbolFrom, + branch_from.symbol->DemangledName()); + +template <typename EntryT> +int CompareTotalPeriod(const EntryT* sample1, const EntryT* sample2) { + uint64_t period1 = sample1->period + sample1->accumulated_period; + uint64_t period2 = sample2->period + sample2->accumulated_period; + return Compare(period2, period1); +} + +// SampleComparator is a class using a collection of compare functions to +// compare two samples. + +template <typename EntryT> +class SampleComparator { + public: + typedef int (*compare_sample_func_t)(const EntryT*, const EntryT*); + + void AddCompareFunction(compare_sample_func_t func) { + compare_v_.push_back(func); + } + + void AddComparator(const SampleComparator<EntryT>& other) { + compare_v_.insert(compare_v_.end(), other.compare_v_.begin(), + other.compare_v_.end()); + } + + bool operator()(const EntryT* sample1, const EntryT* sample2) { + for (const auto& func : compare_v_) { + int ret = func(sample1, sample2); + if (ret != 0) { + return ret < 0; + } + } + return false; + } + + bool empty() const { return compare_v_.empty(); } + + private: + std::vector<compare_sample_func_t> compare_v_; +}; + +#endif // SIMPLE_PERF_SAMPLE_COMPARATOR_H_ |