forked from LearningInfiniTensor/TinyInfiniTensor
-
Notifications
You must be signed in to change notification settings - Fork 98
Expand file tree
/
Copy pathallocator.cc
More file actions
110 lines (100 loc) · 3.38 KB
/
allocator.cc
File metadata and controls
110 lines (100 loc) · 3.38 KB
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
#include "core/allocator.h"
#include <utility>
namespace infini
{
Allocator::Allocator(Runtime runtime) : runtime(runtime)
{
used = 0;
peak = 0;
ptr = nullptr;
// 'alignment' defaults to sizeof(uint64_t), because it is the length of
// the longest data type currently supported by the DataType field of
// the tensor
alignment = sizeof(uint64_t);
}
Allocator::~Allocator()
{
if (this->ptr != nullptr)
{
runtime->dealloc(this->ptr);
}
}
size_t Allocator::alloc(size_t size)
{
IT_ASSERT(this->ptr == nullptr);
// pad the size to the multiple of alignment
size = this->getAlignedSize(size);
this->used += size;
// for(const auto &block : free_blocks) {//auto it = this->free_blocks.begin(); it != this->free_blocks.end();it++
// if(block.second >= size) {
// size_t addr = block.first;
// size_t block_size = block.second;
// free_blocks.erase(block.first);
// if(block_size > size) {
// free_blocks[addr + size] = block_size - size;
// }
// return addr;
// }
// }
for (auto it = this->free_blocks.begin(); it != this->free_blocks.end();
it++) {
if (it->second >= size) {
size_t addr = it->first;
size_t space = it->second - size;
this->free_blocks.erase(it);
if (space > 0) {
this->free_blocks[addr + size] = space;
}
return addr;
}
}
this->peak += size;
return this->peak - size;
// =================================== 作业 ===================================
// TODO: 设计一个算法来分配内存,返回起始地址偏移量
// =================================== 作业 ===================================
}
void Allocator::free(size_t addr, size_t size)
{
IT_ASSERT(this->ptr == nullptr);
size = getAlignedSize(size);
// =================================== 作业 ===================================
// TODO: 设计一个算法来回收内存
// =================================== 作业 ===================================
this->used -= size;
if (addr + size == this->peak) {
this->peak -= size;
return;
}
for (auto it = this->free_blocks.begin(); it != this->free_blocks.end();it++) {
if (it->first + it->second == addr) {
it->second += size;
return;
}
if (it->first == addr + size) {
this->free_blocks[addr] = size + it->second;
this->free_blocks.erase(it);
return;
}
}
this->free_blocks[addr] = size;
}
void *Allocator::getPtr()
{
if (this->ptr == nullptr)
{
this->ptr = runtime->alloc(this->peak);
printf("Allocator really alloc: %p %lu bytes\n", this->ptr, peak);
}
return this->ptr;
}
size_t Allocator::getAlignedSize(size_t size)
{
return ((size - 1) / this->alignment + 1) * this->alignment;
}
void Allocator::info()
{
std::cout << "Used memory: " << this->used
<< ", peak memory: " << this->peak << std::endl;
}
}