summaryrefslogtreecommitdiff
path: root/indra/llcommon/llmemory.h
diff options
context:
space:
mode:
authorKarl Stiefvater (qarl) <qarl@lindenlab.com>2010-05-24 17:10:21 -0500
committerKarl Stiefvater (qarl) <qarl@lindenlab.com>2010-05-24 17:10:21 -0500
commit62059a05cfa2b4b08fde13122997bd2a7ebbbc67 (patch)
treee6da9e6ae2cf49d74e68b837b23fed7a5dc9d5e8 /indra/llcommon/llmemory.h
parent52134bdc817ebfdea7733432e43e8e350944ab2e (diff)
fix aligned malloc for osx. reviewed by falcon.
Diffstat (limited to 'indra/llcommon/llmemory.h')
-rw-r--r--indra/llcommon/llmemory.h12
1 files changed, 8 insertions, 4 deletions
diff --git a/indra/llcommon/llmemory.h b/indra/llcommon/llmemory.h
index f0813fb4ee..071a122c95 100644
--- a/indra/llcommon/llmemory.h
+++ b/indra/llcommon/llmemory.h
@@ -34,13 +34,15 @@
#include <stdlib.h>
-inline void* ll_aligned_malloc(size_t size, size_t alignment = 16) // alignment MUST be power-of-two multiple of sizeof(void*). returned hunk MUST be freed with ll_aligned_free().
+inline void* ll_aligned_malloc_16(size_t size) // returned hunk MUST be freed with ll_aligned_free().
{
#if defined(LL_WINDOWS)
- return _mm_malloc(size, alignment);
+ return _mm_malloc(size, 16);
+#elif defined(LL_DARWIN)
+ return malloc(size); // default osx malloc is 16 byte aligned.
#else
void *rtn;
- if (LL_LIKELY(0 == posix_memalign(&rtn, alignment, size)))
+ if (LL_LIKELY(0 == posix_memalign(&rtn, alignment, 16)))
{
return rtn;
}
@@ -51,10 +53,12 @@ inline void* ll_aligned_malloc(size_t size, size_t alignment = 16) // alignment
#endif
}
-inline void ll_aligned_free(void *p)
+inline void ll_aligned_free_16(void *p)
{
#if defined(LL_WINDOWS)
_mm_free(p);
+#elif defined(LL_DARWIN)
+ return free(p);
#else
free(p); // posix_memalign() is compatible with heap deallocator
#endif