-
Notifications
You must be signed in to change notification settings - Fork 59
/
Copy pathmmap_allocator.h
145 lines (131 loc) · 3.6 KB
/
mmap_allocator.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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
#ifndef _MMAP_ALLOCATOR_H
#define _MMAP_ALLOCATOR_H
#include <memory>
#include <string>
#include <stdio.h>
#include <vector>
#include "mmap_access_mode.h"
#include "mmap_exception.h"
#include "mmap_file_pool.h"
namespace mmap_allocator_namespace
{
template <typename T, typename A>
class mmappable_vector;
template <typename T>
class mmap_allocator: public std::allocator<T>
{
public:
typedef size_t size_type;
typedef off_t offset_type;
typedef T* pointer;
typedef const T* const_pointer;
template<typename _Tp1>
struct rebind
{
typedef mmap_allocator<_Tp1> other;
};
pointer allocate(size_type n, const void *hint=0)
{
void *the_pointer;
if (get_verbosity() > 0) {
fprintf(stderr, "Alloc %zd bytes.\n", n*sizeof(T));
}
if (access_mode == DEFAULT_STL_ALLOCATOR) {
return std::allocator<T>::allocate(n, hint);
} else {
if (n == 0) {
return NULL;
}
if (bypass_file_pool) {
the_pointer = private_file.open_and_mmap_file(filename, access_mode, offset, n*sizeof(T), map_whole_file, allow_remap);
} else {
the_pointer = the_pool.mmap_file(filename, access_mode, offset, n*sizeof(T), map_whole_file, allow_remap);
}
if (the_pointer == NULL) {
throw(mmap_allocator_exception("Couldn't mmap file, mmap_file returned NULL"));
}
if (get_verbosity() > 0) {
fprintf(stderr, "pointer = %p\n", the_pointer);
}
return (pointer)the_pointer;
}
}
void deallocate(pointer p, size_type n)
{
if (get_verbosity() > 0) {
fprintf(stderr, "Dealloc %zd bytes (%p).\n", n*sizeof(T), p);
}
if (access_mode == DEFAULT_STL_ALLOCATOR) {
std::allocator<T>::deallocate(p, n);
} else {
if (n == 0) {
return;
}
if (bypass_file_pool) {
private_file.munmap_and_close_file();
} else {
if (!keep_forever) {
the_pool.munmap_file(filename, access_mode, offset, n*sizeof(T));
}
}
}
}
mmap_allocator() throw():
std::allocator<T>(),
filename(""),
offset(0),
access_mode(DEFAULT_STL_ALLOCATOR),
map_whole_file(false),
allow_remap(false),
bypass_file_pool(false),
private_file(),
keep_forever(false)
{ }
mmap_allocator(const std::allocator<T> &a) throw():
std::allocator<T>(a),
filename(""),
offset(0),
access_mode(DEFAULT_STL_ALLOCATOR),
map_whole_file(false),
allow_remap(false),
bypass_file_pool(false),
private_file(),
keep_forever(false)
{ }
mmap_allocator(const mmap_allocator &a) throw():
std::allocator<T>(a),
filename(a.filename),
offset(a.offset),
access_mode(a.access_mode),
map_whole_file(a.map_whole_file),
allow_remap(a.allow_remap),
bypass_file_pool(a.bypass_file_pool),
private_file(a.private_file),
keep_forever(a.keep_forever)
{ }
mmap_allocator(const std::string filename_param, enum access_mode access_mode_param = READ_ONLY, offset_type offset_param = 0, int flags = 0) throw():
std::allocator<T>(),
filename(filename_param),
offset(offset_param),
access_mode(access_mode_param),
map_whole_file((flags & MAP_WHOLE_FILE) != 0),
allow_remap((flags & ALLOW_REMAP) != 0),
bypass_file_pool((flags & BYPASS_FILE_POOL) != 0),
private_file(),
keep_forever((flags & KEEP_FOREVER) != 0)
{
}
~mmap_allocator() throw() { }
private:
friend class mmappable_vector<T, mmap_allocator<T> >;
std::string filename;
offset_type offset;
enum access_mode access_mode;
bool map_whole_file;
bool allow_remap;
bool bypass_file_pool;
mmapped_file private_file; /* used if bypass is set */
bool keep_forever;
};
}
#endif /* _MMAP_ALLOCATOR_H */