forked from youtube/cobalt_sandbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmemory_reporter.h
105 lines (88 loc) · 3.95 KB
/
memory_reporter.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
// Copyright 2016 The Cobalt Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// Module Overview: Memory Reporting API.
//
// Provides an interface for memory reporting.
#ifndef STARBOARD_MEMORY_REPORTER_H_
#define STARBOARD_MEMORY_REPORTER_H_
#include "starboard/configuration.h"
#include "starboard/export.h"
#include "starboard/types.h"
#ifdef __cplusplus
extern "C" {
#endif
///////////////////////////////////////////////////////////////////////////////
// These are callbacks used by SbMemoryReporter to report memory
// allocation and deallocation.
///////////////////////////////////////////////////////////////////////////////
// A function to report a memory allocation from SbMemoryAllocate(). Note that
// operator new calls SbMemoryAllocate which will delegate to this callback.
typedef void (*SbMemoryReporterOnAlloc)(void* context, const void* memory,
size_t size);
// A function to report a memory deallocation from SbMemoryDeallcoate(). Note
// that operator delete calls SbMemoryDeallocate which will delegate to this
// callback.
typedef void (*SbMemoryReporterOnDealloc)(void* context, const void* memory);
// A function to report a memory mapping from SbMemoryMap().
typedef void (*SbMemoryReporterOnMapMemory)(void* context, const void* memory,
size_t size);
// A function to report a memory unmapping from SbMemoryUnmap().
typedef void (*SbMemoryReporterOnUnMapMemory)(void* context,
const void* memory,
size_t size);
// SbMemoryReporter allows memory reporting via user-supplied functions.
// The void* context is passed to every call back.
// It's strongly recommended that C-Style struct initialization is used
// so that the arguments can be typed check by the compiler.
// For example,
// SbMemoryReporter mem_reporter = { MallocCallback, .... context };
struct SbMemoryReporter {
// Callback to report allocations.
SbMemoryReporterOnAlloc on_alloc_cb;
// Callback to report deallocations.
SbMemoryReporterOnDealloc on_dealloc_cb;
// Callback to report memory map.
SbMemoryReporterOnMapMemory on_mapmem_cb;
// Callback to report memory unmap.
SbMemoryReporterOnUnMapMemory on_unmapmem_cb;
// Optional, is passed to callbacks as first argument.
void* context;
};
// Sets the MemoryReporter. Any previous memory reporter is unset. No lifetime
// management is done internally on input pointer.
//
// Returns true if the memory reporter was set with no errors. If an error
// was reported then check the log for why it failed.
//
// Note that other than a thread-barrier-write of the input pointer, there is
// no thread safety guarantees with this function due to performance
// considerations. It's recommended that this be called once during the
// lifetime of the program, or not at all. Do not delete the supplied pointer,
// ever.
// Example (Good):
// SbMemoryReporter* mem_reporter = new ...;
// SbMemorySetReporter(&mem_reporter);
// ...
// SbMemorySetReporter(NULL); // allow value to leak.
// Example (Bad):
// SbMemoryReporter* mem_reporter = new ...;
// SbMemorySetReporter(&mem_reporter);
// ...
// SbMemorySetReporter(NULL);
// delete mem_reporter; // May crash.
SB_EXPORT bool SbMemorySetReporter(struct SbMemoryReporter* tracker);
#ifdef __cplusplus
} // extern "C"
#endif
#endif // STARBOARD_MEMORY_REPORTER_H_