blob: 79c4673830a74fc29305111cede729262550e177 [file] [log] [blame]
// Copyright (c) 2012 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 NET_DISK_CACHE_BLOCKFILE_STATS_H_
#define NET_DISK_CACHE_BLOCKFILE_STATS_H_
#include <string>
#include "base/macros.h"
#include "base/strings/string_split.h"
#include "net/base/net_export.h"
#include "net/disk_cache/blockfile/addr.h"
#include "starboard/types.h"
namespace disk_cache {
using StatsItems = base::StringPairs;
// This class stores cache-specific usage information, for tunning purposes.
class NET_EXPORT_PRIVATE Stats {
public:
static const int kDataSizesLength = 28;
enum Counters {
MIN_COUNTER = 0,
OPEN_MISS = MIN_COUNTER,
OPEN_HIT,
CREATE_MISS,
CREATE_HIT,
RESURRECT_HIT,
CREATE_ERROR,
TRIM_ENTRY,
DOOM_ENTRY,
DOOM_CACHE,
INVALID_ENTRY,
OPEN_ENTRIES, // Average number of open entries.
MAX_ENTRIES, // Maximum number of open entries.
TIMER,
READ_DATA,
WRITE_DATA,
OPEN_RANKINGS, // An entry has to be read just to modify rankings.
GET_RANKINGS, // We got the ranking info without reading the whole entry.
FATAL_ERROR,
LAST_REPORT, // Time of the last time we sent a report.
LAST_REPORT_TIMER, // Timer count of the last time we sent a report.
DOOM_RECENT, // The cache was partially cleared.
UNUSED, // Was: ga.js was evicted from the cache.
MAX_COUNTER
};
Stats();
~Stats();
// Initializes this object with |data| from disk.
bool Init(void* data, int num_bytes, Addr address);
// Generates a size distribution histogram.
void InitSizeHistogram();
// Returns the number of bytes needed to store the stats on disk.
int StorageSize();
// Tracks changes to the stoage space used by an entry.
void ModifyStorageStats(int32_t old_size, int32_t new_size);
// Tracks general events.
void OnEvent(Counters an_event);
void SetCounter(Counters counter, int64_t value);
int64_t GetCounter(Counters counter) const;
void GetItems(StatsItems* items);
int GetHitRatio() const;
int GetResurrectRatio() const;
void ResetRatios();
// Returns the lower bound of the space used by entries bigger than 512 KB.
int GetLargeEntriesSize();
// Writes the stats into |data|, to be stored at the given cache address.
// Returns the number of bytes copied.
int SerializeStats(void* data, int num_bytes, Addr* address);
private:
// Supports generation of SizeStats histogram data.
int GetBucketRange(size_t i) const;
int GetStatsBucket(int32_t size);
int GetRatio(Counters hit, Counters miss) const;
Addr storage_addr_;
int data_sizes_[kDataSizesLength];
int64_t counters_[MAX_COUNTER];
DISALLOW_COPY_AND_ASSIGN(Stats);
};
} // namespace disk_cache
#endif // NET_DISK_CACHE_BLOCKFILE_STATS_H_