Cycles: Throw bad_alloc exception when custom allocators failed to allocate memory
This mimics behavior of default allocators in STL and allows all the routines to catch out-of-memory exceptions and hopefully recover from that situation/
This commit is contained in:
parent
d7e4f920fd
commit
e3544c9e28
@ -53,19 +53,24 @@ public:
|
||||
size_t size = n * sizeof(T);
|
||||
util_guarded_mem_alloc(size);
|
||||
(void)hint;
|
||||
#ifdef WITH_BLENDER_GUARDEDALLOC
|
||||
if(n == 0) {
|
||||
return NULL;
|
||||
}
|
||||
T *mem;
|
||||
#ifdef WITH_BLENDER_GUARDEDALLOC
|
||||
/* C++ standard requires allocation functions to allocate memory suitably
|
||||
* aligned for any standard type. This is 16 bytes for 64 bit platform as
|
||||
* far as i concerned. We might over-align on 32bit here, but that should
|
||||
* be all safe actually.
|
||||
*/
|
||||
return (T*)MEM_mallocN_aligned(size, 16, "Cycles Alloc");
|
||||
mem = (T*)MEM_mallocN_aligned(size, 16, "Cycles Alloc");
|
||||
#else
|
||||
return (T*)malloc(size);
|
||||
mem = (T*)malloc(size);
|
||||
#endif
|
||||
if(mem == NULL) {
|
||||
throw std::bad_alloc();
|
||||
}
|
||||
return mem;
|
||||
}
|
||||
|
||||
void deallocate(T *p, size_t n)
|
||||
@ -97,7 +102,9 @@ public:
|
||||
|
||||
void construct(T *p, const T& val)
|
||||
{
|
||||
new ((T *)p) T(val);
|
||||
if(p != NULL) {
|
||||
new ((T *)p) T(val);
|
||||
}
|
||||
}
|
||||
|
||||
void destroy(T *p)
|
||||
|
@ -60,11 +60,15 @@ public:
|
||||
if(pointer_ + n >= SIZE) {
|
||||
size_t size = n * sizeof(T);
|
||||
util_guarded_mem_alloc(size);
|
||||
T *mem;
|
||||
#ifdef WITH_BLENDER_GUARDEDALLOC
|
||||
return (T*)MEM_mallocN_aligned(size, 16, "Cycles Alloc");
|
||||
mem = (T*)MEM_mallocN_aligned(size, 16, "Cycles Alloc");
|
||||
#else
|
||||
return (T*)malloc(size);
|
||||
mem = (T*)malloc(size);
|
||||
#endif
|
||||
if(mem == NULL) {
|
||||
throw std::bad_alloc();
|
||||
}
|
||||
}
|
||||
T *mem = &data_[pointer_];
|
||||
pointer_ += n;
|
||||
@ -104,7 +108,9 @@ public:
|
||||
|
||||
void construct(T *p, const T& val)
|
||||
{
|
||||
new ((T *)p) T(val);
|
||||
if(p != NULL) {
|
||||
new ((T *)p) T(val);
|
||||
}
|
||||
}
|
||||
|
||||
void destroy(T *p)
|
||||
|
@ -218,10 +218,16 @@ public:
|
||||
protected:
|
||||
inline T* mem_allocate(size_t N)
|
||||
{
|
||||
if(N == 0) {
|
||||
return NULL;
|
||||
}
|
||||
T *mem = (T*)util_aligned_malloc(sizeof(T)*N, alignment);
|
||||
if(mem != NULL) {
|
||||
util_guarded_mem_alloc(sizeof(T)*N);
|
||||
}
|
||||
else {
|
||||
throw std::bad_alloc();
|
||||
}
|
||||
return mem;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user