summaryrefslogtreecommitdiffstats
path: root/compiler-rt/lib/int_util.c
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2011-11-29 19:44:14 +0000
committerDaniel Dunbar <daniel@zuster.org>2011-11-29 19:44:14 +0000
commite2ed5fb636bc4735694e917408f4bbf9fd34af71 (patch)
treea0e09c3bda65b827af72b5c405d33d1f93580572 /compiler-rt/lib/int_util.c
parentb2d03a6d003a9255655321b649117a010b8efe7f (diff)
downloadbcm5719-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.c11
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();
OpenPOWER on IntegriCloud