diff options
author | Daniel Dunbar <daniel@zuster.org> | 2011-11-29 19:44:14 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2011-11-29 19:44:14 +0000 |
commit | e2ed5fb636bc4735694e917408f4bbf9fd34af71 (patch) | |
tree | a0e09c3bda65b827af72b5c405d33d1f93580572 /compiler-rt/lib/int_util.c | |
parent | b2d03a6d003a9255655321b649117a010b8efe7f (diff) | |
download | bcm5719-llvm-e2ed5fb636bc4735694e917408f4bbf9fd34af71.tar.gz bcm5719-llvm-e2ed5fb636bc4735694e917408f4bbf9fd34af71.zip |
lib/int_util: My refactoring to allow shared utility code had a fatal flaw when
multiple .a files would end up with duplicate strong definitions. This could
cause link failures in certain scenarios when both definitions got loaded.
- The best solution I see for this (aside from not factoring out the utility
code) is to mark the definitions weak. Better solutions appreciated!
llvm-svn: 145427
Diffstat (limited to 'compiler-rt/lib/int_util.c')
-rw-r--r-- | compiler-rt/lib/int_util.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/compiler-rt/lib/int_util.c b/compiler-rt/lib/int_util.c index 2dc4d2ee926..f19476864b1 100644 --- a/compiler-rt/lib/int_util.c +++ b/compiler-rt/lib/int_util.c @@ -11,6 +11,16 @@ #include "int_util.h" #include "int_lib.h" +/* NOTE: The definitions in this file are declared weak because we clients to be + * able to arbitrarily package individual functions into separate .a files. If + * we did not declare these weak, some link situations might end up seeing + * duplicate strong definitions of the same symbol. + * + * We can't use this solution for kernel use (which may not support weak), but + * currently expect that when built for kernel use all the functionality is + * packaged into a single library. + */ + #ifdef KERNEL_USE extern void panic(const char *, ...) __attribute__((noreturn)); @@ -24,6 +34,7 @@ void compilerrt_abort_impl(const char *file, int line, const char *function) { /* Get the system definition of abort() */ #include <stdlib.h> +__attribute__((weak)) __attribute__((visibility("hidden"))) void compilerrt_abort_impl(const char *file, int line, const char *function) { abort(); |