Home | History | Annotate | Download | only in src
      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 FatalProcessOutOfMemory();
     25   static void* New(size_t size);
     26   static void Delete(void* p);
     27 };
     28 
     29 
     30 // A macro is used for defining the base class used for embedded instances.
     31 // The reason is some compilers allocate a minimum of one word for the
     32 // superclass. The macro prevents the use of new & delete in debug mode.
     33 // In release mode we are not willing to pay this overhead.
     34 
     35 #ifdef DEBUG
     36 // Superclass for classes with instances allocated inside stack
     37 // activations or inside other objects.
     38 class Embedded {
     39  public:
     40   void* operator new(size_t size);
     41   void  operator delete(void* p);
     42 };
     43 #define BASE_EMBEDDED : public Embedded
     44 #else
     45 #define BASE_EMBEDDED
     46 #endif
     47 
     48 
     49 // Superclass for classes only using statics.
     50 class AllStatic {
     51 #ifdef DEBUG
     52  public:
     53   void* operator new(size_t size);
     54   void operator delete(void* p);
     55 #endif
     56 };
     57 
     58 
     59 template <typename T>
     60 T* NewArray(size_t size) {
     61   T* result = new T[size];
     62   if (result == NULL) Malloced::FatalProcessOutOfMemory();
     63   return result;
     64 }
     65 
     66 
     67 template <typename T>
     68 void DeleteArray(T* array) {
     69   delete[] array;
     70 }
     71 
     72 
     73 // The normal strdup functions use malloc.  These versions of StrDup
     74 // and StrNDup uses new and calls the FatalProcessOutOfMemory handler
     75 // if allocation fails.
     76 char* StrDup(const char* str);
     77 char* StrNDup(const char* str, int n);
     78 
     79 
     80 // Allocation policy for allocating in the C free store using malloc
     81 // and free. Used as the default policy for lists.
     82 class FreeStoreAllocationPolicy {
     83  public:
     84   INLINE(void* New(size_t size)) { return Malloced::New(size); }
     85   INLINE(static void Delete(void* p)) { Malloced::Delete(p); }
     86 };
     87 
     88 
     89 void* AlignedAlloc(size_t size, size_t alignment);
     90 void AlignedFree(void *ptr);
     91 
     92 } }  // namespace v8::internal
     93 
     94 #endif  // V8_ALLOCATION_H_
     95