-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathkernelallocator.cpp
More file actions
103 lines (77 loc) · 2.77 KB
/
kernelallocator.cpp
File metadata and controls
103 lines (77 loc) · 2.77 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
/***************************************************************************
* kernelallocator.cpp
*
* Copyright 2008 Matthias v.d. Vlies
* matthias@mserver.nl
****************************************************************************/
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
/*! \file kernelallocator.cpp
* \brief Kernel allocator
*
* This file implements the Kernel allocator class. The class manages all other Allocators and should be used
* to allocate memory. The KernelAllocator class will choose wich Allocator should be used for the request.
*
*/
#include <config.h>
#include <errors.h>
#include <core/kernelallocator.h>
#include <core/staticallocator.h>
// placement new function
inline void* operator new(unsigned int n, void* p) throw() {
// avoid warning
n = 0;
return p;
}
// set instance pointer to a null pointer
Core::KernelAllocator* Core::KernelAllocator::_instance = 0;
Core::KernelAllocator* Core::KernelAllocator::getInstance() {
// check for exsisting instance
if(_instance == 0) {
// none found, create new instance (with placement new)
_instance = new (reinterpret_cast<Core::KernelAllocator*>(STATIC_ALLOC_BASE)) Core::KernelAllocator();
// get the default allocator
_instance->_allocator = Core::StaticAllocator::getInstance(STATIC_ALLOC_BASE + sizeof(KernelAllocator));
}
// return the instance
return _instance;
}
unsigned long Core::KernelAllocator::allocate(unsigned long size) {
#ifdef DEBUG
this->allocations++;
#endif
return this->_allocator->allocate(size);
}
void Core::KernelAllocator::free(unsigned long address) {
#ifdef DEBUG
this->frees++;
#endif
this->_allocator->free(address);
}
Core::KernelAllocator::KernelAllocator() {
// dummy constructor
}
#ifdef DEBUG
void Core::KernelAllocator::printDebug() {
// TODO: implement me
}
#endif
unsigned long Core::KernelAllocator::startResource() {
return E_SUCCESS;
}
const char* Core::KernelAllocator::getResourceName() {
return "KernelAllocator";
}