OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_METRICS_LEAK_DETECTOR_LEAK_DETECTOR_CONTROLLER_H_ | 5 #ifndef CHROME_BROWSER_METRICS_LEAK_DETECTOR_LEAK_DETECTOR_CONTROLLER_H_ |
6 #define CHROME_BROWSER_METRICS_LEAK_DETECTOR_LEAK_DETECTOR_CONTROLLER_H_ | 6 #define CHROME_BROWSER_METRICS_LEAK_DETECTOR_LEAK_DETECTOR_CONTROLLER_H_ |
7 | 7 |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
10 #include <vector> | 10 #include <vector> |
(...skipping 17 matching lines...) Expand all Loading... |
28 | 28 |
29 // Retrieves all reports in |stored_reports_|, moving them to |*reports|. | 29 // Retrieves all reports in |stored_reports_|, moving them to |*reports|. |
30 // |stored_reports_| is empty afterwards. | 30 // |stored_reports_| is empty afterwards. |
31 void GetLeakReports(std::vector<MemoryLeakReportProto>* reports); | 31 void GetLeakReports(std::vector<MemoryLeakReportProto>* reports); |
32 | 32 |
33 protected: | 33 protected: |
34 // LeakDetector::Observer: | 34 // LeakDetector::Observer: |
35 void OnLeaksFound(const std::vector<MemoryLeakReportProto>& reports) override; | 35 void OnLeaksFound(const std::vector<MemoryLeakReportProto>& reports) override; |
36 | 36 |
37 // LeakDetectorRemoteController::LocalController: | 37 // LeakDetectorRemoteController::LocalController: |
38 MemoryLeakReportProto::Params GetParams() const override; | 38 MemoryLeakReportProto::Params GetParamsAndRecordRequest() override; |
39 void SendLeakReports( | 39 void SendLeakReports( |
40 const std::vector<MemoryLeakReportProto>& reports) override; | 40 const std::vector<MemoryLeakReportProto>& reports) override; |
41 void OnRemoteProcessShutdown() override; | 41 void OnRemoteProcessShutdown() override; |
42 | 42 |
43 private: | 43 private: |
| 44 // Returns true to indicate that LeakDetector should be enabled on a renderer |
| 45 // process. This is determined as follows: |
| 46 // 1. If the number of processes running LeakDetector is not at max, returns |
| 47 // true with a probability of |per_process_enable_probability_|. |
| 48 // 2. If the number of processes running LeakDetector has reached the max, |
| 49 // returns false. |
| 50 bool ShouldRandomlyEnableLeakDetectorOnRendererProcess() const; |
| 51 |
44 // Stores a given array of leak reports in |stored_reports_|. |process_type| | 52 // Stores a given array of leak reports in |stored_reports_|. |process_type| |
45 // is the type of process that generated these reports. The reports must all | 53 // is the type of process that generated these reports. The reports must all |
46 // come from the same process type. | 54 // come from the same process type. |
47 void StoreLeakReports(const std::vector<MemoryLeakReportProto>& reports, | 55 void StoreLeakReports(const std::vector<MemoryLeakReportProto>& reports, |
48 MemoryLeakReportProto::ProcessType process_type); | 56 MemoryLeakReportProto::ProcessType process_type); |
49 | 57 |
50 // All leak reports received through OnLeakFound() are stored in protobuf | 58 // All leak reports received through OnLeakFound() are stored in protobuf |
51 // format. | 59 // format. |
52 std::vector<MemoryLeakReportProto> stored_reports_; | 60 std::vector<MemoryLeakReportProto> stored_reports_; |
53 | 61 |
54 // Contains all the parameters passed to LeakDetector. Store them in a single | 62 // Contains all the parameters passed to LeakDetector. Store them in a single |
55 // protobuf message instead of in separate member variables. | 63 // protobuf message instead of in separate member variables. |
56 const MemoryLeakReportProto::Params params_; | 64 const MemoryLeakReportProto::Params params_; |
57 | 65 |
58 // The build ID of the current Chrome binary. | 66 // The build ID of the current Chrome binary. |
59 std::vector<uint8_t> build_id_; | 67 std::vector<uint8_t> build_id_; |
60 | 68 |
| 69 // The probability that each process will have the leak detector enabled on |
| 70 // it. For remote processes, this is determined by sending |params_| for |
| 71 // initialization. If the remote process is not to have leak detector enabled, |
| 72 // |params_.sampling_rate()| will be set to 0. Whether or not to enable for a |
| 73 // particular process is independent of the decision for all other processes. |
| 74 double browser_process_enable_probability_; |
| 75 double renderer_process_enable_probability_; |
| 76 |
| 77 // The maximum allowed number of renderer processes with leak detector running |
| 78 // simultaneously. |
| 79 int max_renderer_processes_with_leak_detector_enabled_; |
| 80 |
| 81 // The number of renderer processes on which the leak detector has been |
| 82 // enabled and is running. |
| 83 int num_renderer_processes_with_leak_detector_enabled_; |
| 84 |
61 // For thread safety. | 85 // For thread safety. |
62 base::ThreadChecker thread_checker_; | 86 base::ThreadChecker thread_checker_; |
63 | 87 |
64 DISALLOW_COPY_AND_ASSIGN(LeakDetectorController); | 88 DISALLOW_COPY_AND_ASSIGN(LeakDetectorController); |
65 }; | 89 }; |
66 | 90 |
67 } // namespace metrics | 91 } // namespace metrics |
68 | 92 |
69 #endif // CHROME_BROWSER_METRICS_LEAK_DETECTOR_LEAK_DETECTOR_CONTROLLER_H_ | 93 #endif // CHROME_BROWSER_METRICS_LEAK_DETECTOR_LEAK_DETECTOR_CONTROLLER_H_ |
OLD | NEW |