OLD | NEW |
| (Empty) |
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 | |
3 // found in the LICENSE file. | |
4 | |
5 module metrics.mojom; | |
6 | |
7 struct LeakDetectorParams { | |
8 float sampling_rate; | |
9 uint32 max_stack_depth; | |
10 uint64 analysis_interval_bytes; | |
11 uint32 size_suspicion_threshold; | |
12 uint32 call_stack_suspicion_threshold; | |
13 }; | |
14 | |
15 struct AllocationBreakdown { | |
16 array<uint32> counts_by_size; | |
17 uint32 count_for_call_stack; | |
18 }; | |
19 | |
20 struct MemoryLeakReport { | |
21 uint32 size_bytes; | |
22 array<uint64> call_stack; | |
23 | |
24 array<AllocationBreakdown> alloc_breakdown_history; | |
25 }; | |
26 | |
27 // Provides a remote interface for enabling LeakDetector on remote processes. | |
28 interface LeakDetector { | |
29 // Returns a LeakDetectorParams struct. Used to indicate to the remote process | |
30 // what parameters to use when initializing LeakDetector. Can also return | |
31 // |params.sampling_rate| == 0 to indicate that LeakDetector should not be | |
32 // initialized on a particular process. | |
33 GetParams() => (LeakDetectorParams params); | |
34 | |
35 // When a remote process running LeakDetector gets some leak reports, it | |
36 // should call this function to return the leak reports back to the main | |
37 // process that implements this function. The reports should be sent back as | |
38 // an array of serialized MemoryLeakReportProtos. | |
39 SendLeakReports(array<MemoryLeakReport> reports); | |
40 }; | |
OLD | NEW |