292e1fe23b5f8a070eac5a165aad5dac2b052818
[platform/upstream/v8.git] / src / allocation.h
1 // Copyright 2012 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef V8_ALLOCATION_H_
6 #define V8_ALLOCATION_H_
7
8 #include "src/globals.h"
9
10 namespace v8 {
11 namespace internal {
12
13 // Called when allocation routines fail to allocate.
14 // This function should not return, but should terminate the current
15 // processing.
16 void FatalProcessOutOfMemory(const char* message);
17
18 // Superclass for classes managed with new & delete.
19 class Malloced {
20  public:
21   void* operator new(size_t size) { return New(size); }
22   void  operator delete(void* p) { Delete(p); }
23
24   static void* New(size_t size);
25   static void Delete(void* p);
26 };
27
28
29 // A macro is used for defining the base class used for embedded instances.
30 // The reason is some compilers allocate a minimum of one word for the
31 // superclass. The macro prevents the use of new & delete in debug mode.
32 // In release mode we are not willing to pay this overhead.
33
34 #ifdef DEBUG
35 // Superclass for classes with instances allocated inside stack
36 // activations or inside other objects.
37 class Embedded {
38  public:
39   void* operator new(size_t size);
40   void  operator delete(void* p);
41 };
42 #define BASE_EMBEDDED : public Embedded
43 #else
44 #define BASE_EMBEDDED
45 #endif
46
47
48 // Superclass for classes only using statics.
49 class AllStatic {
50 #ifdef DEBUG
51  public:
52   void* operator new(size_t size);
53   void operator delete(void* p);
54 #endif
55 };
56
57
58 template <typename T>
59 T* NewArray(size_t size) {
60   T* result = new T[size];
61   if (result == NULL) FatalProcessOutOfMemory("NewArray");
62   return result;
63 }
64
65
66 template <typename T>
67 void DeleteArray(T* array) {
68   delete[] array;
69 }
70
71
72 // The normal strdup functions use malloc.  These versions of StrDup
73 // and StrNDup uses new and calls the FatalProcessOutOfMemory handler
74 // if allocation fails.
75 char* StrDup(const char* str);
76 char* StrNDup(const char* str, int n);
77
78
79 // Allocation policy for allocating in the C free store using malloc
80 // and free. Used as the default policy for lists.
81 class FreeStoreAllocationPolicy {
82  public:
83   INLINE(void* New(size_t size)) { return Malloced::New(size); }
84   INLINE(static void Delete(void* p)) { Malloced::Delete(p); }
85 };
86
87
88 void* AlignedAlloc(size_t size, size_t alignment);
89 void AlignedFree(void *ptr);
90
91 } }  // namespace v8::internal
92
93 #endif  // V8_ALLOCATION_H_