// Copyright 2015 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef BASE_TRACE_EVENT_PROCESS_MEMORY_TOTALS_H_ #define BASE_TRACE_EVENT_PROCESS_MEMORY_TOTALS_H_ #include <stdint.h> #include <map> #include "base/base_export.h" #include "base/macros.h" namespace base { namespace trace_event { class TracedValue; // Data model for process-wide memory stats. class BASE_EXPORT ProcessMemoryTotals { public: ProcessMemoryTotals(); ~ProcessMemoryTotals(); // Called at trace generation time to populate the TracedValue. void AsValueInto(TracedValue* value) const; // Clears up all the data collected. void Clear(); uint64_t resident_set_bytes() const { return resident_set_bytes_; } void set_resident_set_bytes(uint64_t value) { resident_set_bytes_ = value; } uint64_t peak_resident_set_bytes() const { return peak_resident_set_bytes_; } void set_peak_resident_set_bytes(uint64_t value) { peak_resident_set_bytes_ = value; } // On some platforms (recent linux kernels, see goo.gl/sMvAVz) the peak rss // can be reset. When is_peak_rss_resettable == true, the peak refers to // peak from the previous measurement. When false, it is the absolute peak // since the start of the process. bool is_peak_rss_resetable() const { return is_peak_rss_resetable_; } void set_is_peak_rss_resetable(bool value) { is_peak_rss_resetable_ = value; } void SetExtraFieldInBytes(const char* name, uint64_t value); private: uint64_t resident_set_bytes_; uint64_t peak_resident_set_bytes_; bool is_peak_rss_resetable_; // Extra metrics for OS-specific statistics. std::map<const char*, uint64_t> extra_fields_; DISALLOW_COPY_AND_ASSIGN(ProcessMemoryTotals); }; } // namespace trace_event } // namespace base #endif // BASE_TRACE_EVENT_PROCESS_MEMORY_TOTALS_H_