-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathxallocator.h
105 lines (91 loc) · 3.92 KB
/
xallocator.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
#ifndef _XALLOCATOR_H
#define _XALLOCATOR_H
#include <stddef.h>
#include "DataTypes.h"
// @see https://github.com/endurodave/xallocator
// David Lafreniere
#ifdef __cplusplus
// Define AUTOMATIC_XALLOCATOR_INIT_DESTROY to automatically call xalloc_init() and
// xalloc_destroy() when using xallocator in C++ projects. On embedded systems that
// never exit, you can save 1-byte of RAM storage per translation unit by undefining
// AUTOMATIC_XALLOCATOR_INIT_DESTROY and calling xalloc_init() manually before the OS
// starts.
#define AUTOMATIC_XALLOCATOR_INIT_DESTROY
#ifdef AUTOMATIC_XALLOCATOR_INIT_DESTROY
/// If a C++ translation unit, create a static instance of XallocInitDestroy. Any C++
/// file including xallocator.h will have the xallocDestroy instance declared first
/// within the translation unit and thus will be constructed first. Destruction
/// will occur in the reverse order so xallocInitDestroy is called last. This way,
/// any static user objects relying on xallocator will be destroyed first before
/// xalloc_destroy() is called.
/// Embedded systems that never exit can remove the XallocInitDestroy class entirely.
class XallocInitDestroy
{
public:
XallocInitDestroy();
~XallocInitDestroy();
private:
static INT refCount;
};
static XallocInitDestroy xallocInitDestroy;
#endif // AUTOMATIC_XALLOCATOR_INIT_DESTROY
#endif // __cplusplus
#ifdef __cplusplus
extern "C" {
#endif
/// This function must be called exactly one time before the operating system
/// threading starts. If using xallocator exclusively in C files within your application
/// code, you must call this function before the OS starts. If using C++, client code
/// does not call xalloc_init. Let XallocInitDestroy() call xalloc_init automatically.
/// Embedded systems that never exit can call xalloc_init() manually at startup
/// and eliminate XallocInitDestroy usage. When the system is still single threaded at
/// startup, the xallocator API does not need mutex protection.
void xalloc_init();
/// This function must be called once when the application exits. Never call xalloc_destroy()
/// manually except if using xallocator in a C-only application. If using xallocator
/// exclusively in C files within your application code, you must call this function before
/// the program exits. If using C++, ~XallocInitDestroy() must call xalloc_destroy automatically.
/// Embedded systems that never exit need not call this function at all.
void xalloc_destroy();
/// Allocate a block of memory
/// @param[in] size - the size of the block to allocate.
void *xmalloc(size_t size);
/// Frees a previously xalloc allocated block
/// @param[in] ptr - a pointer to a previously allocated memory using xalloc.
void xfree(void* ptr);
/// Reallocates an existing xalloc block to a new size
/// @param[in] ptr - a pointer to a previously allocated memory using xalloc.
/// @param[in] size - the size of the new block
void *xrealloc(void *ptr, size_t size);
/// Output allocator statistics to the standard output
void xalloc_stats();
// Macro to overload new/delete with xalloc/xfree. Add macro to any class to enable
// fixed-block memory allocation. Add to a base class provides fixed-block memory
// for the base and all derived classes.
#define XALLOCATOR \
public: \
void* operator new(size_t size) { \
return xmalloc(size); \
} \
void* operator new(size_t size, void* mem) { \
return mem; \
} \
void* operator new(size_t size, const std::nothrow_t& nt) { \
return xmalloc(size); \
} \
void* operator new[](size_t size) { \
return xmalloc(size); \
} \
void operator delete(void* pObject) { \
xfree(pObject); \
} \
void operator delete(void* pObject, const std::nothrow_t& nt) { \
xfree(pObject); \
} \
void operator delete[](void* pData) { \
xfree(pData); \
}
#ifdef __cplusplus
}
#endif
#endif