-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathlocal_address_space.cc
77 lines (61 loc) · 1.59 KB
/
local_address_space.cc
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
#include "address_space.h"
#include <cassert>
#include <sys/mman.h>
#include <gasnet.h>
#include <iostream>
#include "common.h"
class LocalNodeImpl : public Node {
public:
LocalNodeImpl(void *base, uintptr_t size) :
base_((char*)base), size_(size)
{
#if 0
std::cout << "local mem: base=" << base
<< " size=" << size << std::endl;
#endif
}
size_t size() {
return size_;
}
void read(void *dst, void *src, size_t len) {
char *abs_src = base_ + (uintptr_t)src;
assert((abs_src + len - 1) < (base_ + size_));
memcpy(dst, abs_src, len);
}
void write(void *dst, void *src, size_t len) {
char *abs_dst = base_ + (uintptr_t)dst;
assert((abs_dst + len - 1) < (base_ + size_));
memcpy(abs_dst, src, len);
}
void aio_read(group_io_handle_t handle, void *dst, void *src, size_t len) {
return read(dst, src, len);
}
void aio_write(group_io_handle_t handle, void *dst, void *src, size_t len) {
return write(dst, src, len);
}
private:
char *base_;
uintptr_t size_;
};
int LocalAddressSpace::init(struct gassyfs_opts *opts)
{
const size_t size = opts->heap_size << 20;
void *data = mmap(NULL, size, PROT_READ|PROT_WRITE,
MAP_PRIVATE|MAP_ANONYMOUS, -1, 0);
if (data == MAP_FAILED)
return -ENOMEM;
LocalNodeImpl *node = new LocalNodeImpl(data, size);
nodes_.push_back(node);
opts->rank0_alloc = 1;
return 0;
}
/*
* local mode aio becomes synchronous (i.e. memcpy)
*/
Node::group_io_handle_t LocalAddressSpace::group_io_start()
{
return NULL;
}
void LocalAddressSpace::group_io_wait(Node::group_io_handle_t handle)
{
}