普通文本  |  147行  |  3.19 KB

// Copyright (c) 2011 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.

#include "net/base/file_stream_metrics.h"

#include <windows.h>

#include "base/basictypes.h"

namespace net {

namespace {

struct Range {
  int low;
  int high;
};

// The error range list is extracted from WinError.h.
//
// NOTE: The gaps between the ranges need to be recorded too.
// They will have odd-numbered buckets.
const Range kErrorRangeList[] = {
  { 0, 321 },  // 2.
  { 335, 371 },  // 4.
  { 383, 387 },  // 6.
  { 399, 404 },  // etc.
  { 415, 418 },
  { 431, 433 },
  { 447, 868 },
  { 994, 1471 },
  { 1500, 1513 },
  { 1536, 1553 },
  { 1601, 1654 },
  { 1700, 1834 },
  { 1898, 1938 },
  { 2000, 2024 },
  { 2048, 2085 },
  { 2108, 2110 },
  { 2202, 2203 },
  { 2250, 2251 },
  { 2401, 2405 },
  { 3000, 3021 },
  { 3950, 3951 },
  { 4000, 4007 },
  { 4050, 4066 },
  { 4096, 4116 },
  { 4200, 4215 },
  { 4300, 4353 },
  { 4390, 4395 },
  { 4500, 4501 },
  { 4864, 4905 },
  { 5001, 5090 },
  { 5890, 5953 },
  { 6000, 6023 },
  { 6118, 6119 },
  { 6200, 6201 },
  { 6600, 6649 },
  { 6700, 6732 },
  { 6800, 6856 },
  { 7001, 7071 },
  { 8001, 8018 },
  { 8192, 8263 },
  { 8301, 8640 },
  { 8704, 8705 },
  { 8960, 9053 },
  { 9216, 9218 },
  { 9263, 9276 },
  { 9472, 9506 },
  { 9550, 9573 },
  { 9600, 9622 },
  { 9650, 9656 },
  { 9688, 9723 },
  { 9750, 9754 },
  { 9800, 9802 },
  { 9850, 9853 },
  { 9900, 9907 },
  { 10000, 10072 },
  { 10091, 10113 },
  { 11001, 11034 },
  { 12288, 12335 },
  { 12544, 12559 },
  { 12595, 12597 },
  { 12801, 12803 },
  { 13000, 13026 },
  { 13800, 13933 },
  { 14000, 14111 },
  { 15000, 15039 },
  { 15080, 15086 },
  { 15100, 15109 },
  { 15200, 15208 },
  { 15250, 15251 },
  { 15299, 15302 },
  { 16385, 16436 },
  { 18432, 18454 },
  { 20480, 20486 },
  { 24577, 24607 },
  { 28673, 28698 },
  { 32790, 32816 },
  { 33281, 33322 },
  { 35005, 35024 },
  { 36000, 36004 },
  { 40010, 40011 },
  { 40067, 40069 },
  { 53248, 53293 },
  { 53376, 53382 },
  { 57344, 57360 },
  { 57377, 57394 },
  { 65535, 65536 }  // 2 * kNumErrorRanges.
};
const size_t kNumErrorRanges = ARRAYSIZE_UNSAFE(kErrorRangeList);

}  // namespace

// Windows has very many errors.  We're not interested in most of them, but we
// don't know which ones are significant.
// This function maps error ranges to specific buckets.
// If we get hits on the buckets, we can add those values to the values we
// record individually.
// If we get values *between* the buckets, we record those as buckets too.
int GetFileErrorUmaBucket(int error) {
  error = HRESULT_CODE(error);

  // This is a linear search, but of a short fixed-size array.
  // It also gets called infrequently, on errors.
  for (size_t n = 0; n < kNumErrorRanges; ++n) {
    if (error < kErrorRangeList[n].low)
      return (2 * (n + 1)) - 1;  // In gap before the range.
    if (error <= kErrorRangeList[n].high)
      return 2 * (n + 1);  // In the range.
  }

  // After the last bucket.
  return 2 * kNumErrorRanges + 1;
}

int MaxFileErrorUmaBucket() {
  return 2 * kNumErrorRanges + 2;
}

int MaxFileErrorUmaValue() {
  return kErrorRangeList[0].high + 1;
}

}  // namespace net