mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 12:41:49 +01:00
Optimizing to calloc() to malloc() + memset() can be bad on some platforms.
llvm-svn: 26732
This commit is contained in:
parent
3b4ceba4ff
commit
1fc1ed55c4
@ -1,33 +0,0 @@
|
||||
//===-- memory.c - String functions for the LLVM libc Library ----*- C -*-===//
|
||||
//
|
||||
// A lot of this code is ripped gratuitously from glibc and libiberty.
|
||||
//
|
||||
//===---------------------------------------------------------------------===//
|
||||
|
||||
#include <stdlib.h>
|
||||
|
||||
// If we're not being compiled with GCC, turn off attributes. Question is how
|
||||
// to handle overriding of memory allocation functions in that case.
|
||||
#ifndef __GNUC__
|
||||
#define __attribute__(X)
|
||||
#endif
|
||||
|
||||
// For now, turn off the weak linkage attribute on Mac OS X.
|
||||
#if defined(__GNUC__) && defined(__APPLE_CC__)
|
||||
#define __ATTRIBUTE_WEAK__
|
||||
#elif defined(__GNUC__)
|
||||
#define __ATTRIBUTE_WEAK__ __attribute__((weak))
|
||||
#else
|
||||
#define __ATTRIBUTE_WEAK__
|
||||
#endif
|
||||
|
||||
void *malloc(size_t) __ATTRIBUTE_WEAK__;
|
||||
void free(void *) __ATTRIBUTE_WEAK__;
|
||||
void *memset(void *, int, size_t) __ATTRIBUTE_WEAK__;
|
||||
void *calloc(size_t nelem, size_t elsize) __ATTRIBUTE_WEAK__;
|
||||
|
||||
void *calloc(size_t nelem, size_t elsize) {
|
||||
void *Result = malloc(nelem*elsize);
|
||||
if (Result) memset(Result, 0, nelem*elsize);
|
||||
return Result;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user